r5207: patches from Jay Fenlason @ RedHat (scooped from their Fedora packages)
authorGerald Carter <jerry@samba.org>
Fri, 4 Feb 2005 00:25:33 +0000 (00:25 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 15:55:33 +0000 (10:55 -0500)
(This used to be commit 9019a8436162d3606f6b8584701b0832cf5a7439)

source3/client/smbmnt.c
source3/client/smbumount.c
source3/libads/ldap.c
source3/nsswitch/pam_winbind.c
source3/nsswitch/winbindd_ads.c

index 753a31c3139f0f0b6cee95f5694b28ec81c03951..06dd3e5c02320c29326853d37eb0b7abc7663b16 100644 (file)
@@ -162,7 +162,7 @@ do_mount(char *share_name, unsigned int flags, struct smb_mount_data *data)
 
        slprintf(opts, sizeof(opts)-1,
                 "version=7,uid=%d,gid=%d,file_mode=0%o,dir_mode=0%o,%s",
-                data->uid, data->gid, data->file_mode, data->dir_mode,options);
+                mount_uid, mount_gid, data->file_mode, data->dir_mode,options);
        if (mount(share_name, ".", "smbfs", flags, data1) == 0)
                return 0;
        return mount(share_name, ".", "smbfs", flags, data2);
@@ -225,7 +225,7 @@ do_mount(char *share_name, unsigned int flags, struct smb_mount_data *data)
                 return -1;
         }
 
-        data.uid = mount_uid;
+        data.uid = mount_uid;    // truncates to 16-bits here!!!
         data.gid = mount_gid;
         data.file_mode = (S_IRWXU|S_IRWXG|S_IRWXO) & mount_fmask;
         data.dir_mode  = (S_IRWXU|S_IRWXG|S_IRWXO) & mount_dmask;
index 9ea3083a6f992ab061a0329ba51dcf806cbdfdfa..29a7b5dafc13786f5a40afd42300e894e7655e91 100644 (file)
@@ -39,7 +39,7 @@ umount_ok(const char *mount_point)
        /* we set O_NOFOLLOW to prevent users playing games with symlinks to
           umount filesystems they don't own */
         int fid = open(mount_point, O_RDONLY|O_NOFOLLOW, 0);
-        __kernel_uid_t mount_uid;
+        __kernel_uid32_t mount_uid;
        
         if (fid == -1) {
                 fprintf(stderr, "Could not open %s: %s\n",
@@ -47,10 +47,14 @@ umount_ok(const char *mount_point)
                 return -1;
         }
         
-        if (ioctl(fid, SMB_IOC_GETMOUNTUID, &mount_uid) != 0) {
-                fprintf(stderr, "%s probably not smb-filesystem\n",
-                        mount_point);
-                return -1;
+        if (ioctl(fid, SMB_IOC_GETMOUNTUID32, &mount_uid) != 0) {
+                __kernel_uid_t mount_uid16;
+                if (ioctl(fid, SMB_IOC_GETMOUNTUID, &mount_uid16) != 0) {
+                        fprintf(stderr, "%s probably not smb-filesystem\n",
+                                mount_point);
+                        return -1;
+                }
+                mount_uid = mount_uid16;
         }
 
         if ((getuid() != 0)
index 494bd930e4ea94f2b7adc62c113ea5162528fc5c..c9bba7252461d835a204e7933d076434fdcacaf6 100644 (file)
@@ -2526,7 +2526,7 @@ ADS_STATUS ads_workgroup_name(ADS_STRUCT *ads, TALLOC_CTX *mem_ctx, const char *
        int i;
        void *res;
        const char *attrs[] = {"servicePrincipalName", NULL};
-       int num_principals;
+       size_t num_principals;
 
        (*workgroup) = NULL;
 
index bfd8dd45ee5efc077a0fa2516884e7dc6d5a08c1..ffe82b0bd26ab5a74b58de1c331667dedff875bd 100644 (file)
@@ -4,7 +4,7 @@
    Copyright Tim Potter <tpot@samba.org> 2000
    Copyright Andrew Bartlett <abartlet@samba.org> 2002
 
-   largely based on pam_userdb by Christian Gafton <gafton@redhat.com> 
+   largely based on pam_userdb by Cristian Gafton <gafton@redhat.com> 
    also contains large slabs of code from pam_unix by Elliot Lee <sopwith@redhat.com>
    (see copyright below for full details)
 */
@@ -696,7 +696,7 @@ PAM_EXTERN int pam_sm_chauthtok(pam_handle_t * pamh, int flags,
                lctrl = ctrl;
                
                if (on(WINBIND_USE_AUTHTOK_ARG, lctrl)) {
-                       ctrl = WINBIND_USE_FIRST_PASS_ARG | lctrl;
+                       lctrl |= WINBIND_USE_FIRST_PASS_ARG;
                }
                retry = 0;
                retval = PAM_AUTHTOK_ERR;
index 335e21adcbe231cd253f2a3e8dc5c2406fe04f0e..88a7d3ed3b1c2186abd2b7eabf08e06afcc1a5ff 100644 (file)
@@ -651,7 +651,8 @@ static NTSTATUS lookup_groupmem(struct winbindd_domain *domain,
        NTSTATUS status = NT_STATUS_UNSUCCESSFUL;
        char *sidstr;
        char **members;
-       int i, num_members;
+       int i;
+       size_t num_members;
        fstring sid_string;
        BOOL more_values;
        const char **attrs;