Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/anordal/shellharden
The corrective bash syntax highlighter
https://github.com/anordal/shellharden
lint policy syntax-highlighter
Last synced: 2 months ago
JSON representation
The corrective bash syntax highlighter
- Host: GitHub
- URL: https://github.com/anordal/shellharden
- Owner: anordal
- License: mpl-2.0
- Created: 2017-01-19T23:19:34.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-03-24T12:20:48.000Z (10 months ago)
- Last Synced: 2024-04-24T19:12:27.025Z (9 months ago)
- Topics: lint, policy, syntax-highlighter
- Language: Rust
- Homepage:
- Size: 438 KB
- Stars: 4,538
- Watchers: 48
- Forks: 136
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-bash - shellharden - The corrective bash syntax highlighter. (Analysis / Reusable Things)
- awesome-starred-test - anordal/shellharden - The corrective bash syntax highlighter (Rust)
- awesome-starred - shellharden - The corrective bash syntax highlighter (Rust)
- awesome-alternatives-in-rust - Shellharden - The corrective bash syntax highlighter (Development tools / Linters)
README
[![Build and test status](https://github.com/anordal/shellharden/workflows/build-and-tests/badge.svg?branch=master)](https://github.com/anordal/shellharden/actions)
Shellharden
===========Shellharden is a syntax highlighter and a tool to semi-automate the rewriting
of scripts to ShellCheck conformance, mainly focused on quoting.The default mode of operation is like `cat`, but with syntax highlighting in
foreground colors and suggestive changes in background colors:![real-world example](img/ex-realworld.png)
Above: Selected portions of `xdg-desktop-menu` as highlighted by Shellharden.
The foreground colors are syntax highlighting, whereas the background colors
(green and red) show characters that Shellharden would have added or removed
if let loose with the `--transform` option.
Below: An artificial example that shows more tricky cases and special features.![artificial example](img/ex-artificial.png)
Why
---A variable in bash is like a hand grenade – take off its quotes, and it starts ticking. Hence, rule zero of [bash pitfalls][1]: Always use quotes.
Name
----Shellharden can do what Shellcheck can't: Apply the suggested changes.
In other words, harden vulnerable shellscripts.
The builtin assumption is that the script does not *depend* on the vulnerable behavior –
the user is responsible for the code review.Shellharden was previously known as "Naziquote".
In the right jargon, that was the best name ever,
but oh so misleading and unspeakable to outsiders.I couldn't call it "bash cleaner" either, as that means "poo smearer" in Norwegian.
Prior art
---------* [Shellcheck][2] is a wonderful tool to *detect*, and give general advice, about vulnerable bash code. The only thing missing is something to say yes with, and *apply* those advice (assuming proper review of course).
* I asked [this SO question][3], for a tool that could rewrite bash scripts with proper quoting. One answerer beat me to it. But if it was me, I would do a syntax highlighter in the same tool (as a way to see if the parser gets lost, and make the most out of the parser, because bash is like quantum mechanics – nobody really knows how it works).
Get it
------Distro packages:
[![Packaging status](https://repology.org/badge/vertical-allrepos/shellharden.svg)](https://repology.org/project/shellharden/versions)
[Official rust package](https://crates.io/crates/shellharden):
cargo install shellharden
Build from source
-----------------cargo build --release
### Install
mv target/release/shellharden ~/.local/bin/
### Run tests
cargo test
(requires bash)
### Test coverage
env RUSTFLAGS="-C instrument-coverage" LLVM_PROFILE_FILE='run-%m.profraw' cargo test
grcov . --binary-path ./target/debug/ -s . -t html -o ./coverage/
rm run-*.profraw
open coverage/src/index.html### Fuzz test
cargo install cargo-afl
cargo afl build --release
cargo afl fuzz -i moduletests/original -o /tmp/fuzz-shellharden target/release/shellharden ''Usage advice
------------Don't apply `--transform` blindly; code review is still necessary: A script that *relies* on unquoted behavior (implicit word splitting and glob expansion from variables and command substitutions) to work as intended will do none of that after getting the `--transform` treatment!
In that unlucky case, ask yourself whether the script has any business in doing that. All too often, it's just a product of classical shellscripting, and would be better off rewritten, such as by using arrays. Even in the opposite case, say the business logic involves word splitting; that can still be done without invoking globbing. In short: There is always a better way than the forbidden syntax (if not more explicit), but some times, a human must step in to rewrite. See how, in the accompanying [how to do things safely in bash](how_to_do_things_safely_in_bash.md).
[1]: http://mywiki.wooledge.org/BashPitfalls
[2]: https://www.shellcheck.net/
[3]: http://stackoverflow.com/questions/41104131/tool-to-automatically-rewrite-a-bash-script-with-proper-quoting