settings module¶
|
|
- class Settings(instance_id: str = 'default', handle=None)[source]¶
Bases:
object
Settings
provides a way to define and access settings in a hierarchical fashion. The value of a setting can be defined for each hierarchical level, where each level overrides the preceding level. The backing-store for setting values at each level is also configurable. This allows for ephemeral or platform-independent persistent settings storage for components within Binary Ninja or consumers of the Binary Ninja API.Each
Settings
instance has aninstance_id
which identifies a schema. The schema defines the settings contents and the way in which settings are retrieved and manipulated. A newSettings
instance defaults to using a value of ‘default’ for theinstance_id
. The ‘default’ settings schema defines all of the settings available for the active Binary Ninja components which include at a minimum, the settings defined by the Binary Ninja core. The ‘default’ schema may additionally define settings for the UI and/or installed plugins. Extending existing schemas, or defining new ones is accomplished by callingregister_group
andregister_setting
methods, or by deserializing an existing schema withdeserialize_schema
.Note
All settings in the ‘default’ settings schema are rendered with UI elements in the Settings View of Binary Ninja UI.
Allowing setting overrides is an important feature and Binary Ninja accomplishes this by allowing one to override a setting at various levels. The levels and their associated storage are shown in the following table. Default setting values are optional, and if specified, saved in the schema itself.
Setting Level
Settings Scope
Preference
Storage
Default
SettingsDefaultScope
Lowest
Settings Schema
User
SettingsUserScope
<User Directory>/settings.json
Project
SettingsProjectScope
<Project Directory>/settings.json
Resource
SettingsResourceScope
Highest
Raw BinaryView (Storage in BNDB)
Settings are identified by a key, which is a string in the form of ‘<group>.<name>’ or ‘<group>.<subGroup>.<name>’. Groups provide a simple way to categorize settings. Sub-groups are optional and multiple sub-groups are allowed. When defining a settings group, the
register_group
method allows for specifying a UI friendly title for use in the Binary Ninja UI. Defining a new setting requires a unique setting key and a JSON string of property, value pairs. The following table describes the available properties and values.Property
JSON Data Type
Prerequisite
Optional
{Allowed Values} and Notes
“title”
string
None
No
Concise Setting Title
“type”
string
None
No
{“array”, “boolean”, “number”, “string”}
“elementType”
string
“type” is “array”
No
{“string”}
“sorted”
boolean
“type” is “array”
Yes
Automatically sort list items (default is true)
“enum”
array : {string}
“type” is “string”
Yes
Enumeration definitions
“enumDescriptions”
array : {string}
“type” is “string”
Yes
Enumeration descriptions that match “enum” array
“minValue”
number
“type” is “number”
Yes
Specify 0 to infer unsigned (default is signed)
“maxValue”
number
“type” is “number”
Yes
Values less than or equal to INT_MAX result in a QSpinBox UI element
“precision”
number
“type” is “number”
Yes
Specify precision for a QDoubleSpinBox
“default”
{array, boolean, number, string, null}
None
Yes
Specify optimal default value
“aliases”
array : {string}
None
Yes
Array of deprecated setting key(s)
“description”
string
None
No
Detailed setting description
“ignore”
array : {string}
None
Yes
{“SettingsUserScope”, “SettingsProjectScope”, “SettingsResourceScope”}
“message”
string
None
Yes
An optional message with additional emphasis
“readOnly”
boolean
None
Yes
Only enforced by UI elements
“optional”
boolean
None
Yes
Indicates setting can be null
“hidden”
bool
“type” is “string”
Yes
Indicates the UI should conceal the content. The “ignore” property is required to specify the applicable storage scopes
“requiresRestart
boolean
None
Yes
Enable restart notification in the UI upon change
“uiSelectionAction”
string
“type” is “string”
Yes
{“file”, “directory”, <Registered UIAction Name>} Informs the UI to add a button to open a selection dialog or run a registered UIAction
Note
In order to facilitate deterministic analysis results, settings from the ‘default’ schema that impact analysis are serialized from Default, User, and Project scope into Resource scope during initial BinaryView analysis. This allows an analysis database to be opened at a later time with the same settings, regardless if Default, User, or Project settings have been modified.
Note
Settings that do not impact analysis (e.g. many UI settings) should use the “ignore” property to exclude “SettingsProjectScope” and “SettingsResourceScope” from the applicable scopes for the setting.
Example analysis plugin setting:
>>> my_settings = Settings() >>> title = "My Pre-Analysis Plugin" >>> description = "Enable extra analysis before core analysis." >>> properties = f'{{"title" : "{title}", "description" : "{description}", "type" : "boolean", "default" : false}}' >>> my_settings.register_group("myPlugin", "My Plugin") True >>> my_settings.register_setting("myPlugin.enablePreAnalysis", properties) True >>> my_bv = load("/bin/ls", options={'myPlugin.enablePreAnalysis' : True}) >>> Settings().get_bool("myPlugin.enablePreAnalysis") False >>> Settings().get_bool("myPlugin.enablePreAnalysis", my_bv) True
Example UI plugin setting:
>>> my_settings = Settings() >>> title = "My UI Plugin" >>> description = "Enable My UI Plugin table display." >>> properties = f'{{"title" : "{title}", "description" : "{description}", "type" : "boolean", "default" : true, "ignore" : ["SettingsProjectScope", "SettingsResourceScope"]}}' >>> my_settings.register_group("myPlugin", "My Plugin") True >>> my_settings.register_setting("myPlugin.enableTableView", properties) True >>> my_bv = load("/bin/ls", options={'myPlugin.enableTableView' : True}) >>> Settings().get_bool("myPlugin.enableTableView") True
- Parameters:
instance_id (str) –
- contains(key)[source]¶
contains
determine if a setting identifier exists in the active settings schema
- is_empty()[source]¶
is_empty
determine if the active settings schema is empty- Returns:
True if the active settings schema is empty, False otherwise
- Return type:
- register_group(group, title)[source]¶
register_group
registers a group in the schema for thisSettings
instance
- register_setting(key, properties)[source]¶
register_setting
registers a new setting with thisSettings
instance- Parameters:
- Returns:
True on success, False on failure.
- Return type:
- Example:
>>> Settings().register_group("solver", "Solver") True >>> Settings().register_setting("solver.basicBlockSlicing", '{"description" : "Enable the basic block slicing in the solver.", "title" : "Basic Block Slicing", "default" : true, "type" : "boolean"}') True
- set_resource_id(resource_id=None)[source]¶
set_resource_id
Sets the resource identifier for this class:Settings instance. When accessing setting values at theSettingsResourceScope
level, the resource identifier is passed along through the backing store interface.Note
Currently the only available backing store for
SettingsResourceScope
is aBinaryView
object. In the context of aBinaryView
the resource identifier is theBinaryViewType
name. All settings for this type of backing store are saved in the ‘Raw’BinaryViewType
. This enables the configuration of setting values such that they are available duringBinaryView
creation and initialization.- Parameters:
resource_id (str) – a unique identifier
- Return type:
None
- default_handle = <binaryninja._binaryninjacore.LP_BNSettings object>¶