Added documentation notes about the configuration object

This commit is contained in:
Caleb Stewart 2020-10-08 13:53:31 -04:00
parent e658f9a592
commit f69542f0b4
1 changed files with 65 additions and 0 deletions

View File

@ -0,0 +1,65 @@
Configuration
=============
Configuration in ``pwncat`` is tracked in the ``pwncat.config`` object. This object
acts similar to a dictionary with some extra features. Specifically, this object
implements type checking, and understands/tracks module context.
There is a module named ``pwncat.config`` which contains some helper-types, but
generally should not be needed. It is masked behind an object defined in ``pwncat/__init__.py``
named ``config``. The ``pwncat.config`` object is of the type ``pwncat.config.Config``.
When used as a dictionary, only setting local values (specific to a module context) is
supported. Therefore, the following is valid within a module context:
.. code-block:: python
import pwncat
pwncat.config["lhost"] = "10.10.10.10"
If you would like to set global configuration items, you must use the ``set`` method:
.. code-block:: python
import pwncat
pwncat.config.set("lhost", "10.10.10.10", glob=True)
When retreiving values, the preference is always for local module-context values. If
no module-specific values are set, then the global value is returned. You can use the
dictionary syntax for this:
.. code-block:: python
import pwncat
username = pwncat.config["backdoor_user"]
To add available global configuration items, you can add items to the ``pwncat.config.values``
dictionary. This dictionary maps configuration names to another dictionary. The structure
looks like this:
.. code-block:: python
pwncat.config.values["config_name"] = {
"value": "default or current value",
"type": callable_converting_string_to_correct_type
}
The ``type`` property should be a callable which converts the input (normally a string``
to the required type. If the required type is passed in, it should be returned unchanged.
If the provided value is invalid, a ``ValueError`` should be raised.
If the value is a script (such as ``on_load``), the type will be a regular string. In this
case, the string is literally a script which will be evaluated upon some condition.
Key Bindings
------------
Key bindings are handled separately from standard configuration items. They are managed
with the same configuration object, but are retrieved using the ``binding`` method. This method
takes either a string representing the name of the key or a bytes object representing the
raw key-codes. The keybindings are stored in the ``pwncat.config.bindings`` dictionary which
maps ``KeyType`` objects to the script which executes upon their press.
This is mainly a UI/end-user function, and therefore the only clean method of modifying this
dictionary at the moment is through the ``set`` command. This may change in the future.