#自动化 #peace #参数 #框架 #配置文件 #命令 #

peace_code_gen

Peace自动化框架的代码生成宏

7个版本

0.0.13 2024年2月3日
0.0.12 2023年12月29日
0.0.11 2023年6月27日
0.0.9 2023年4月12日
0.0.8 2023年3月25日

#33 in #peace

Download history 41/week @ 2024-03-12 26/week @ 2024-03-19 22/week @ 2024-03-26 69/week @ 2024-04-02 17/week @ 2024-04-09 21/week @ 2024-04-16 31/week @ 2024-04-23 21/week @ 2024-04-30 26/week @ 2024-05-07 12/week @ 2024-05-14 44/week @ 2024-05-21 38/week @ 2024-05-28 31/week @ 2024-06-04 30/week @ 2024-06-11 39/week @ 2024-06-18 24/week @ 2024-06-25

每月下载132
用于16个crate(通过peace_cmd

MIT/Apache

215KB
3.5K SLoC

🕊️ peace – 零压力自动化

Crates.io docs.rs CI Coverage Status

peace 是一个构建同理心软件自动化框架。

查看

  • peace.mk 了解项目愿景。
  • 背景 了解创建此框架的动机。
  • 运营UX 了解在 peace 的设计和开发过程中考虑的维度。

指导原则

  • 使用愉快。
  • 符合人体工程学的API和指导,帮助用户做出正确的操作。
  • 输出结果易于理解。

功能

符号 意义
🟢 工作良好
🟡 部分支持
计划中
🔵 设计兼容
🟣 工作,"有趣的想法"
  • 🟢 幂等:多次调用产生相同的目标结果。
  • 🟢 简洁:每个对象的创建都与其清理方式配对。
  • 🟢 易于理解:进度以易于理解的详细程度显示。
  • 🔵 易于理解:错误报告与 miette 兼容。
  • 🟡 可中断:执行可以中断。
  • 🟢 可恢复:自动化从中断的地方恢复。
  • 🟢 可序列化:状态和差异以YAML格式序列化。
  • 🟢 高效:任务通过 fn_graph 并发执行。
  • 🟢 命名空间:配置文件目录将环境彼此隔离。
  • 🟢 类型安全:项和参数在代码中定义,而不是在配置中。

路线图

  • 🟢 定义要管理的项目。
  • 🟢 定义项目之间的依赖关系。
  • 🟢 定义“应用”逻辑。
  • 🟢 定义“清理”逻辑。
  • 🟢 发现当前和目标状态。
  • 🟢 定义状态之间的差异计算。
  • 🟢 在多个命令之间存储和调用参数。
  • 🟢 在多个配置文件之间比较状态。
  • 🟢 类型安全引用参数 -- 将自动化过程中生成的值作为后续项目的参数使用。
  • 🟡 功能门控增量功能。
  • 🟡 对常见项目的即用支持。
  • 🟡 干运行。
  • 🔴 WASM 支持。
  • ⚫ 通过 tokio-graceful-shutdown 进行取消安全的中断。
  • ⚫ 设计安全的支持:加密值存储,按执行/基于时间的代理解密。
  • ⚫ 编写软件生命周期管理工具的教程。
  • ⚫ 内置应用程序执行方法 -- CLI,网络服务。
  • ⚫ 基于 peace 的配置工作流二进制文件。
  • ⚫ 基于网络的交互式图形用户界面。
  • ⚫ 代理模式在服务器上运行 peace(Web API 调用)。

进一步的想法

  • 备份当前状态。
  • 恢复先前的状态。
  • 遥测/指标日志分析。

示例

示例使用 --package 运行,而不是 --example,因为每个示例都组织为其自己的crate。

cargo run --package $example_name --all-features

# e.g.
cargo build --package download --all-features
cargo run -q --package download --all-features -- init https://ifconfig.me ip.json

for cmd in status goal diff ensure ensure diff clean clean diff
do
    printf "=== ${cmd} ===\n"
    cargo run -q --package download --all-features -- --format text $cmd
    printf '\n'
done

# Look at metadata that Peace has saved
find .peace -type f -exec bash -c 'echo \# {}; cat {}; echo' \;

# Clean up the metadata directory
rm -rf .peace

WASM

可以使用 wasm-packdownload 示例构建为 WebAssembly 应用程序。

cd examples/download
wasm-pack build --target web

examples/download 目录中,启动一个 HTTP 服务器,然后打开 https://127.0.0.1:8000/

python3 -m http.server 8000 # or
simple-http-server --nocache --port 8000 -i

许可证

在以下任一许可证下发布:

供您选择。

贡献

除非您明确声明,否则您提交给工作的任何有意贡献,根据 Apache-2.0 许可证定义,应按上述方式双许可,没有任何附加条款或条件。

依赖项

~275–730KB
~17K SLoC