ginst

ginst (short for generic installer) a tool used to install programs according to self written configurations.

The tool takes a .json file and tries to execute the commands given.

Note: It's currently only tested on Linux.

Requirements

Installation (as of now)

bash git clone https://github.com/Sebbito/FTI.git cd ginst/ cargo build -r sudo cp ./target/debug/ginst ~/.local/bin/

Info: This assumes that ~/.local/bin/ is in your PATH.

Usage

ginst --file path/to/programs.json

...it really can't do more than that as of now.

Configuring

Right now the only way to configure the tool is through the programs.json file (which has to be in the working dir). There you can specify a program with installations per distribution and dependencies.

See the example.json on how ginst expects the .json to look like.

The .json file has the following structure:

json { "programs": [ ... ] }

Where each program has a structure of:

json { "name": "<name>", "installation": { "<dist-name1>,<dist-name2>": [ "<bash-command1>", "<bash-command2>" ] }, "configuration": { "<dist-name1>,<dist-name2>": [ "<bash-command1>", "<bash-command2>" ] }, "dependencies": { "programs": [ ... ] } }

Some things that are worth noting:

Troubleshooting

Q: The programm doesn't start with the error:

Could not parse json file. Maybe you forgot a comma somewhere?

A: Well the answer is right there. The json could not be parsed. Make sure that you follow the outlined structure and have no syntax error.

os-release names

Make sure you use one of these in your .json: