diff options
-rw-r--r-- | source4/dsdb/schema/schema_prefixmap.c | 65 |
1 files changed, 45 insertions, 20 deletions
diff --git a/source4/dsdb/schema/schema_prefixmap.c b/source4/dsdb/schema/schema_prefixmap.c index 08e51559d6..6943ee0217 100644 --- a/source4/dsdb/schema/schema_prefixmap.c +++ b/source4/dsdb/schema/schema_prefixmap.c @@ -131,41 +131,66 @@ static WERROR _dsdb_schema_pfm_add_entry(struct dsdb_schema_prefixmap *pfm, DATA /** - * Make ATTID for given OID + * Make partial binary OID for supplied OID. * Reference: [MS-DRSR] section 5.12.2 */ -WERROR dsdb_schema_pfm_make_attid(struct dsdb_schema_prefixmap *pfm, const char *oid, uint32_t *attid) +static WERROR _dsdb_pfm_make_binary_oid(const char *full_oid, TALLOC_CTX *mem_ctx, + DATA_BLOB *_bin_oid, uint32_t *_last_subid) { - uint32_t i; - uint32_t lo_word, hi_word; - DATA_BLOB bin_oid; - const char *last_subid; - uint32_t last_value; - struct dsdb_schema_prefixmap_oid *pfm_entry; - - if (!pfm) return WERR_INVALID_PARAMETER; - if (!oid) return WERR_INVALID_PARAMETER; + uint32_t last_subid; + const char *oid_subid; /* make last sub-identifier value */ - last_subid = strrchr(oid, '.'); - if (!last_subid) { + oid_subid = strrchr(full_oid, '.'); + if (!oid_subid) { return WERR_INVALID_PARAMETER; } - last_subid++; - last_value = strtoul(last_subid, NULL, 10); + oid_subid++; + last_subid = strtoul(oid_subid, NULL, 10); /* encode oid in BER format */ - if (!ber_write_OID_String(pfm, &bin_oid, oid)) { + if (!ber_write_OID_String(mem_ctx, _bin_oid, full_oid)) { return WERR_INTERNAL_ERROR; } /* get the prefix of the OID */ - if (last_value < 128) { - bin_oid.length -= 1; + if (last_subid < 128) { + _bin_oid->length -= 1; } else { - bin_oid.length -= 2; + _bin_oid->length -= 2; } + /* return last_value if requested */ + if (_last_subid) { + *_last_subid = last_subid; + } + + return WERR_OK; +} + +/** + * Make ATTID for given OID + * Reference: [MS-DRSR] section 5.12.2 + */ +WERROR dsdb_schema_pfm_make_attid(struct dsdb_schema_prefixmap *pfm, const char *oid, uint32_t *attid) +{ + WERROR werr; + uint32_t i; + uint32_t lo_word, hi_word; + uint32_t last_value; + DATA_BLOB bin_oid; + struct dsdb_schema_prefixmap_oid *pfm_entry; + + if (!pfm) { + return WERR_INVALID_PARAMETER; + } + if (!oid) { + return WERR_INVALID_PARAMETER; + } + + werr = _dsdb_pfm_make_binary_oid(oid, pfm, &bin_oid, &last_value); + W_ERROR_NOT_OK_RETURN(werr); + /* search the prefix in the prefix table, if none found, add * one entry for new prefix. */ @@ -182,7 +207,7 @@ WERROR dsdb_schema_pfm_make_attid(struct dsdb_schema_prefixmap *pfm, const char /* add entry in no entry exists */ if (!pfm_entry) { uint32_t idx; - WERROR werr = _dsdb_schema_pfm_add_entry(pfm, bin_oid, &idx); + werr = _dsdb_schema_pfm_add_entry(pfm, bin_oid, &idx); W_ERROR_NOT_OK_RETURN(werr); pfm_entry = &pfm->prefixes[idx]; |