-
Notifications
You must be signed in to change notification settings - Fork 101
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Custom value types #62
Comments
Good catch. I see that there are two modifiers that we should be taking into account:
I'm not quite sure how these affect parsing yet, but I'm sure we can work that out to support lists and arrays of the other basic types (int, string, timestamp, etc). To do this, we'd also need to check the "type modifier" by using
With this approach, we'd be inspecting the lower two bytes of the DWORD. Do you know what is placed in the higher two bytes, and if we can parse it? Are 0xFFFF0012 and 0x00000012 both In any case, I suggest that we update |
On Windows 10, when storing device properties, these bytes are always set to 0xFF. But, as I said before, the higher two bytes in other keys can be used by something else. |
Ok, then I propose updating The benefit is that this allows an advanced user to parse unusual structures manually using An issue is that most developers won't realize this could happen, and will assume that I'm trying to balance ease-of-use of the module with providing the most correct data. As a developer, what would you most like to see? |
Sounds good.
I think that the best solution is to introduce the |
+1 on the issue - I just ran into 0x00002012 today (along with 0x00000011 and 0x00000012, which python-registry does not handle). |
@geoffblack having read the above discussion, do you have any opinions on how the API could be enhanced? |
An application (or a driver) can specify any value type possible. You may also find this post interesting. |
I think introducing separate methods per data type set is the wrong thing to do, and not just for backwards compatibility. In the short term, I like fixing the mask and adding raw_data_type() - it gets what I need as the user to do my own decoding with raw_data(), and it's a quick fix. In the long term, you could build profiles of data type definitions, where data() takes a parameter for the data type set. The default would be standard registry data types already included in python-registry, but you could add other data type lists like devprop_type* from devpropdef.h over time, and the necessary code to support decoding those data types. The user would still have to know which data type set to use in certain areas of the registry, but it would make it easier for the user. |
@williballenthin I've just read through raw_data() and realized your implementation there is problematic for this, as well. Take, for example, the case of RegMultiSZ (0x07). In the DevPropType list 0x00000007 is a uint32. I have not tested this, but there's a case in there where you're not actually returning the raw data (!!!), but instead returning and empty byte string because, "it must be 4, and be composed of completely \x00, so the strings are empty." So, I'm not sure raw_data_type() is a quick fix if raw_data() can't be relied upon with non-default data types. |
Just to follow up - I do indeed have a registry value with 4 bytes of data where |
acknowledged. sounds like i need to sit down one weekend and implement some of these approaches to figure out what works best. is there any chance you can share the hive? i understand if you cannot. |
You can find samples of these values in the SANS Donald Blake Windows 8.1 image in various keys under |
thanks! |
Is it possible to get the image? Not just registry files. |
Hello.
At present, the
data_type()
method of theVKRecord
class applies theDEVPROP_MASK_TYPE
(0x00000FFF) bit mask to a registry value type using the AND operation, and thus clears bits#12
-#31
in this value type. I know that the purpose of this operation is to extract theDEVPROP_TYPE_FILETIME
(0x00000010) type (you call itRegFileTime
), but there is a major issue here:DEVPROP_TYPE_FILETIME
),DEVPROP_MASK_TYPE
bit mask when parsing a value type.Based on this, the library can't silently clear the bits in a value type. For example, the PnP subsystem is using the
DEVPROP_TYPE_STRING_LIST
(0x00002012) type to store device location paths in the registry (this type will be converted to following value: 0xFFFF2012). Reading such a type withpython-registry
will return 18 (0x12), orDEVPROP_TYPE_STRING
, if we resolve this constant in the context of device properties, but this value is wrong, because it doesn't match the value stored by the subsystem.The text was updated successfully, but these errors were encountered: