FlexIni allows you to load, utilize, and save one or more ini files within your Bash script. Values from the ini files are stored in an associative array and remain there until you initiate a save operation. This library was based on the ini/config management feature provided by Bashly. Big thanks to Bashly for making writing Bash scripts significantly more enjoyable!
The easiest way to "install" this is just to copy the flex_ini.sh into your project and add the line source /path/to/flex_ini.sh
to your script to make the functionality available.
You'll need to load an ini file and (if using multiple ini files within a script) set the ini id. The ini id is optional, so if you're only loading one ini file or if you started with one and now need to add a second, you can have some things which omit it, which populates the default_ini array, and some that specify it, which will populate the named array. Values can be set and read with or without sections:
section = nope!
email = email@email.com
[docker]
installed = false
[docker-ce]
installed = true
flex_ini_load "./app/global_settings.ini" "global"
flex_ini_load "./app/tenants/big-corp/settings.ini" "big-corp"
flex_ini_reload "your_ini_id"
flex_ini_clear "your_ini_id"
flex_ini_get "your.key" "your_ini_id"
flex_ini_has "your.key" "your_ini_id"
flex_ini_update "your.key" "the value" "your_ini_id"
# Optional saving of your ini at this stage
flex_ini_save "your_ini_id"
flex_ini_delete "the.key" "your_ini_id"
# Optional saving of your ini at this stage
flex_ini_save "your_ini_id"
flex_ini_save "your_ini_id"
flex_ini_save_as "/path/to/save/as/file.ini" "your_ini_id"
flex_ini_has_unsaved "your_ini_id"
flex_ini_reset
flex_ini_show "your_ini_id"
flex_ini_keys "your_ini_id"
If you want to override a default setting, you may change these or, probably better, change them when your script initializes after you source flex_ini.sh.
This setting controls whether we attempt to create an ini file when it is loaded but does not-yet exist on the filesystem. Most of the time this is probably desirable for ease of use.
auto_create_ini_on_load=true
This setting affects whether any change operations will also trigger a save operation. This can be helpful in cases where you know you're going to be updating only a setting or two, but should be avoided in the case where you are going to be doing tons and tons of updates. This will be less critical when the bulk update feature is ready.
auto_save_on_changes=false
This setting affects whether we make a your_settings.ini.bak file before we replace what's there. It's not a foolproof backup system, obviously, but it can help in case something goes wrong while you're testing.
back_up_changes_on_save=true
This setting shouldn't really, I don't think, be needed, but I still added it for transparency. By default, the file you specify during a save-as operation isn't backed up if it already exists.
back_up_changes_on_save_as=false
Sometimes you might need to run FlexIni as root but you may want to keep the file permissions of the ini the same. Update this to true to make the script attempt to re-assign the original owner/group.
reassign_file_permissions_when_possible=false
This allows you to override the directory used to store the temp files we make before saving.
tmp_directory="/tmp"