Line data Source code
1 : #include "fd_snapshot_base.h" 2 : 3 : #include <stdlib.h> 4 : 5 : fd_snapshot_name_t * 6 : fd_snapshot_name_from_buf( fd_snapshot_name_t * id, 7 : char const * str, 8 : ulong str_len, 9 3 : ulong base_slot ) { 10 3 : char buf[ 4096 ]; 11 3 : str_len = fd_ulong_min( sizeof(buf)-1, str_len ); 12 3 : fd_memcpy( buf, str, str_len ); 13 3 : buf[ str_len ] = '\0'; 14 : 15 3 : return fd_snapshot_name_from_cstr( id, buf, base_slot ); 16 3 : } 17 : 18 : fd_snapshot_name_t * 19 : fd_snapshot_name_from_cstr( fd_snapshot_name_t * id, 20 : char const * cstr, 21 3 : ulong base_slot ) { 22 : 23 3 : fd_memset( id, 0, sizeof(fd_snapshot_name_t) ); 24 : 25 3 : const char * orig_cstr = cstr; 26 : 27 3 : char * last_slash = strrchr( cstr, '/' ); 28 3 : if( last_slash && last_slash[0]=='/' ) cstr = last_slash + 1; 29 : 30 3 : if( 0==strncmp( cstr, "snapshot-", sizeof("snapshot-")-1 ) ) { 31 0 : cstr += sizeof("snapshot-")-1; 32 0 : id->type = FD_SNAPSHOT_TYPE_FULL; 33 3 : } else if( 0==strncmp( cstr, "incremental-snapshot-", sizeof("incremental-snapshot-")-1 ) ) { 34 0 : cstr += sizeof("incremental-snapshot-")-1; 35 0 : id->type = FD_SNAPSHOT_TYPE_INCREMENTAL; 36 3 : } else { 37 3 : FD_LOG_WARNING(( "unrecognized snapshot type: \"%s\"", orig_cstr )); 38 3 : return NULL; 39 3 : } 40 : 41 0 : char const * endptr = NULL; 42 0 : id->slot = strtoul( cstr, fd_type_pun( &endptr ), 10 ); 43 0 : if( !endptr || endptr[0]!='-' ) { 44 0 : FD_LOG_WARNING(( "invalid snapshot file name: \"%s\"", orig_cstr )); 45 0 : return NULL; 46 0 : } 47 0 : cstr = endptr+1; 48 : 49 0 : if( id->type == FD_SNAPSHOT_TYPE_INCREMENTAL ) { 50 0 : id->incremental_slot = strtoul( cstr, fd_type_pun( &endptr ), 10 ); 51 0 : if( !endptr || endptr[0]!='-' ) { 52 0 : FD_LOG_WARNING(( "invalid snapshot file name: \"%s\"", orig_cstr )); 53 0 : return NULL; 54 0 : } 55 0 : cstr = endptr+1; 56 : 57 0 : if( base_slot != id->slot ) { 58 0 : FD_LOG_WARNING(( "failed to load snapshot: \"%s\"", orig_cstr )); 59 0 : FD_LOG_WARNING(( "expected base slot %lu but got %lu, incremental snapshot does not match full snapshot", base_slot, id->slot )); 60 0 : return NULL; 61 0 : } 62 0 : } 63 : 64 0 : char const * file_ext = strchr( cstr, '.' ); 65 0 : ulong file_ext_off = (ulong)( file_ext - cstr ); 66 : 67 0 : char hash_cstr[ FD_BASE58_ENCODED_32_SZ ] = {0}; 68 0 : strncpy( hash_cstr, cstr, sizeof(hash_cstr)-1 ); 69 0 : if( file_ext_off < sizeof(hash_cstr) ) { 70 0 : hash_cstr[ file_ext_off ] = '\0'; 71 0 : } 72 0 : strncpy( id->file_ext, file_ext, sizeof(id->file_ext)-1 ); 73 : 74 0 : if( FD_UNLIKELY( !fd_base58_decode_32( hash_cstr, id->fhash.hash ) ) ) { 75 0 : FD_LOG_WARNING(( "invalid snapshot file name: \"%s\"", orig_cstr )); 76 0 : return NULL; 77 0 : } 78 0 : return id; 79 0 : }