Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bwireman/go-over
A tool to audit Erlang & Elixir dependencies, to make sure your ✨ gleam projects really sparkle!
https://github.com/bwireman/go-over
audit beam cli dependencies dependency elixir erlang ghsa gleam javascript security security-audit security-tools tools vulnerable
Last synced: 3 days ago
JSON representation
A tool to audit Erlang & Elixir dependencies, to make sure your ✨ gleam projects really sparkle!
- Host: GitHub
- URL: https://github.com/bwireman/go-over
- Owner: bwireman
- License: mit
- Created: 2024-05-18T22:58:19.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2025-02-15T17:51:22.000Z (3 days ago)
- Last Synced: 2025-02-15T18:24:46.193Z (3 days ago)
- Topics: audit, beam, cli, dependencies, dependency, elixir, erlang, ghsa, gleam, javascript, security, security-audit, security-tools, tools, vulnerable
- Language: Gleam
- Homepage: https://hex.pm/packages/go_over
- Size: 3.09 MB
- Stars: 17
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gleam - go_over - [📚](https://hexdocs.pm/go_over/) - A tool to audit Erlang & Elixir dependencies, to make sure your gleam projects really sparkle! ✨ (Packages / Project Tooling)
- awesome-ccamel - bwireman/go-over - A tool to audit Erlang & Elixir dependencies, to make sure your ✨ gleam projects really sparkle! (Gleam)
README
# 🕵️♂️ go_over
[data:image/s3,"s3://crabby-images/36a30/36a30ba6686db1b12eea3d61afd686cee9901624" alt="Package Version"](https://hex.pm/packages/go_over)
[data:image/s3,"s3://crabby-images/7c557/7c557a32f08e49c79944cb17a8d1b101a5ccade0" alt="Hex Docs"](https://hexdocs.pm/go_over/)
[data:image/s3,"s3://crabby-images/fe407/fe407202820c3707b164fa8d9ecaae120a987c78" alt="mit"](https://github.com/bwireman/over/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/c2a99/c2a99c8f162ad203292361064a92e955a30074ef" alt="gleam js"](https://gleam.run/news/v0.16-gleam-compiles-to-javascript/)
[data:image/s3,"s3://crabby-images/2f0ba/2f0ba1c06f44db249fc155c1bd3ec58bfa1eaeb2" alt="gleam erlang"](https://gleam.run)A tool to audit Erlang & Elixir dependencies, to make sure your ✨ gleam
projects really sparkle!🚨 _**NOTE**_: security advisories are _NOT_ currently monitored for gleam
dependencies. The language, while excellent, is far too new and niche# 🔽 Install
```sh
gleam add --dev go_over
```## 📣 Also!
- add `.go-over/` to your `.gitignore`
- make sure `git` & `curl` are installed#### 🌸 Javascript
If running with Javascript install
```json
{
"devDependencies": {
"yaml": "^2.4.3"
}
}
```Bun, Deno & Nodejs are _all_ supported!
# ▶️ Usage
```sh
gleam run -m go_over
```### 🎥 Obligatory VHS
data:image/s3,"s3://crabby-images/0bbe4/0bbe42ae48d5886ea667b0bdae52795c90e78184" alt="demo"
### 🏴 Flags
- `--format` FORMAT: Specify the output format of any warnings, [minimal,
verbose, json] (default: None)
- `--force`: Force pulling new data even if the cached data is still valid
- `--outdated`: Additionally check if newer versions of dependencies exist
- `--ignore-indirect`: Ignore all warnings for indirect dependencies
- `--verbose`: Print progress as packages are checked
- `--help`,-h: Print helpFlags override config values if set
### ⚙️ Config
Optional settings that can be added to your project's `gleam.toml`
```toml
[go-over]
# disables caching if false
# default: true
cache = true
# if true all cached data will be stored in user's home directory
# allowing cache to be shared between projects
# default: false
global = false
# sets output format for warnings ["minimal", "detailed", "json"]
# default: "minimal"
format = "minimal"
# will additionally check if newer versions of dependencies exist
# default: false
outdated = false[go-over.ignore]
# will ignore all warnings for indirect dependencies
# default: false
indirect = false
# will ignore all warnings for dev-dependencies. Note: to ignore indirect dependencies regardless of source see go-over.ignore.indirect
# default: false
dev_dependencies = false
# list of package names to skip when auditing dependencies
# default: []
packages = ["example_package"]
# list of warning severities to skip when auditing dependencies
# default: []
# (case insensitive)
severity = ["example_moderate"]
# list of advisory IDs to skip when auditing dependencies
# default: []
ids = ["GHSA-xxxx-yyyy-zzzz"]
```### ⌛ Caching
- Security advisory data is cached for **_six_** hours
- hex.pm retired package data is cached for **_one_** hour## 🪝 pre-commit hooks
You can add go_over to you're pre-commit hooks by installing
[🌵cactus](https://hex.pm/packages/cactus) & then adding this to your
`gleam.toml````toml
[cactus.pre-commit]
actions = [
{ command = "go_over", kind = "module", args=["--outdated"] },
]
```## ⚙️ CI
You can also schedule daily runs to keep your deps up to date and open issues
when necessary!
[Example ▶️](https://github.com/bwireman/go-over/blob/main/.github/workflows/deps.yml)# 🖌️ Other Art
- As I'm sure is no surprise this tool is inspired by (and all around worse
than) [mirego/mix_audit](https://github.com/mirego/mix_audit). Please check it
out!
- It also draws inspiration from
[mix hex.audit](https://hexdocs.pm/hex/Mix.Tasks.Hex.Audit.html)# ⚖️ License
- This tool uses
[mirego/elixir-security-advisories](https://github.com/mirego/elixir-security-advisories)
which is it self licensed with- `BSD-3-Clause license`
- `CC-BY 4.0 open source license`.
- See their
[#license section](https://github.com/mirego/elixir-security-advisories?tab=readme-ov-file#license)- Code original to this repo is Licensed under `MIT`