Crates.io | opx |
lib.rs | opx |
version | 0.0.6 |
source | src |
created_at | 2023-05-10 08:52:44.835321 |
updated_at | 2024-02-16 02:49:37.477873 |
description | Enhance 1password secret expansion with the opx CLI |
homepage | |
repository | https://github.com/Hacksore/opx |
max_upload_size | |
id | 861197 |
size | 26,087 |
This tool allows you to use the opx
binary to start an application with all .env
files passed to op run ...
.
cargo install opx
# start your app with secrets injected
opx
The command above would run this in the background:
op run --env-file=.env --env-file=apps/web/.env -- npm start
Working example of it doing the correct thing in a demo repo:
opx ✔ $ opx
[OPX] Forcing terminal colors with FORCE_COLOR=1
[ENV] .env
[ENV] apps/demo/.env
[ENV] apps/other-app/.env
[OPX] op run --env-file=/Users/hacksore/Code/opensource/demo-1pass-secrets/.env --env-file=/Users/hacksore/Code/opensource/demo-1pass-secrets/apps/demo/.env --env-file=/Users/hacksore/Code/opensource/demo-1pass-secrets/apps/other-app/.env -- npm start
> demo-1pass-secrets@0.0.0 start
> turbo run start
• Packages in scope: demo, eslint-config-custom, other-app, tsconfig
• Running start in 4 packages
• Remote caching disabled
demo:start: cache bypass, force executing 545833253ebd38cc
other-app:start: cache bypass, force executing 2ed51133d14970ce
other-app:start:
other-app:start: > other-app@1.0.0 start
other-app:start: > node main.js
other-app:start:
demo:start:
demo:start: > demo@1.0.0 start
demo:start: > node main.js
demo:start:
demo:start: Hello this is a sample app that uses a secret from 1password cli
other-app:start: Hello this is a sample app that uses a secret from 1password cli
demo:start: Secret is: <concealed by 1Password>
other-app:start: Secret is: <concealed by 1Password>
Tasks: 2 successful, 2 total
Cached: 0 cached, 2 total
Time: 216ms
How i link it
# dev
cargo watch -x "build --release"
# link it
export PATH="$HOME/code/opensource/opx/target/release:$PATH"