filemap is a Python module for comfortable processing of Kubernetes-style config maps and secrets, mounted as the volumes.
When connected as volumes, Kubernetes config maps and secrets are single-level directory, where files are keys and file contents are values.
When loaded, inside FileMap object, keys are transformed into fields and namespaces, field trees are formed with the dots in file names, as:
- somekey => obj.data.somekey
- some.key => obj.data.some.key
- some.another.key => obj.data.some.another.key
Example:
from filemap import FileMap
config = FileMap('/etc/config')
print(config.data.somekey)
print(config.data.some.key)
print(config.data.some.another.key)
Note: when text data is loaded, it's automatically right-stripped.
print(config.get('some.key'))
print(config.get('some.another.key'))
When serialized, FileMap object is transformed into dict:
data = config.serialize() # or
data = dict(config) # does the same
print(data['somekey'])
print(data['some']['key'])
print(data['some']['another']['key'])
FileMap object can be updated multiple times with content from the different data folders:
config = FileMap()
config.update('/etc/config')
config.update('/etc/config2')
config.update('/etc/secrets')
If the same keys exist in different volumes, newer keys override the older ones.
Refer to library pydoc for more info
pip3 install filemap