diff options
Diffstat (limited to 'source4/lib')
| -rw-r--r-- | source4/lib/appweb/mpr/miniMpr.c | 7 | ||||
| -rw-r--r-- | source4/lib/appweb/mpr/miniMpr.h | 2 | ||||
| -rw-r--r-- | source4/lib/registry/hive.c | 3 | ||||
| -rw-r--r-- | source4/lib/registry/hive.h | 3 | ||||
| -rw-r--r-- | source4/lib/registry/ldb.c | 14 | ||||
| -rw-r--r-- | source4/lib/registry/patchfile.c | 9 | ||||
| -rw-r--r-- | source4/lib/registry/patchfile.h | 1 | ||||
| -rw-r--r-- | source4/lib/registry/patchfile_dotreg.c | 3 | ||||
| -rw-r--r-- | source4/lib/registry/patchfile_preg.c | 17 | ||||
| -rw-r--r-- | source4/lib/registry/regf.c | 10 | ||||
| -rw-r--r-- | source4/lib/registry/tests/hive.c | 4 | ||||
| -rw-r--r-- | source4/lib/registry/tools/regdiff.c | 2 | 
12 files changed, 50 insertions, 25 deletions
| diff --git a/source4/lib/appweb/mpr/miniMpr.c b/source4/lib/appweb/mpr/miniMpr.c index 949d64fcf1..52b23608aa 100644 --- a/source4/lib/appweb/mpr/miniMpr.c +++ b/source4/lib/appweb/mpr/miniMpr.c @@ -30,6 +30,7 @@   */  #include	"miniMpr.h" +#include "param/param.h"  /************************************ Code ************************************/  #if !BLD_APPWEB @@ -49,6 +50,12 @@ void *mprMemCtx(void)  	return mpr_ctx;  } +/* return the loadparm context being used for all ejs variables */ +struct loadparm_context *mprLpCtx(void) +{ +	return global_loadparm; +} +  void mprFree(void *ptr)  {  	talloc_free(ptr); diff --git a/source4/lib/appweb/mpr/miniMpr.h b/source4/lib/appweb/mpr/miniMpr.h index 836fdab9f2..15ce30c8df 100644 --- a/source4/lib/appweb/mpr/miniMpr.h +++ b/source4/lib/appweb/mpr/miniMpr.h @@ -272,6 +272,8 @@ extern int 		mprMemcpy(char *dest, int destMax, const char *src, int nbytes);  extern void mprSetCtx(void *ctx);  extern void *mprMemCtx(void); +struct loadparm_context; +extern struct loadparm_context *mprLpCtx(void);  /* This function needs to be provided by anyone using ejs */  void ejs_exception(const char *reason); diff --git a/source4/lib/registry/hive.c b/source4/lib/registry/hive.c index 5d56a30b3e..ad6a6421ab 100644 --- a/source4/lib/registry/hive.c +++ b/source4/lib/registry/hive.c @@ -22,6 +22,7 @@  #include "includes.h"  #include "hive.h"  #include "system/filesys.h" +#include "param/param.h"  /** Open a registry file/host/etc */  _PUBLIC_ WERROR reg_open_hive(TALLOC_CTX *parent_ctx, const char *location, @@ -52,7 +53,7 @@ _PUBLIC_ WERROR reg_open_hive(TALLOC_CTX *parent_ctx, const char *location,  	if (!strncmp(peek, "regf", 4)) {  		close(fd); -		return reg_open_regf_file(parent_ctx, location, lp_ctx, root); +		return reg_open_regf_file(parent_ctx, location, lp_iconv_convenience(lp_ctx), root);  	} else if (!strncmp(peek, "TDB file", 8)) {  		close(fd);  		return reg_open_ldb_file(parent_ctx, location, session_info, diff --git a/source4/lib/registry/hive.h b/source4/lib/registry/hive.h index 6d9a69c7c5..87f335663d 100644 --- a/source4/lib/registry/hive.h +++ b/source4/lib/registry/hive.h @@ -188,7 +188,7 @@ WERROR hive_key_flush(struct hive_key *key);  WERROR reg_open_directory(TALLOC_CTX *parent_ctx,  			  const char *location, struct hive_key **key);  WERROR reg_open_regf_file(TALLOC_CTX *parent_ctx, -			  const char *location, struct loadparm_context *lp_ctx, +			  const char *location, struct smb_iconv_convenience *iconv_convenience,  			  struct hive_key **key);  WERROR reg_open_ldb_file(TALLOC_CTX *parent_ctx, const char *location,  			 struct auth_session_info *session_info, @@ -200,6 +200,7 @@ WERROR reg_open_ldb_file(TALLOC_CTX *parent_ctx, const char *location,  WERROR reg_create_directory(TALLOC_CTX *parent_ctx,  			    const char *location, struct hive_key **key);  WERROR reg_create_regf_file(TALLOC_CTX *parent_ctx, +			    struct smb_iconv_convenience *iconv_convenience,  			    const char *location,  			    int major_version,  			    struct hive_key **key); diff --git a/source4/lib/registry/ldb.c b/source4/lib/registry/ldb.c index 0c8a55396e..dfd368ea80 100644 --- a/source4/lib/registry/ldb.c +++ b/source4/lib/registry/ldb.c @@ -36,7 +36,9 @@ struct ldb_key_data  	int subkey_count, value_count;  }; -static void reg_ldb_unpack_value(TALLOC_CTX *mem_ctx, struct ldb_message *msg, +static void reg_ldb_unpack_value(TALLOC_CTX *mem_ctx,  +				 struct smb_iconv_convenience *iconv_convenience, +				 struct ldb_message *msg,  				 const char **name, uint32_t *type,  				 DATA_BLOB *data)  { @@ -57,7 +59,7 @@ static void reg_ldb_unpack_value(TALLOC_CTX *mem_ctx, struct ldb_message *msg,  	{  	case REG_SZ:  	case REG_EXPAND_SZ: -		data->length = convert_string_talloc(mem_ctx, lp_iconv_convenience(global_loadparm), CH_UTF8, CH_UTF16, +		data->length = convert_string_talloc(mem_ctx, iconv_convenience, CH_UTF8, CH_UTF16,  						     val->data, val->length,  						     (void **)&data->data);  		break; @@ -281,7 +283,7 @@ static WERROR ldb_get_value_by_id(TALLOC_CTX *mem_ctx, struct hive_key *k,  	if (idx >= kd->value_count)  		return WERR_NO_MORE_ITEMS; -	reg_ldb_unpack_value(mem_ctx, kd->values[idx], +	reg_ldb_unpack_value(mem_ctx, lp_iconv_convenience(global_loadparm), kd->values[idx],  			     name, data_type, data);  	return WERR_OK; @@ -310,7 +312,7 @@ static WERROR ldb_get_value(TALLOC_CTX *mem_ctx, struct hive_key *k,  	if (res->count == 0)  		return WERR_BADFILE; -	reg_ldb_unpack_value(mem_ctx, res->msgs[0], NULL, data_type, data); +	reg_ldb_unpack_value(mem_ctx, lp_iconv_convenience(global_loadparm), res->msgs[0], NULL, data_type, data);  	return WERR_OK;  } @@ -607,7 +609,9 @@ static WERROR ldb_get_key_info(TALLOC_CTX *mem_ctx,  			if (max_valbufsize != NULL) {  				DATA_BLOB data; -				reg_ldb_unpack_value(mem_ctx, kd->values[i], NULL,  +				reg_ldb_unpack_value(mem_ctx,  +						     lp_iconv_convenience(global_loadparm), +						     kd->values[i], NULL,   						     NULL, &data);  				*max_valbufsize = MAX(*max_valbufsize, data.length);  				talloc_free(data.data); diff --git a/source4/lib/registry/patchfile.c b/source4/lib/registry/patchfile.c index a4579010cd..687fd4b91b 100644 --- a/source4/lib/registry/patchfile.c +++ b/source4/lib/registry/patchfile.c @@ -27,6 +27,7 @@  _PUBLIC_ WERROR reg_preg_diff_load(int fd, +				   struct smb_iconv_convenience *iconv_convenience,   				   const struct reg_diff_callbacks *callbacks,  				   void *callback_data); @@ -273,6 +274,7 @@ _PUBLIC_ WERROR reg_generate_diff(struct registry_context *ctx1,   * Load diff file   */  _PUBLIC_ WERROR reg_diff_load(const char *filename, +			      struct smb_iconv_convenience *iconv_convenience,  			      const struct reg_diff_callbacks *callbacks,  			      void *callback_data)  { @@ -305,10 +307,10 @@ _PUBLIC_ WERROR reg_diff_load(const char *filename,  #endif  	if (strncmp(hdr, "PReg", 4) == 0) {  		/* Must be a GPO Registry.pol file */ -		return reg_preg_diff_load(fd, callbacks, callback_data); +		return reg_preg_diff_load(fd, iconv_convenience, callbacks, callback_data);  	} else {  		/* Must be a normal .REG file */ -		return reg_dotreg_diff_load(fd, lp_iconv_convenience(global_loadparm), callbacks, callback_data); +		return reg_dotreg_diff_load(fd, iconv_convenience, callbacks, callback_data);  	}  } @@ -442,5 +444,6 @@ _PUBLIC_ WERROR reg_diff_apply(struct registry_context *ctx, const char *filenam  	callbacks.del_all_values = reg_diff_apply_del_all_values;  	callbacks.done = NULL; -	return reg_diff_load(filename, &callbacks, ctx); +	return reg_diff_load(filename, lp_iconv_convenience(global_loadparm),  +			     &callbacks, ctx);  } diff --git a/source4/lib/registry/patchfile.h b/source4/lib/registry/patchfile.h index 08a977d9cd..9289390685 100644 --- a/source4/lib/registry/patchfile.h +++ b/source4/lib/registry/patchfile.h @@ -43,6 +43,7 @@ WERROR reg_generate_diff(struct registry_context *ctx1,  			 const struct reg_diff_callbacks *callbacks,  			 void *callback_data);  WERROR reg_dotreg_diff_save(TALLOC_CTX *ctx, const char *filename, +			    struct smb_iconv_convenience *iconv_convenience,  			    struct reg_diff_callbacks **callbacks,  			    void **callback_data);  WERROR reg_generate_diff_key(struct registry_key *oldkey, diff --git a/source4/lib/registry/patchfile_dotreg.c b/source4/lib/registry/patchfile_dotreg.c index 46ea7c0008..6de642ecb8 100644 --- a/source4/lib/registry/patchfile_dotreg.c +++ b/source4/lib/registry/patchfile_dotreg.c @@ -101,6 +101,7 @@ static WERROR reg_dotreg_diff_del_all_values(void *callback_data,   * Save registry diff   */  _PUBLIC_ WERROR reg_dotreg_diff_save(TALLOC_CTX *ctx, const char *filename, +				     struct smb_iconv_convenience *iconv_convenience,  				     struct reg_diff_callbacks **callbacks,  				     void **callback_data)  { @@ -109,7 +110,7 @@ _PUBLIC_ WERROR reg_dotreg_diff_save(TALLOC_CTX *ctx, const char *filename,  	data = talloc_zero(ctx, struct dotreg_data);  	*callback_data = data; -	data->iconv_convenience = lp_iconv_convenience(global_loadparm); +	data->iconv_convenience = iconv_convenience;  	if (filename) {  		data->fd = open(filename, O_CREAT, 0755); diff --git a/source4/lib/registry/patchfile_preg.c b/source4/lib/registry/patchfile_preg.c index 9cc9a5dec2..0d39e67450 100644 --- a/source4/lib/registry/patchfile_preg.c +++ b/source4/lib/registry/patchfile_preg.c @@ -29,14 +29,14 @@ struct preg_data {  	int fd;  }; -static WERROR preg_read_utf16(int fd, char *c) +static WERROR preg_read_utf16(struct smb_iconv_convenience *ic, int fd, char *c)  {  	uint16_t v;  	if (read(fd, &v, 2) < 2) {  		return WERR_GENERAL_FAILURE;  	} -	push_codepoint(lp_iconv_convenience(global_loadparm), c, v); +	push_codepoint(ic, c, v);  	return WERR_OK;  } @@ -123,6 +123,7 @@ _PUBLIC_ WERROR reg_preg_diff_save(TALLOC_CTX *ctx, const char *filename,   * Load diff file   */  _PUBLIC_ WERROR reg_preg_diff_load(int fd, +				   struct smb_iconv_convenience *iconv_convenience,   				   const struct reg_diff_callbacks *callbacks,  				   void *callback_data)  { @@ -162,7 +163,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  	while(1) {  		uint32_t value_type, length; -		if (!W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr))) { +		if (!W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr))) {  			break;  		}  		if (*buf_ptr != '[') { @@ -173,7 +174,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  		/* Get the path */  		buf_ptr = buf; -		while (W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr)) && +		while (W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr)) &&  		       *buf_ptr != ';' && buf_ptr-buf < buf_size) {  			buf_ptr++;  		} @@ -181,7 +182,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  		/* Get the name */  		buf_ptr = buf; -		while (W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr)) && +		while (W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr)) &&  		       *buf_ptr != ';' && buf_ptr-buf < buf_size) {  			buf_ptr++;  		} @@ -195,7 +196,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  		}  		/* Read past delimiter */  		buf_ptr = buf; -		if (!(W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr)) && +		if (!(W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr)) &&  		    *buf_ptr == ';') && buf_ptr-buf < buf_size) {  			DEBUG(0, ("Error in PReg file.\n"));  			ret = WERR_GENERAL_FAILURE; @@ -209,7 +210,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  		}  		/* Read past delimiter */  		buf_ptr = buf; -		if (!(W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr)) && +		if (!(W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr)) &&  		    *buf_ptr == ';') && buf_ptr-buf < buf_size) {  			DEBUG(0, ("Error in PReg file.\n"));  			ret = WERR_GENERAL_FAILURE; @@ -227,7 +228,7 @@ _PUBLIC_ WERROR reg_preg_diff_load(int fd,  		/* Check if delimiter is in place (whine if it isn't) */  		buf_ptr = buf; -		if (!(W_ERROR_IS_OK(preg_read_utf16(fd, buf_ptr)) && +		if (!(W_ERROR_IS_OK(preg_read_utf16(iconv_convenience, fd, buf_ptr)) &&  		    *buf_ptr == ']') && buf_ptr-buf < buf_size) {  			DEBUG(0, ("Warning: Missing ']' in PReg file, expected ']', got '%c' 0x%x.\n",  				*buf_ptr, *buf_ptr)); diff --git a/source4/lib/registry/regf.c b/source4/lib/registry/regf.c index 15b60745f0..cf3e564c0e 100644 --- a/source4/lib/registry/regf.c +++ b/source4/lib/registry/regf.c @@ -1863,7 +1863,9 @@ static WERROR regf_save_hbin(struct regf_data *regf)  	return WERR_OK;  } -WERROR reg_create_regf_file(TALLOC_CTX *parent_ctx, const char *location, +WERROR reg_create_regf_file(TALLOC_CTX *parent_ctx,  +			    struct smb_iconv_convenience *iconv_convenience, +			    const char *location,  			    int minor_version, struct hive_key **key)  {  	struct regf_data *regf; @@ -1874,7 +1876,7 @@ WERROR reg_create_regf_file(TALLOC_CTX *parent_ctx, const char *location,  	regf = (struct regf_data *)talloc_zero(NULL, struct regf_data); -	regf->iconv_convenience = lp_iconv_convenience(global_loadparm); +	regf->iconv_convenience = iconv_convenience;  	W_ERROR_HAVE_NO_MEMORY(regf); @@ -1950,7 +1952,7 @@ WERROR reg_create_regf_file(TALLOC_CTX *parent_ctx, const char *location,  }  WERROR reg_open_regf_file(TALLOC_CTX *parent_ctx, const char *location,  -			  struct loadparm_context *lp_ctx, struct hive_key **key) +			  struct smb_iconv_convenience *iconv_convenience, struct hive_key **key)  {  	struct regf_data *regf;  	struct regf_hdr *regf_hdr; @@ -1959,7 +1961,7 @@ WERROR reg_open_regf_file(TALLOC_CTX *parent_ctx, const char *location,  	regf = (struct regf_data *)talloc_zero(NULL, struct regf_data); -	regf->iconv_convenience = lp_iconv_convenience(lp_ctx); +	regf->iconv_convenience = iconv_convenience;  	W_ERROR_HAVE_NO_MEMORY(regf); diff --git a/source4/lib/registry/tests/hive.c b/source4/lib/registry/tests/hive.c index 4d27e83a74..1dcb464d80 100644 --- a/source4/lib/registry/tests/hive.c +++ b/source4/lib/registry/tests/hive.c @@ -25,6 +25,7 @@  #include "torture/torture.h"  #include "librpc/gen_ndr/winreg.h"  #include "system/filesys.h" +#include "param/param.h"  static bool test_del_nonexistant_key(struct torture_context *tctx,  				     const void *test_data) @@ -349,7 +350,8 @@ static bool hive_setup_regf(struct torture_context *tctx, void **data)  	rmdir(dirname); -	error = reg_create_regf_file(tctx, dirname, 5, &key); +	error = reg_create_regf_file(tctx, lp_iconv_convenience(tctx->lp_ctx), +				     dirname, 5, &key);  	if (!W_ERROR_IS_OK(error)) {  		fprintf(stderr, "Unable to create new regf file\n");  		return false; diff --git a/source4/lib/registry/tools/regdiff.c b/source4/lib/registry/tools/regdiff.c index 406eaeea3d..c94380efd2 100644 --- a/source4/lib/registry/tools/regdiff.c +++ b/source4/lib/registry/tools/regdiff.c @@ -126,7 +126,7 @@ int main(int argc, const char **argv)  	poptFreeContext(pc); -	error = reg_dotreg_diff_save(ctx, outputfile, &callbacks, +	error = reg_dotreg_diff_save(ctx, outputfile, lp_iconv_convenience(cmdline_lp_ctx), &callbacks,  				     &callback_data);  	if (!W_ERROR_IS_OK(error)) {  		fprintf(stderr, "Problem saving registry diff to '%s': %s\n", | 
