/// <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);
            }
        }
Exemplo n.º 3
0
		/// <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;
		}
Exemplo n.º 4
0
        /// <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);
            }
        }
Exemplo n.º 5
0
        /// <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);
            }
        }
Exemplo n.º 6
0
 /// <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);
 }
 /// <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);
 }