Changeset 257


Ignore:
Timestamp:
06/16/11 20:13:13 (14 years ago)
Author:
tim
Message:

documentation fixes/additions

Location:
trunk
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/lib/regfi.c

    r256 r257  
    19971997  cur_key = regfi_iterator_cur_key(i);
    19981998  if(cur_key == NULL)
    1999     /* XXX: report error */
     1999    regfi_log_add(REGFI_LOG_ERROR, "Current key invalid in find_subkey.");
    20002000    return ret_val;
    20012001
     
    21002100  cur_key = regfi_iterator_cur_key(i);
    21012101  if(cur_key == NULL)
    2102     /* XXX: report error */
     2102    regfi_log_add(REGFI_LOG_ERROR, "Current key invalid in cur_subkey.");
    21032103    return NULL;
    21042104
     
    21292129  cur_key = regfi_iterator_cur_key(i);
    21302130  if(cur_key == NULL)
    2131     /* XXX: report error */
     2131    regfi_log_add(REGFI_LOG_ERROR, "Current key invalid in find_value.");
    21322132    return ret_val;
    21332133
     
    21612161  cur_key = regfi_iterator_cur_key(i);
    21622162  if(cur_key == NULL)
    2163     /* XXX: report error */
     2163    regfi_log_add(REGFI_LOG_ERROR, "Current key invalid in cur_value.");
    21642164    return ret_val;
    21652165
     
    25232523    }
    25242524
    2525     /* XXX: check for NULL */
    25262525    tmp_str = talloc_realloc(NULL, tmp_str, uint8_t, tmp_size);
     2526    if(tmp_str == NULL)
     2527      return false;
    25272528    data->interpreted.string = tmp_str;
    25282529    data->interpreted_size = tmp_size;
     
    27702771  memcpy(ret_val->file_name, file_header+0x30,  REGFI_REGF_NAME_SIZE);
    27712772
    2772   /* XXX: Should we add a warning if these uuid parsers fail?  Can they? */
    27732773  ret_val->rm_id = winsec_parse_uuid(ret_val, file_header+0x70, 16);
     2774  if(ret_val->rm_id == NULL)
     2775    regfi_log_add(REGFI_LOG_WARN, "Hive header's rm_id failed to parse.");
     2776
    27742777  ret_val->log_id = winsec_parse_uuid(ret_val, file_header+0x80, 16);
     2778  if(ret_val->log_id == NULL)
     2779    regfi_log_add(REGFI_LOG_WARN, "Hive header's log_id failed to parse.");
     2780
    27752781  ret_val->flags = IVAL(file_header, 0x90);
     2782
    27762783  ret_val->tm_id = winsec_parse_uuid(ret_val, file_header+0x94, 16);
     2784  if(ret_val->tm_id == NULL)
     2785    regfi_log_add(REGFI_LOG_WARN, "Hive header's tm_id failed to parse.");
     2786
    27772787  ret_val->guid_signature = IVAL(file_header, 0xa4);
    27782788
     
    34863496
    34873497  /* XXX: do something with unalloc? */
    3488 
    34893498  max_size = regfi_calc_maxsize(file, offset);
    34903499  if((max_size < 0) || (num_chunks*sizeof(uint32_t) + 4 > max_size))
  • trunk/lib/winsec.c

    r253 r257  
    6262  ret_val->control = SVAL(buf, 0x2);
    6363
     64  /* XXX: should probably reject any non-self relative */
    6465  if(!(ret_val->control & WINSEC_DESC_SELF_RELATIVE))
    6566    fprintf(stderr, "DEBUG: NOT self-relative!\n");
  • trunk/python/pyregfi/__init__.py

    r256 r257  
    1111#
    1212# The library operates on registry hives, each of which is contained within a
    13 # single file.  To get started, one must first open the registry hive file with
    14 # the open() or file() Python built-in functions (or equivalent) and then pass
    15 # the resulting file object to pyregfi. For example:
     13# single file.  The quickest way to get started, is to use the @ref openHive()
     14# function to obtain a Hive object.  For example:
    1615# @code
    1716# >>> import pyregfi
    18 # >>> fh = open('/mnt/win/c/WINDOWS/system32/config/system', 'rb')
    19 # >>> myHive = pyregfi.Hive(fh)
     17# >>> myHive = pyregfi.openHive('/mnt/win/c/WINDOWS/system32/config/system')
    2018# @endcode
    2119#
     
    300298#
    301299class Security(_StructureWrapper):
    302     ## Number of keys referencing this SK record
     300    ## Number of registry Keys referencing this SK record
    303301    ref_count = 1
    304302
     
    306304    offset = 0xCAFEBABE
    307305
    308     ## The @ref SecurityDescriptor for this SK record
     306    ## The @ref winsec.SecurityDescriptor for this SK record
    309307    descriptor = object()
    310308
     
    314312        self.descriptor = winsec.SecurityDescriptor(base.contents.sec_desc.contents)
    315313
    316     ## Loads the "previous" Security record in the hive
     314    ## Loads the "next" Security record in the hive
    317315    #
    318316    # @note
     
    337335## Abstract class for ValueList and SubkeyList
    338336class _GenericList(object):
     337    # XXX: consider implementing keys(), values(), items() and other dictionary methods
    339338    _hive = None
    340339    _key_base = None
     
    373372    ## Retrieves a list element by name
    374373    #
     374    # @param name The name of the subkey or value desired. 
     375    #             This is case-sensitive.
     376    #
     377    # @note The registry format does inherently prevent multiple
     378    #       subkeys or values from having the same name. 
     379    #       This interface simply returns the first match. 
     380    #       Lookups using this method could also fail due to incorrectly
     381    #       encoded strings.
     382    #       To identify any duplicates, use the iterator interface to
     383    #       check every list element.
     384    #
    375385    # @return the first element whose name matches, or None if the element
    376386    #         could not be found
    377387    def __getitem__(self, name):
     388        # XXX: Consider interpreting integer names as offsets in the underlying list
    378389        index = ctypes.c_uint32()
    379390        if isinstance(name, str):
     
    391402        raise KeyError('')
    392403
     404
     405    ## Fetches the requested element by name, or the default value if the lookup
     406    #  fails.
     407    #
    393408    def get(self, name, default):
    394409        try:
     
    426441# @endcode
    427442#
    428 # @note SubkeyLists should never be accessed directly and only exist
    429 #       in association with a parent Key object.  Do not retain references to
    430 #       SubkeyLists.  Instead, access them via their parent Key at all times.
     443# You may also request the len() of a subkeys list.
     444# However keys(), values(), items() and similar methods are not currently
     445# implemented.
    431446class SubkeyList(_GenericList):
    432447    _fetch_num = regfi.regfi_fetch_num_subkeys
     
    447462# @endcode
    448463#
    449 # @note ValueLists should never be accessed directly and only exist
    450 #       in association with a parent Key object.  Do not retain references to
    451 #       ValueLists.  Instead, access them via their parent Key at all times.
     464# You may also request the len() of a values list.
     465# However keys(), values(), items() and similar methods are not currently
     466# implemented.
    452467class ValueList(_GenericList):
    453468    _fetch_num = regfi.regfi_fetch_num_values
     
    460475# access to their subkeys, values, and other metadata.
    461476#
    462 # @note Value instances may provide access to more than the attributes
     477# @note Key instances may provide access to more attributes than are
    463478#       documented here.  However, undocumented attributes may change over time
    464479#       and are not officially supported.  If you need access to an attribute
    465 #       not shown here, see pyregfi.structures.
     480#       not shown here, see @ref pyregfi.structures.
    466481class Key(_StructureWrapper):
    467482    ## A @ref ValueList object representing the list of Values
     
    558573        return None
    559574
     575
     576    ## Checks to see if this Key is the root of its Hive
     577    #
     578    #  @return True if it is, False otherwise
    560579    def is_root(self):
    561580        return (self._hive.root == self)
     
    567586# access to their associated data.
    568587#
    569 # @note Value instances may provide access to more than the attributes
     588# @note Value instances may provide access to more attributes than are
    570589#       documented here.  However, undocumented attributes may change over time
    571590#       and are not officially supported.  If you need access to an attribute
    572 #       not shown here, see pyregfi.structures.
     591#       not shown here, see @ref pyregfi.structures.
    573592class Value(_StructureWrapper):
    574593    ## The raw Value name as an uninterpreted bytearray
  • trunk/python/pyregfi/winsec.py

    r255 r257  
    9797
    9898## Represents a Microsoft access control entry, which are elements of access
    99 #  control lists
     99#  control lists.  For more information, see:
     100#    http://msdn.microsoft.com/en-us/library/aa374868%28v=vs.85%29.aspx
    100101#
    101102#  @note
     
    136137
    137138
     139## A Microsoft security descriptor
     140# For more information, see:
     141#   http://msdn.microsoft.com/en-us/library/aa379563%28v=vs.85%29.aspx
     142#
    138143class SecurityDescriptor(object):
    139144    ## The security descriptor's owner SID, as a string
     
    143148    group = "S-1-2-..."
    144149
    145     ## A list of @ref ACE objects which represents the System ACL
    146     # May be None if a sacl isn't defined
     150    ## The system access control list represented as a list of @ref ACE objects.
     151    #
     152    # Is set to None if a sacl isn't defined
    147153    sacl = []
    148154
    149     ## A list of @ref ACE objects which represents the User ACL
    150     # May be None if a dacl isn't defined
     155    ## The discretionary access control list represented as a list of @ref ACE objects
     156    #
     157    # Is set to None if a dacl isn't defined
    151158    dacl = []
    152159
     
    160167        libc.free(c_str)
    161168
    162         # XXX: add checks for NULL pointers
    163169        self.sacl = None
    164170        if sec_desc.sacl:
Note: See TracChangeset for help on using the changeset viewer.