yage
3fe01a7263
===================================================================== Increased non-scwrypts-runtime compatibility and improved clarity in user environments after sourcing the scwrypts.plugin.zsh. --- New Features ------------------------- - added experimental support for --output json - added 'scwrypts --list-groups' to output the SCWRYPTS_GROUPS value - added 'scwrypts --config' to be `eval`-ed in non-scwrypts-runtime zsh --- Changes ------------------------------ - removed config variables which pertained to old scwrypts - removed deprecated --no-log - cleaned up environment requirements and improved import saftey for scwrypts.plugin.zsh; scwrypts is now *required* on $PATH in order to work - refactored group configuration to match external group configuration (configuration now in scwrypts.scwrypts.zsh rather than zsh/lib/config.group.zsh) - plugins/kubectl now forces an unalias of `f` (for fluxcd) on load - the 'use' command now supports the '-c' short flag for ease of quick use - upgraded max supported python version to 3.12; dropped support for python 3.9 (>3.10 required) - remove old references to SCWRYPTS_ROOT in favour of SCWRYPTS_ROOT__scwrypts - SCWRYPTS_LOG_LEVEL setting is now forwarded when using the SCWRYPTS__RUN meta execution function |
||
---|---|---|
.circleci | ||
.config | ||
.github/workflows | ||
docs | ||
plugins | ||
py | ||
zsh | ||
zx | ||
.gitattributes | ||
.gitignore | ||
action.yaml | ||
LICENSE | ||
README.md | ||
scwrypts | ||
scwrypts.plugin.zsh | ||
scwrypts.scwrypts.zsh |
Scwrypts (Wryn + Scripts)
Scwrypts is a friendly CLI / API for quickly running sandboxed scripts in the terminal.
In modern developer / dev-ops workflows, scripts require a complex configurations. Without a better solution, the developer is cursed to copy lines-upon-lines of variables into terminals, create random text artifacts, or maybe even commit secure credentials into source. Scwrypts leverages ZSH to give hot-key access to run scripts in such environments.
Major Version Upgrade Notice
Please refer to Version 3 to Version 4 Upgrade Path when upgrading from scwrypts v3 to scwrypts v4!
Dependencies
Due to the wide variety of resources used by scripting libraries, the user is expected to manually resolve dependencies. Dependencies are lazy-loaded, and more information can be found by command error messages or in the appropriate README.
Because Scwrypts relies on Scwrypts (see Meta Scwrypts), zsh
must be installed and junegunn/fzf
must be available on your PATH.
Usage
Install Scwrypts by cloning this repository and sourcing scwrypts.plugin.zsh
in your zshrc
.
You can now run Scwrypts using the ZLE hotkey bound to SCWRYPTS_SHORTCUT
(default CTRL + W
).
% cd <path-to-cloned-repo>
% echo "source $(pwd)/scwrypts.plugin.zsh >> $HOME/.zshrc"
Check out Meta Scwrypts to quickly set up environments and adjust configuration.
No Install / API Usage
Alternatively, the scwrypts
API can be used directly:
./scwrypts [--env environment-name] (...script-name-patterns...) [-- ...passthrough arguments... ]
Given one or more script patterns, Scwrypts will filter the commands by pattern conjunction. If only one command is found which matches the pattern(s), it will immediately begin execution. If multiple commands match, the user will be prompted to select from the filtered list. Of course, if no commands match, Scwrypts will exit with an error.
Given no script patterns, Scwrypts becomes an interactive CLI, prompting the user to select a command.
After determining which script to run, if no environment has been specified, Scwrypts prompts the user to choose one.
Using in CI/CD or Automated Workflows
Set environment variable CI=true
(and use the no install method) to run in an automated pipeline.
There are a few notable changes to this runtime:
- The Scwrypts sandbox environment will not load. All variables will be read from context.
- User yes/no prompts will always be YES
- Other user input will default to an empty string
- Logs will not be captured
- Setting the environment variable
SCWRYPTS_GROUP_LOADER__[a-z_]\+
will source the file indicated in the variable (this allows custom groups without needing to modify theconfig.zsh
directly)- In GitHub actions,
*.scwrypts.zsh
groups are detected automatically from the$GITHUB_WORKSPACE
; setSCWRYPTS_GITHUB_NO_AUTOLOAD=true
to disable
- In GitHub actions,
Contributing
Before contributing an issue, idea, or pull request, check out the super-brief contributing guide