s3: Add "len" to pdb_set_hours
authorVolker Lendecke <vl@samba.org>
Wed, 16 Feb 2011 15:47:23 +0000 (16:47 +0100)
committerVolker Lendecke <vl@samba.org>
Sat, 19 Feb 2011 10:32:49 +0000 (11:32 +0100)
source3/include/proto.h
source3/libnet/libnet_dssync_passdb.c
source3/libnet/libnet_samsync_passdb.c
source3/passdb/passdb.c
source3/passdb/pdb_get_set.c
source3/passdb/pdb_ldap.c
source3/rpc_server/samr/srv_samr_util.c
source3/utils/pdbedit.c

index 088505309806e0c30cd47a90e699cfc2baa53cc3..a2cc222e0f74d4c7d1d7e71a522c016195494db7 100644 (file)
@@ -3770,7 +3770,8 @@ bool pdb_set_country_code(struct samu *sampass, uint16_t country_code,
 bool pdb_set_code_page(struct samu *sampass, uint16_t code_page,
                       enum pdb_value_state flag);
 bool pdb_set_unknown_6(struct samu *sampass, uint32_t unkn, enum pdb_value_state flag);
-bool pdb_set_hours(struct samu *sampass, const uint8_t *hours, enum pdb_value_state flag);
+bool pdb_set_hours(struct samu *sampass, const uint8 *hours, int hours_len,
+                  enum pdb_value_state flag);
 bool pdb_set_backend_private_data(struct samu *sampass, void *private_data, 
                                   void (*free_fn)(void **), 
                                   const struct pdb_methods *my_methods, 
index 4b66c39bb3f26e97ba2ef814401ba1e43f4d37d8..df99e40ebb3797817a8685918a2cecee3e1a0125 100644 (file)
@@ -1263,7 +1263,8 @@ static NTSTATUS sam_account_from_object(struct samu *account,
                pdb_sethexhours(oldstr, pdb_get_hours(account));
                pdb_sethexhours(newstr, logonHours.data);
                if (!strequal(oldstr, newstr)) {
-                       pdb_set_hours(account, logonHours.data, PDB_CHANGED);
+                       pdb_set_hours(account, logonHours.data,
+                                     logonHours.length, PDB_CHANGED);
                }
        }
 
index 9d72194c03a534af916af09fd72b316d4c7ba3c0..cfcdb7cec27dd348b1131701615d7278940b19b8 100644 (file)
@@ -179,7 +179,8 @@ static NTSTATUS sam_account_from_delta(struct samu *account,
                pdb_sethexhours(oldstr, pdb_get_hours(account));
                pdb_sethexhours(newstr, r->logon_hours.bits);
                if (!strequal(oldstr, newstr))
-                       pdb_set_hours(account, r->logon_hours.bits, PDB_CHANGED);
+                       pdb_set_hours(account, r->logon_hours.bits,
+                                     pdb_get_hours_len(account), PDB_CHANGED);
        }
 
        if (pdb_get_bad_password_count(account) != r->bad_password_count)
index dafe55eef756fa3cbb77b8d59888e9e57e594cfd..fdc4bdc48639c72652f489bf152f17cb60737014 100644 (file)
@@ -1086,7 +1086,7 @@ static bool init_samu_from_buffer_v0(struct samu *sampass, uint8_t *buf, uint32_
        pdb_set_unknown_6(sampass, unknown_6, PDB_SET);
        pdb_set_acct_ctrl(sampass, acct_ctrl, PDB_SET);
        pdb_set_logon_divs(sampass, logon_divs, PDB_SET);
-       pdb_set_hours(sampass, hours, PDB_SET);
+       pdb_set_hours(sampass, hours, hours_len, PDB_SET);
 
 done:
 
@@ -1278,7 +1278,7 @@ static bool init_samu_from_buffer_v1(struct samu *sampass, uint8_t *buf, uint32_
        pdb_set_unknown_6(sampass, unknown_6, PDB_SET);
        pdb_set_acct_ctrl(sampass, acct_ctrl, PDB_SET);
        pdb_set_logon_divs(sampass, logon_divs, PDB_SET);
-       pdb_set_hours(sampass, hours, PDB_SET);
+       pdb_set_hours(sampass, hours, hours_len, PDB_SET);
 
 done:
 
@@ -1509,7 +1509,7 @@ static bool init_samu_from_buffer_v2(struct samu *sampass, uint8_t *buf, uint32_
        pdb_set_unknown_6(sampass, unknown_6, PDB_SET);
        pdb_set_acct_ctrl(sampass, acct_ctrl, PDB_SET);
        pdb_set_logon_divs(sampass, logon_divs, PDB_SET);
-       pdb_set_hours(sampass, hours, PDB_SET);
+       pdb_set_hours(sampass, hours, hours_len, PDB_SET);
 
 done:
 
@@ -1744,7 +1744,7 @@ static bool init_samu_from_buffer_v3(struct samu *sampass, uint8_t *buf, uint32_
        /* Change from V2 is the uint32_t acct_ctrl */
        pdb_set_acct_ctrl(sampass, acct_ctrl, PDB_SET);
        pdb_set_logon_divs(sampass, logon_divs, PDB_SET);
-       pdb_set_hours(sampass, hours, PDB_SET);
+       pdb_set_hours(sampass, hours, hours_len, PDB_SET);
 
 done:
 
index 07a63e24e63a26048d9f299cf13fd0f3c7366b65..e572c3d94fee25c699a99960c97844a2571ee852 100644 (file)
@@ -918,12 +918,17 @@ bool pdb_set_unknown_6(struct samu *sampass, uint32_t unkn, enum pdb_value_state
        return pdb_set_init_flags(sampass, PDB_UNKNOWN6, flag);
 }
 
-bool pdb_set_hours(struct samu *sampass, const uint8 *hours, enum pdb_value_state flag)
+bool pdb_set_hours(struct samu *sampass, const uint8 *hours, int hours_len,
+                  enum pdb_value_state flag)
 {
+       if (hours_len > sizeof(sampass->hours)) {
+               return false;
+       }
+
        if (!hours) {
-               memset ((char *)sampass->hours, 0, MAX_HOURS_LEN);
+               memset ((char *)sampass->hours, 0, hours_len);
        } else {
-               memcpy (sampass->hours, hours, MAX_HOURS_LEN);
+               memcpy (sampass->hours, hours, hours_len);
        }
 
        return pdb_set_init_flags(sampass, PDB_HOURS, flag);
index a884b305ed78dde2123d16a5f798c474623851f6..573c50520e6ee9008cdcfa246ebd5499dc6c625a 100644 (file)
@@ -1027,7 +1027,7 @@ static bool init_sam_from_ldap(struct ldapsam_privates *ldap_state,
        if (temp) {
                pdb_gethexhours(temp, hours);
                memset((char *)temp, '\0', strlen(temp) +1);
-               pdb_set_hours(sampass, hours, PDB_SET);
+               pdb_set_hours(sampass, hours, hours_len, PDB_SET);
                ZERO_STRUCT(hours);
        }
 
index 0bab1271f25d82716dda2da2712ee99547a4ce45..8dfeae15e83a80de8b9f7437cb8bf63afbf10edd 100644 (file)
@@ -580,7 +580,9 @@ void copy_id21_to_sam_passwd(const char *log_prefix,
                pdb_sethexhours(oldstr, pdb_get_hours(to));
                pdb_sethexhours(newstr, from->logon_hours.bits);
                if (!strequal(oldstr, newstr)) {
-                       pdb_set_hours(to, from->logon_hours.bits, PDB_CHANGED);
+                       pdb_set_hours(to, from->logon_hours.bits,
+                                     from->logon_hours.units_per_week/8,
+                                     PDB_CHANGED);
                }
        }
 
index 400805375e121357c017bd2e4c95f4c783bd7854..ec324cd5e8ec2a3aeb24e0052bc0261b40028a62 100644 (file)
@@ -526,7 +526,7 @@ static int set_user_info(const char *username, const char *fullname,
                hours_len = pdb_get_hours_len(sam_pwent);
                memset(hours_array, 0xff, hours_len);
 
-               pdb_set_hours(sam_pwent, hours_array, PDB_CHANGED);
+               pdb_set_hours(sam_pwent, hours_array, hours_len, PDB_CHANGED);
        }
 
        if (!pdb_update_autolock_flag(sam_pwent, &updated_autolock)) {