2 Unix SMB/CIFS implementation.
4 routines for printing some linked list structs in DRSUAPI
6 Copyright (C) Stefan (metze) Metzmacher 2005
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
24 #include "librpc/gen_ndr/ndr_drsuapi.h"
25 #include "librpc/gen_ndr/ndr_misc.h"
26 #include "../lib/util/asn1.h"
27 #include "librpc/ndr/ndr_compression.h"
29 void ndr_print_drsuapi_DsReplicaObjectListItem(struct ndr_print *ndr, const char *name,
30 const struct drsuapi_DsReplicaObjectListItem *r)
32 ndr_print_struct(ndr, name, "drsuapi_DsReplicaObjectListItem");
34 ndr_print_ptr(ndr, "next_object", r->next_object);
35 ndr_print_drsuapi_DsReplicaObject(ndr, "object", &r->object);
38 ndr_print_drsuapi_DsReplicaObjectListItem(ndr, "next_object", r->next_object);
42 void ndr_print_drsuapi_DsReplicaObjectListItemEx(struct ndr_print *ndr, const char *name, const struct drsuapi_DsReplicaObjectListItemEx *r)
44 ndr_print_struct(ndr, name, "drsuapi_DsReplicaObjectListItemEx");
46 ndr_print_ptr(ndr, "next_object", r->next_object);
47 ndr_print_drsuapi_DsReplicaObject(ndr, "object", &r->object);
48 ndr_print_uint32(ndr, "is_nc_prefix", r->is_nc_prefix);
49 ndr_print_ptr(ndr, "parent_object_guid", r->parent_object_guid);
51 if (r->parent_object_guid) {
52 ndr_print_GUID(ndr, "parent_object_guid", r->parent_object_guid);
55 ndr_print_ptr(ndr, "meta_data_ctr", r->meta_data_ctr);
57 if (r->meta_data_ctr) {
58 ndr_print_drsuapi_DsReplicaMetaDataCtr(ndr, "meta_data_ctr", r->meta_data_ctr);
63 ndr_print_drsuapi_DsReplicaObjectListItemEx(ndr, "next_object", r->next_object);
67 #define _OID_PUSH_CHECK(call) do { \
70 if (_status != true) { \
71 return ndr_push_error(ndr, NDR_ERR_SUBCONTEXT, "OID Conversion Error: %s\n", __location__); \
75 #define _OID_PULL_CHECK(call) do { \
78 if (_status != true) { \
79 return ndr_pull_error(ndr, NDR_ERR_SUBCONTEXT, "OID Conversion Error: %s\n", __location__); \
83 enum ndr_err_code ndr_push_drsuapi_DsReplicaOID(struct ndr_push *ndr, int ndr_flags, const struct drsuapi_DsReplicaOID *r)
85 if (ndr_flags & NDR_SCALARS) {
86 NDR_CHECK(ndr_push_align(ndr, 4));
87 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_size_drsuapi_DsReplicaOID_oid(r->oid, 0)));
88 NDR_CHECK(ndr_push_unique_ptr(ndr, r->oid));
90 if (ndr_flags & NDR_BUFFERS) {
94 #if (_SAMBA_BUILD_ == 3)
95 if (StrnCaseCmp("ff", r->oid, 2) == 0) {
97 if (strncasecmp("ff", r->oid, 2) == 0) {
99 blob = strhex_to_data_blob(ndr, r->oid);
101 return ndr_push_error(ndr, NDR_ERR_SUBCONTEXT,
102 "HEX String Conversion Error: %s\n",
106 _OID_PUSH_CHECK(ber_write_OID_String(&blob, r->oid));
109 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, blob.length));
110 NDR_CHECK(ndr_push_array_uint8(ndr, NDR_SCALARS, blob.data, blob.length));
113 return NDR_ERR_SUCCESS;
116 enum ndr_err_code ndr_pull_drsuapi_DsReplicaOID(struct ndr_pull *ndr, int ndr_flags, struct drsuapi_DsReplicaOID *r)
119 TALLOC_CTX *_mem_save_oid_0;
120 if (ndr_flags & NDR_SCALARS) {
121 NDR_CHECK(ndr_pull_align(ndr, 4));
122 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->__ndr_size));
123 if (r->__ndr_size < 0 || r->__ndr_size > 10000) {
124 return ndr_pull_error(ndr, NDR_ERR_RANGE, "value out of range");
126 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_oid));
128 NDR_PULL_ALLOC(ndr, r->oid);
133 if (ndr_flags & NDR_BUFFERS) {
135 DATA_BLOB _oid_array;
138 _mem_save_oid_0 = NDR_PULL_GET_MEM_CTX(ndr);
139 NDR_PULL_SET_MEM_CTX(ndr, ndr, 0);
140 NDR_CHECK(ndr_pull_array_size(ndr, &r->oid));
141 _oid_array.length = ndr_get_array_size(ndr, &r->oid);
142 NDR_PULL_ALLOC_N(ndr, _oid_array.data, _oid_array.length);
143 NDR_CHECK(ndr_pull_array_uint8(ndr, NDR_SCALARS, _oid_array.data, _oid_array.length));
144 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_oid_0, 0);
146 if (_oid_array.length && _oid_array.data[0] == 0xFF) {
147 _oid = data_blob_hex_string(ndr, &_oid_array);
148 NDR_ERR_HAVE_NO_MEMORY(_oid);
150 _OID_PULL_CHECK(ber_read_OID_String(ndr, _oid_array, &_oid));
152 data_blob_free(&_oid_array);
153 talloc_steal(r->oid, _oid);
157 NDR_CHECK(ndr_check_array_size(ndr, (void*)&r->oid, r->__ndr_size));
160 return NDR_ERR_SUCCESS;
163 size_t ndr_size_drsuapi_DsReplicaOID_oid(const char *oid, int flags)
170 #if (_SAMBA_BUILD_ == 3)
171 if (StrnCaseCmp("ff", oid, 2) == 0) {
173 if (strncasecmp("ff", oid, 2) == 0) {
175 _blob = strhex_to_data_blob(NULL, oid);
180 if (ber_write_OID_String(&_blob, oid)) {
184 data_blob_free(&_blob);
188 enum ndr_err_code ndr_push_drsuapi_DsGetNCChangesMSZIPCtr1(struct ndr_push *ndr, int ndr_flags, const struct drsuapi_DsGetNCChangesMSZIPCtr1 *r)
190 if (ndr_flags & NDR_SCALARS) {
191 uint32_t decompressed_length = 0;
192 uint32_t compressed_length = 0;
195 struct ndr_push *_ndr_ts;
196 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
198 struct ndr_push *_ndr_ts_compressed;
199 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
200 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr1TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
201 decompressed_length = _ndr_ts_compressed->offset;
202 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
204 compressed_length = _ndr_ts->offset;
205 talloc_free(_ndr_ts);
208 NDR_CHECK(ndr_push_align(ndr, 4));
209 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, decompressed_length));
210 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, compressed_length));
211 NDR_CHECK(ndr_push_unique_ptr(ndr, r->ts));
213 if (ndr_flags & NDR_BUFFERS) {
216 struct ndr_push *_ndr_ts;
217 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
219 struct ndr_push *_ndr_ts_compressed;
220 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
221 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr1TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
222 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
224 NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_ts, 4, -1));
228 return NDR_ERR_SUCCESS;
231 enum ndr_err_code ndr_push_drsuapi_DsGetNCChangesMSZIPCtr6(struct ndr_push *ndr, int ndr_flags, const struct drsuapi_DsGetNCChangesMSZIPCtr6 *r)
233 if (ndr_flags & NDR_SCALARS) {
234 uint32_t decompressed_length = 0;
235 uint32_t compressed_length = 0;
238 struct ndr_push *_ndr_ts;
239 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
241 struct ndr_push *_ndr_ts_compressed;
242 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
243 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr6TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
244 decompressed_length = _ndr_ts_compressed->offset;
245 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
247 compressed_length = _ndr_ts->offset;
248 talloc_free(_ndr_ts);
251 NDR_CHECK(ndr_push_align(ndr, 4));
252 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, decompressed_length));
253 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, compressed_length));
254 NDR_CHECK(ndr_push_unique_ptr(ndr, r->ts));
256 if (ndr_flags & NDR_BUFFERS) {
259 struct ndr_push *_ndr_ts;
260 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
262 struct ndr_push *_ndr_ts_compressed;
263 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
264 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr6TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
265 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_MSZIP, -1));
267 NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_ts, 4, -1));
271 return NDR_ERR_SUCCESS;
274 enum ndr_err_code ndr_push_drsuapi_DsGetNCChangesXPRESSCtr1(struct ndr_push *ndr, int ndr_flags, const struct drsuapi_DsGetNCChangesXPRESSCtr1 *r)
276 if (ndr_flags & NDR_SCALARS) {
277 uint32_t decompressed_length = 0;
278 uint32_t compressed_length = 0;
281 struct ndr_push *_ndr_ts;
282 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
284 struct ndr_push *_ndr_ts_compressed;
285 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
286 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr1TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
287 decompressed_length = _ndr_ts_compressed->offset;
288 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
290 compressed_length = _ndr_ts->offset;
291 talloc_free(_ndr_ts);
294 NDR_CHECK(ndr_push_align(ndr, 4));
295 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, decompressed_length));
296 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, compressed_length));
297 NDR_CHECK(ndr_push_unique_ptr(ndr, r->ts));
299 if (ndr_flags & NDR_BUFFERS) {
302 struct ndr_push *_ndr_ts;
303 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
305 struct ndr_push *_ndr_ts_compressed;
306 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
307 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr1TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
308 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
310 NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_ts, 4, -1));
314 return NDR_ERR_SUCCESS;
317 enum ndr_err_code ndr_push_drsuapi_DsGetNCChangesXPRESSCtr6(struct ndr_push *ndr, int ndr_flags, const struct drsuapi_DsGetNCChangesXPRESSCtr6 *r)
319 if (ndr_flags & NDR_SCALARS) {
320 uint32_t decompressed_length = 0;
321 uint32_t compressed_length = 0;
324 struct ndr_push *_ndr_ts;
325 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
327 struct ndr_push *_ndr_ts_compressed;
328 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
329 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr6TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
330 decompressed_length = _ndr_ts_compressed->offset;
331 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
333 compressed_length = _ndr_ts->offset;
334 talloc_free(_ndr_ts);
337 NDR_CHECK(ndr_push_align(ndr, 4));
338 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, decompressed_length));
339 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, compressed_length));
340 NDR_CHECK(ndr_push_unique_ptr(ndr, r->ts));
342 if (ndr_flags & NDR_BUFFERS) {
345 struct ndr_push *_ndr_ts;
346 NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_ts, 4, -1));
348 struct ndr_push *_ndr_ts_compressed;
349 NDR_CHECK(ndr_push_compression_start(_ndr_ts, &_ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
350 NDR_CHECK(ndr_push_drsuapi_DsGetNCChangesCtr6TS(_ndr_ts_compressed, NDR_SCALARS|NDR_BUFFERS, r->ts));
351 NDR_CHECK(ndr_push_compression_end(_ndr_ts, _ndr_ts_compressed, NDR_COMPRESSION_XPRESS, -1));
353 NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_ts, 4, -1));
357 return NDR_ERR_SUCCESS;