Bash Script Manager
Project description
Welcome to pbash
Bash Script Manager
pbash helps managing a set of bash scripts. It keeps the logic of one file per script, but creates aliases and handle parameter prompt and pipe.
Main features
- bash script run
- parameter prompt
- parameter pass through pipe
- automatic cli command and option from the script
- git support
- possibility to handle several distinct stores
- commands and params autocompletion
Roadmap
- enhanced filter
- test on other platforms
- code cleaning
Installation
Requirements
The application is developped and used on ubuntu 21.10, with python 3.9.7. Any feedback on other platforms is welcomed.
- python3 >=3.6.2,<4.0
- git:
sudo apt install git
- nano:
sudo apt install nano
Install from pypi
pip install pbash
For an isolated environment with pipx:
pipx install pbash
Install from deb package
A deb package is available, built using dh-virtualenv
. Installing this package will create a new Python virtual environment in opt/venvs
. It will then create the symlink usr/bin/pbash
pointing to opt/venvs/pbash/bin/pbash
.
Note that dh-virtualenv
built packages are dependent of python version. Use this only if you have default python version installed:
- ubuntu bionic 18.04: Python 3.6
- ubuntu focal 20.04: Python 3.8
- ubuntu hirsute 21.04: Python 3.9
- ubuntu impish 21.10: Python 3.9
Download latest .deb
file from the release page.
sudo dpkg -i pbash_0.1.0_{{os}}_amd64.deb
Usage
Initialise
Initialisation is required before using the application, to create the working diretory.
pbash init
A configuration file .pbashrc
is created in the user home directory.
By default, scripts will be stored in ${HOME}/.pbash/
folder.
The --edit
option will open configuration file in edit mode.
Create a new script
You can create a new script file.
pbash new --name "${NAME}" --desc "${DESCRIPTION}" --param "${PARAM1}" --param "${PARAM2}"
If options are not given, they will be prompted at run.
For param details, see below.
Script template
To add a description to the script, add a comment line beginning with #DESC
.
#DESC ...
To add a param to the script, add a comment line beginning with #PARAM
.
#PARAM <name>, <question>, <default>, <always_prompt>
Only <name>
is required. This value must be strict alphanumeric. The application will automatically create an option --<name>
for the cli run
command.
<question>
is used for cli prompt and option help message. Default is empty string.
<default>
is the default value. Default is empty string.
<always_prompt>
is used to display prompt even when a default value is given. Set to true
if desired. Default is false
.
Run a script
The generic run
command calls the corresponding script.
pbash run <name>
Options are automatically created based on script informations.
Run a script (example)
Let's take the below script example.sh
#!/bin/bash
#PARAM user, User
#PARAM message, Which message
read -p "User: " user
read -p "Which message: " message
echo "$user says $message"
The script can be run directly through terminal.
It can also be run through pbash : the params will be prompted
pbash run example
It can be run with options :
pbash run example --user "Sebastien" --message "Hello World!"
Or with piped arguments
(echo "Sebastien"; echo "Hello World!") | pbash run example
# or
cat <(echo "Sebastien") <(echo "Hello World!") | pbash run example
Note : for piped arguments, all params must be given so that it works
List scripts
pbash list <filter>
Edit a script
Script edition will open the file in default cli editor.
pbash edit <filter>
Filter
Currently command filter is only done on the script file name.
A future enhancement will provide a better filter functionnality.
pbash <command> <anything>
will filter displayed scripts based on anything
value (name containing this value).
Add a new store
You can create several stores (config sections). Default store path is ${HOME}/.pbash-${NAME}/
pbash -c "${STORE}" init --new-section
You can also select path via the option --path
. The folder will be created if it does not exist.
pbash -c "${STORE}" init --new-section --path "${PATH}"
Use a store
All functions can be used for a specific store by using the -c
option from pbash application.
pbash -c "${STORE}" new ...
pbash -c "${STORE}" list ...
pbash -c "${STORE}" run ...
# etc.
Initialise new git repository
You can initialise a new git repository in store path. It will set automatic git push for every script creation or modification. The git repository needs to be created on your platform before.
A default branch main
is created.
pbash -c "${STORE}" init-git
You can also pass parameter through cli command:
pbash -c "${STORE}" init-git --repo "${REPO}" --user "${USER}" --mail "${EMAIL}" --branch "${BRANCH}"
Initialise from existing git repository
If the git repository already exists, you can restore it in the current store folder by adding the --pull
option to init-git
command.
It will download the latest commit from main
branch. If the branch name is different, you can update it in the config file through pbash init --edit
or through --branch
option.
Publish to git
When a git repository is enabled, all changes to scripts will be pushed to remote. However, there will never be automatic pull to retrieve potential scripts changes from remote (from other application, computer, user, aso.).
It can be done manually through
pbash -c "${STORE} git pull"
# or
pbash -c "${STORE} git sync" # pull then push
In case a remote change is done but not pulled, the automatic push on script modification will fail. A manual git sync
will be required to merge local and remote.
Shortcuts and Aliases
Application must give a fast access to scripts to be useful.
I personnaly defined shortcuts in my home .bashrc
file:
alias pb='pbash -c PRO'
alias pbr='pbash -c PRO run'
alias pbp='pbash -c PERSO'
alias pbpr='pbash -c PERSO run'
Build
Requirements
- debhelper:
sudo apt install debhelper
- dh-virtualenv
- build
- virtualenv
Commands
poetry install
# build deb
dpkg-buildpackage -us -uc
dpkg-buildpackage -Tclean
# build python package
python3 -m build
Dependencies
Python Libraries
Python Development Libraries
Author
Sébastien Guerri - github page
Issues
Contributions, issues and feature requests are welcome!
Feel free to check issues page. You can also contact me.
License
Copyright (C) 2022 Sebastien Guerri
pbash is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version.
pbash is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with pbash. If not, see https://www.gnu.org/licenses/.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pbash-0.1.0.tar.gz
.
File metadata
- Download URL: pbash-0.1.0.tar.gz
- Upload date:
- Size: 16.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1d477c23684aeb7e684fbbc4abfe81c4c16de1aa007c68278ae9d40b3844ca1c |
|
MD5 | c34ad26825d5341e9017b7e13de60e37 |
|
BLAKE2b-256 | 37270f12f056062e6e9c455eee68ea0032aa16da3788ba4fb2814a0473e5b391 |
File details
Details for the file pbash-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: pbash-0.1.0-py3-none-any.whl
- Upload date:
- Size: 16.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ee67d328ca182d62d1452840e1dd5b803f95e5a4afdb19e489599c69d06d4bf3 |
|
MD5 | 58779d1467cefc23f535b552525f8f9f |
|
BLAKE2b-256 | 9c542f789154e13a03ec41067b81e56b86d26677190363d2cac48c8a8e1285f0 |