2010-09-20 04:42:10 +04:00
/*
* Unix SMB / CIFS implementation .
* Virtual Windows Registry Layer
* Copyright ( C ) Volker Lendecke 2006
* Copyright ( C ) Michael Adam 2007 - 2010
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , see < http : //www.gnu.org/licenses/>.
*/
/*
* Higher level utility functions on top of reg_api . c
*/
# include "includes.h"
# include "registry.h"
2010-09-21 10:11:18 +04:00
# include "reg_api.h"
2010-09-20 04:42:10 +04:00
# include "reg_api_util.h"
2012-04-30 12:27:56 +04:00
# include "libcli/registry/util_reg.h"
2010-09-20 04:42:10 +04:00
/**
* Utility function to open a complete registry path including the hive prefix .
*/
WERROR reg_open_path ( TALLOC_CTX * mem_ctx , const char * orig_path ,
2015-04-14 17:50:28 +03:00
uint32_t desired_access , const struct security_token * token ,
2010-09-20 04:42:10 +04:00
struct registry_key * * pkey )
{
struct registry_key * hive , * key ;
char * path , * p ;
WERROR err ;
if ( ! ( path = SMB_STRDUP ( orig_path ) ) ) {
2015-12-03 17:24:14 +03:00
return WERR_NOT_ENOUGH_MEMORY ;
2010-09-20 04:42:10 +04:00
}
p = strchr ( path , ' \\ ' ) ;
if ( ( p = = NULL ) | | ( p [ 1 ] = = ' \0 ' ) ) {
/*
* No key behind the hive , just return the hive
*/
err = reg_openhive ( mem_ctx , path , desired_access , token ,
& hive ) ;
if ( ! W_ERROR_IS_OK ( err ) ) {
SAFE_FREE ( path ) ;
return err ;
}
SAFE_FREE ( path ) ;
* pkey = hive ;
return WERR_OK ;
}
* p = ' \0 ' ;
err = reg_openhive ( mem_ctx , path , KEY_ENUMERATE_SUB_KEYS , token ,
& hive ) ;
if ( ! W_ERROR_IS_OK ( err ) ) {
SAFE_FREE ( path ) ;
return err ;
}
err = reg_openkey ( mem_ctx , hive , p + 1 , desired_access , & key ) ;
TALLOC_FREE ( hive ) ;
SAFE_FREE ( path ) ;
if ( ! W_ERROR_IS_OK ( err ) ) {
return err ;
}
* pkey = key ;
return WERR_OK ;
}