/// <summary> /// Obte els recursos compartits d'un servidor CIFS NT /// </summary> /// <param name="server">Nom del servidor</param> /// <param name="shares">Colecció de recursos</param> protected static Shares EnumerateSharesNT(string server) { Shares shares = new Shares(); Share s; int level = 2; int entriesRead, totalEntries, nRet, hResume = 0; IntPtr pBuffer = IntPtr.Zero; try { nRet = WrapperWin32Api.NetShareEnum(server, level, out pBuffer, -1, out entriesRead, out totalEntries, ref hResume); if (WrapperWin32Api.ERROR_ACCESS_DENIED == nRet) { //depenent del tipus de nivell d'acces que tenim la consulta obtindrà un tipus de dades // o un altres, això afectarà a l'estructura on es carrega el resultat level = 1; nRet = WrapperWin32Api.NetShareEnum(server, level, out pBuffer, -1, out entriesRead, out totalEntries, ref hResume); } if (WrapperWin32Api.NO_ERROR == nRet && entriesRead > 0) { Type t = (2 == level) ? typeof(WrapperWin32Api.SHARE_INFO_2) : typeof(WrapperWin32Api.SHARE_INFO_1); int offset = Marshal.SizeOf(t); for (int i = 0, lpItem = pBuffer.ToInt32(); i < entriesRead; i++, lpItem += offset) { IntPtr pItem = new IntPtr(lpItem); if (1 == level) //estructura basica { WrapperWin32Api.SHARE_INFO_1 si = (WrapperWin32Api.SHARE_INFO_1)Marshal.PtrToStructure(pItem, t); s = new Share(); s.comment = si.Remark; s.name = si.NetName; s.type = CommonShareTypes(si.ShareType); shares.addShare(s); } else //estructura amb més informació, però seguirem agafant la mateixa { WrapperWin32Api.SHARE_INFO_2 si = (WrapperWin32Api.SHARE_INFO_2)Marshal.PtrToStructure(pItem, t); s = new Share(); s.comment = si.Remark; s.name = si.NetName; s.type = CommonShareTypes(si.ShareType); shares.addShare(s); } } } return(shares); } finally { // Netejem el buffer if (IntPtr.Zero != pBuffer) { WrapperWin32Api.NetApiBufferFree(pBuffer); } } }
/// <summary> /// Obte els recursos compartits d'un servidor CIFS NTWindows 9x /// </summary> /// <param name="server">Nom del servidor</param> /// <param name="shares">Colecció de recursos</param> protected static Shares EnumerateShares9x(string server) { Shares shares = new Shares(); Share s; int level = 50; int nRet = 0; ushort entriesRead, totalEntries; Type t = typeof(WrapperWin32Api.SHARE_INFO_2_9x); int size = Marshal.SizeOf(t); ushort cbBuffer = (ushort)(WrapperWin32Api.MAX_SI50_ENTRIES * size); //A Win9x, s'ha de reserva la memòria del buffer abans de cridar l'API IntPtr pBuffer = Marshal.AllocHGlobal(cbBuffer); try { nRet = WrapperWin32Api.NetShareEnum(server, level, pBuffer, cbBuffer, out entriesRead, out totalEntries); if (WrapperWin32Api.ERROR_WRONG_LEVEL == nRet) { level = 1; //el matix problema del permisos i les estructures de retorn de dades t = typeof(WrapperWin32Api.SHARE_INFO_1_9x); size = Marshal.SizeOf(t); nRet = WrapperWin32Api.NetShareEnum(server, level, pBuffer, cbBuffer, out entriesRead, out totalEntries); } if (WrapperWin32Api.NO_ERROR == nRet || WrapperWin32Api.ERROR_MORE_DATA == nRet) { for (int i = 0, lpItem = pBuffer.ToInt32(); i < entriesRead; i++, lpItem += size) { IntPtr pItem = new IntPtr(lpItem); if (1 == level) { WrapperWin32Api.SHARE_INFO_1_9x si = (WrapperWin32Api.SHARE_INFO_1_9x)Marshal.PtrToStructure(pItem, t); s = new Share(); s.comment = si.Remark; s.name = si.NetName; s.type = CommonShareTypes(si.ShareType); shares.addShare(s); } else { WrapperWin32Api.SHARE_INFO_2_9x si = (WrapperWin32Api.SHARE_INFO_2_9x)Marshal.PtrToStructure(pItem, t); System.Console.WriteLine(si.NetName); s = new Share(); s.comment = si.Remark; s.name = si.NetName; s.type = CommonShareTypes(si.ShareType); shares.addShare(s); } } } else { Console.WriteLine(nRet); } return(shares); } finally { //Netejem el buffe Marshal.FreeHGlobal(pBuffer); } }
/// <summary> /// Llista els recursos compartits d'un servidor CIFS /// </summary> /// <param name="UNCpath"> /// Adreça del servidor CIFS (DNS o IP) <see cref="System.String"/> /// </param> /// <returns> /// Col·lecció de recursos compartits <see cref="Shares"/> /// </returns> public Shares ShareEnum(string UNCpath){ /* Realment aquesta mateixa ordre en el cas de samba podria * navegar per una carpeta, però s'ha diferenciat de ReadDir * per compatibilitat en Win32 */ int dh=0; Shares shares = new Shares(); //Comprovació de l'existencia del recurs o carpeta dh=WrapperSambaClient.smbc_opendir(@"smb:"+parseUNCPath(UNCpath)); if (dh<0) throw new IOException(Stdlib.GetLastError().ToString()); else{ IntPtr dirbuf = new IntPtr(); //creem un punter gestionat dirbuf= WrapperSambaClient.smbc_readdir(dh); Share s; while(dirbuf!= IntPtr.Zero){ SambaDirInfo dir = (SambaDirInfo)Marshal.PtrToStructure(dirbuf, typeof(SambaDirInfo)); //passem el punter a l'estructura dirbuf= WrapperSambaClient.smbc_readdir(dh); s= new Share(); s.comment=dir.comment; s.name=dir.name; s.type=CommonShareTypes((int)dir.smbc_type); shares.addShare(s); } WrapperSambaClient.smbc_closedir(dh); } return shares; }
/// <summary> /// Obte els recursos compartits d'un servidor CIFS NT /// </summary> /// <param name="server">Nom del servidor</param> /// <param name="shares">Colecció de recursos</param> protected static Shares EnumerateSharesNT(string server) { Shares shares= new Shares(); Share s; int level = 2; int entriesRead, totalEntries, nRet, hResume = 0; IntPtr pBuffer = IntPtr.Zero; try { nRet = WrapperWin32Api.NetShareEnum(server, level, out pBuffer, -1, out entriesRead, out totalEntries, ref hResume); if (WrapperWin32Api.ERROR_ACCESS_DENIED == nRet) { //depenent del tipus de nivell d'acces que tenim la consulta obtindrà un tipus de dades // o un altres, això afectarà a l'estructura on es carrega el resultat level = 1; nRet = WrapperWin32Api.NetShareEnum(server, level, out pBuffer, -1, out entriesRead, out totalEntries, ref hResume); } if (WrapperWin32Api.NO_ERROR == nRet && entriesRead > 0) { Type t = (2 == level) ? typeof(WrapperWin32Api.SHARE_INFO_2) : typeof(WrapperWin32Api.SHARE_INFO_1); int offset = Marshal.SizeOf(t); for (int i=0, lpItem=pBuffer.ToInt32(); i<entriesRead; i++, lpItem+=offset) { IntPtr pItem = new IntPtr(lpItem); if (1 == level) //estructura basica { WrapperWin32Api.SHARE_INFO_1 si = (WrapperWin32Api.SHARE_INFO_1)Marshal.PtrToStructure(pItem, t); s= new Share(); s.comment=si.Remark; s.name=si.NetName; s.type=CommonShareTypes(si.ShareType); shares.addShare(s); } else //estructura amb més informació, però seguirem agafant la mateixa { WrapperWin32Api.SHARE_INFO_2 si = (WrapperWin32Api.SHARE_INFO_2)Marshal.PtrToStructure(pItem, t); s= new Share(); s.comment=si.Remark; s.name=si.NetName; s.type=CommonShareTypes(si.ShareType); shares.addShare(s); } } } return shares; } finally { // Netejem el buffer if (IntPtr.Zero != pBuffer) WrapperWin32Api.NetApiBufferFree(pBuffer); } }
/// <summary> /// Obte els recursos compartits d'un servidor CIFS NTWindows 9x /// </summary> /// <param name="server">Nom del servidor</param> /// <param name="shares">Colecció de recursos</param> protected static Shares EnumerateShares9x(string server) { Shares shares= new Shares(); Share s; int level = 50; int nRet = 0; ushort entriesRead, totalEntries; Type t = typeof(WrapperWin32Api.SHARE_INFO_2_9x ); int size = Marshal.SizeOf(t); ushort cbBuffer = (ushort)(WrapperWin32Api.MAX_SI50_ENTRIES * size); //A Win9x, s'ha de reserva la memòria del buffer abans de cridar l'API IntPtr pBuffer = Marshal.AllocHGlobal(cbBuffer); try { nRet = WrapperWin32Api.NetShareEnum(server, level, pBuffer, cbBuffer, out entriesRead, out totalEntries); if (WrapperWin32Api.ERROR_WRONG_LEVEL == nRet) { level = 1; //el matix problema del permisos i les estructures de retorn de dades t = typeof(WrapperWin32Api.SHARE_INFO_1_9x); size = Marshal.SizeOf(t); nRet = WrapperWin32Api.NetShareEnum(server, level, pBuffer, cbBuffer, out entriesRead, out totalEntries); } if (WrapperWin32Api.NO_ERROR == nRet || WrapperWin32Api.ERROR_MORE_DATA == nRet) { for (int i=0, lpItem=pBuffer.ToInt32(); i<entriesRead; i++, lpItem+=size) { IntPtr pItem = new IntPtr(lpItem); if (1 == level) { WrapperWin32Api.SHARE_INFO_1_9x si = (WrapperWin32Api.SHARE_INFO_1_9x)Marshal.PtrToStructure(pItem, t); s= new Share(); s.comment=si.Remark; s.name=si.NetName; s.type=CommonShareTypes(si.ShareType); shares.addShare(s); } else { WrapperWin32Api.SHARE_INFO_2_9x si = (WrapperWin32Api.SHARE_INFO_2_9x)Marshal.PtrToStructure(pItem, t); System.Console.WriteLine(si.NetName); s= new Share(); s.comment=si.Remark; s.name=si.NetName; s.type=CommonShareTypes(si.ShareType); shares.addShare(s); } } } else Console.WriteLine(nRet); return shares; } finally { //Netejem el buffe Marshal.FreeHGlobal(pBuffer); } }
/// <summary> /// Afegiex un recurs compartit a la collecció /// </summary> /// <param name="share"> /// Recurs Compartit <see cref="Share"/> /// </param> public void addShare(Share share) { shares.Add(share); }