2003-08-13 05:53:07 +04:00
/*
Unix SMB / CIFS implementation .
Easy management of byte - length data
Copyright ( C ) Andrew Tridgell 2001
Copyright ( C ) Andrew Bartlett 2001
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 2 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 , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
/*******************************************************************
construct a data blob , must be freed with data_blob_free ( )
you can pass NULL for p and get a blank data blob
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-26 10:41:59 +04:00
DATA_BLOB data_blob_named ( const void * p , size_t length , const char * name )
2003-08-13 05:53:07 +04:00
{
DATA_BLOB ret ;
2004-08-25 06:07:20 +04:00
if ( length = = 0 ) {
2003-08-13 05:53:07 +04:00
ZERO_STRUCT ( ret ) ;
return ret ;
}
if ( p ) {
2004-08-25 07:23:39 +04:00
ret . data = talloc_memdup ( NULL , p , length ) ;
2003-08-13 05:53:07 +04:00
} else {
2005-01-06 06:06:58 +03:00
ret . data = talloc_size ( NULL , length ) ;
2004-08-25 07:23:39 +04:00
}
if ( ret . data = = NULL ) {
ret . length = 0 ;
return ret ;
2003-08-13 05:53:07 +04:00
}
2004-09-26 10:41:59 +04:00
talloc_set_name_const ( ret . data , name ) ;
2003-08-13 05:53:07 +04:00
ret . length = length ;
return ret ;
}
/*******************************************************************
construct a data blob , using supplied TALLOC_CTX
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-27 08:20:18 +04:00
DATA_BLOB data_blob_talloc_named ( TALLOC_CTX * mem_ctx , const void * p , size_t length , const char * name )
2003-08-13 05:53:07 +04:00
{
2004-09-27 08:20:18 +04:00
DATA_BLOB ret = data_blob_named ( p , length , name ) ;
2003-08-13 05:53:07 +04:00
2004-08-25 07:23:39 +04:00
if ( ret . data ) {
2004-09-27 08:20:18 +04:00
talloc_steal ( mem_ctx , ret . data ) ;
2003-08-13 05:53:07 +04:00
}
return ret ;
}
2004-11-06 06:44:16 +03:00
/*******************************************************************
2004-11-06 08:40:34 +03:00
reference a data blob , to the supplied TALLOC_CTX .
Returns a NULL DATA_BLOB on failure
2004-11-06 06:44:16 +03:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
DATA_BLOB data_blob_talloc_reference ( TALLOC_CTX * mem_ctx , DATA_BLOB * blob )
{
DATA_BLOB ret = * blob ;
2004-11-06 08:40:34 +03:00
ret . data = talloc_reference ( mem_ctx , blob - > data ) ;
if ( ! ret . data ) {
return data_blob ( NULL , 0 ) ;
}
2004-11-06 06:44:16 +03:00
return ret ;
}
2003-12-13 05:20:40 +03:00
/*******************************************************************
construct a zero data blob , using supplied TALLOC_CTX .
use this sparingly as it initialises data - better to initialise
yourself if you want specific data in the blob
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
DATA_BLOB data_blob_talloc_zero ( TALLOC_CTX * mem_ctx , size_t length )
{
DATA_BLOB blob = data_blob_talloc ( mem_ctx , NULL , length ) ;
data_blob_clear ( & blob ) ;
return blob ;
}
2003-08-13 05:53:07 +04:00
/*******************************************************************
free a data blob
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void data_blob_free ( DATA_BLOB * d )
{
if ( d ) {
2004-08-25 07:23:39 +04:00
talloc_free ( d - > data ) ;
2004-05-09 16:30:33 +04:00
d - > data = NULL ;
2003-08-13 05:53:07 +04:00
d - > length = 0 ;
}
}
/*******************************************************************
clear a DATA_BLOB ' s contents
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void data_blob_clear ( DATA_BLOB * d )
{
if ( d - > data ) {
memset ( d - > data , 0 , d - > length ) ;
}
}
/*******************************************************************
free a data blob and clear its contents
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void data_blob_clear_free ( DATA_BLOB * d )
{
data_blob_clear ( d ) ;
data_blob_free ( d ) ;
}
/*******************************************************************
check if two data blobs are equal
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2003-11-26 05:08:41 +03:00
BOOL data_blob_equal ( const DATA_BLOB * d1 , const DATA_BLOB * d2 )
2003-08-13 05:53:07 +04:00
{
if ( d1 - > length ! = d2 - > length ) {
return False ;
}
if ( d1 - > data = = d2 - > data ) {
return True ;
}
if ( d1 - > data = = NULL | | d2 - > data = = NULL ) {
return False ;
}
if ( memcmp ( d1 - > data , d2 - > data , d1 - > length ) = = 0 ) {
return True ;
}
return False ;
}
2004-12-01 19:51:37 +03:00
/*******************************************************************
print the data_blob as hex string
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
char * data_blob_hex_string ( TALLOC_CTX * mem_ctx , DATA_BLOB * blob )
{
int i ;
char * hex_string ;
hex_string = talloc_array_p ( mem_ctx , char , ( blob - > length * 2 ) + 1 ) ;
if ( ! hex_string ) {
return NULL ;
}
for ( i = 0 ; i < blob - > length ; i + + )
slprintf ( & hex_string [ i * 2 ] , 3 , " %02X " , blob - > data [ i ] ) ;
return hex_string ;
}
2004-12-18 07:38:43 +03:00
/*
useful for constructing data blobs in test suites , while
avoiding const warnings
*/
DATA_BLOB data_blob_string_const ( const char * str )
{
DATA_BLOB blob ;
blob . data = discard_const ( str ) ;
blob . length = strlen ( str ) ;
return blob ;
}
2004-12-21 18:15:49 +03:00
DATA_BLOB data_blob_const ( const void * p , size_t length )
{
DATA_BLOB blob ;
blob . data = discard_const ( p ) ;
blob . length = length ;
return blob ;
}