#shell #native-bindings #declarative #scripting #bash #ansible #rash

bin+lib rash_core

使用 Rust 本地绑定的声明式 shell 脚本

30 个稳定版本

2.3.1 2024年8月15日
1.10.5 2024年7月4日
1.10.1 2024年2月23日
1.10.0 2023年9月12日
0.1.0 2020年5月17日

#73 in Unix API

Download history 4/week @ 2024-05-20 2/week @ 2024-06-03 5/week @ 2024-06-10 112/week @ 2024-06-17 161/week @ 2024-06-24 206/week @ 2024-07-01 73/week @ 2024-07-08 300/week @ 2024-08-05 554/week @ 2024-08-12

854 个月下载量
mdbook_rash 中使用

自定义许可 和可能 LGPL-3.0

295KB
8K SLoC

rash

Build status Rash Docker image Documentation crates.io concept-map Rash license Rash Aur package

Ansible 启发,使用 Rust 本地绑定的声明式 shell 脚本

入门 & 文档

有关安装和用法,请参阅我们的 文档

为什么选择 Rash

以声明式风格管理您的脚本。

如果您

  • 认为长 bash 脚本难以维护
  • 喜欢 Ansible 语法来设置环境

或者将其用于您的本地脚本!

那么请继续阅读。

这就是 Rash!

声明式与命令式

命令式:entrypoint.sh

#!/bin/bash
set -e

REQUIRED_PARAMS="
VAULT_URL
VAULT_ROLE_ID
VAULT_SECRET_ID
VAULT_SECRET_PATH
"

for required in $REQUIRED_PARAMS ; do
  [[ -z "${!required}" ]] && echo "$required IS NOT DEFINED" && exit 1
done

echo "[$0] Logging into Vault..."
VAULT_TOKEN=$(curl -s $VAULT_URL/v1/auth/approle/login \
--data '{"role_id": "'$VAULT_ROLE_ID'","secret_id": "'$VAULT_SECRET_ID'"}' \
| jq -r .auth.client_token)

echo "[$0] Getting Samuel API key from Vault..."
export APP1_API_KEY=$(curl -s -H "X-Vault-Token: $VAULT_TOKEN" \
$VAULT_URL/v1/$VAULT_SECRET_PATH | jq -r .data.api_key)


exec "$@"

声明式:entrypoint.rh

#!/bin/rash

- name: Verify input parameters
  assert:
    that:
      - env.VAULT_URL is defined
      - env.VAULT_ROLE_ID is defined
      - env.VAULT_SECRET_ID is defined
      - env.VAULT_SECRET_PATH is defined

- name: launch docker CMD
  command:
    cmd: { { rash.argv } }
    transfer_pid: yes
  env:
    APP1_API_KEY: "{{ lookup('vault', env.VAULT_SECRET_PATH ) }}"

Docopts

docopt 实现

  • 轻松为命令行应用程序定义接口。
  • 从文档自动生成解析器。

示例

#!/usr/bin/env -S rash --
#
# Copy files from source to dest dir
#
# Usage:
#   copy.rh [options] <source>... <dest>
#   copy.rh
#
# Options:
#   -h --help    show this help message and exit
#   --mode MODE  dest file permissions [default: 0644]

- copy:
    src: "{{ item }}"
    dest: "{{ dest }}/{{ item | split('/') | last }}"
    mode: "{{ options.mode }}"
  loop: "{{ source | default ([]) }}"

轻量级

您只需要 Linux 内核就可以运行 Rash!

您可以在运行 Linux 的您最喜欢的 IoT 芯片或从头开始的容器中使用它!

状态

具有少量模块的稳定 API。

依赖关系

~15–46MB
~759K SLoC