-
Notifications
You must be signed in to change notification settings - Fork 0
Plugins Guide
Slctl 有完整的 plugin 系統以延伸開發更多的功能, 包含許多優點:
Slctl 建議將 Plugin 設計為 Stateless, 也就本身無狀態的. 若需要儲存資料或狀態, 則必須考慮到日後升級 Plugin 時的資料轉移.
Plugin 可以透過指令 $ slctl plugin install SOURCE
來安裝, SOURCE 支援以下幾種:
Plugin 可以是本機上的任何目錄, 透過給予絕對或相對路徑來安裝
$ slctl plugin install /path/to/plugin-dir/
Plugin 也可以是來自於網路上或在本機中壓縮檔, 透過給予網址或路徑來安裝, 格式支援: .zip, .tar, .tar.gz, .tgz, .tar.bz2, .tbz2, .tar.xz, .txz, .tar.lz4, .tlz4, .tar.sz, .tsz, .rar, .bz2, .gz, .lz4, .sz, .xz
$ slctl plugin install /path/to/plugin-archive.zip
$ slctl plugin install http://host/plugin-archive.zip
Plugin 也可以是一個 GitHub repo, 傳入 github.com/OWNER/REPO
, slctl 會自動收尋最新一版的 release, 並從該 release 的所有下載檔中, 嘗試找出含有當前 OS 名稱的壓縮檔來安裝, 當找不到時會改下載第一個壓縮檔來安裝
$ slctl plugin install github.com/softleader/slctl-whereis
傳入 --tag
可以指定 release 版本
$ slctl plugin install github.com/softleader/slctl-whereis --tag 1.0.0
傳入 --tag
及 --asset
可以指定 release 版本以及要下載第幾個 asset 檔案 (從 0 開始) 來安裝
$ slctl plugin install github.com/softleader/slctl-whereis --tag 1.0.0 --asset 2
傳入 --force
在 install 時自動刪除已存在的 plugin
$ slctl plugin install github.com/softleader/slctl-whereis -f
Plugin 的根目錄下必須有一份 metadata.yaml
檔案來描述該 Plugin 的相關資訊, 包含:
name: foo
version: 0.1.0
usage: foo
description: The foo plugin
exec:
command: $SL_BIN
platform:
- os: darwin
arch: ""
command: $SL_BIN
- os: windows
arch: ""
command: $SL_BIN
hook:
command: echo hello foo
platform: []
ignoreGlobalFlags: false
github:
scopes: []
-
name - 從 slctl 執行的 subcommand, 如
foo
即代表將使用slctl foo
來執行, name 不可跟 slctl 第一層 command 或任何其他 plugin name 重複, name 也必須符正規式驗證:^[\w\d_-]+$
- version - 必須是符合 Semantic Versioning 2 規格的版本號
-
usage - 顯示在
slctl --help
的說明, 應以一句話簡短說明 -
description - 顯示在
slctl plugin list
的說明 - exec - 執行 plugin 時的指令, 如果有定義 platform 且符合 runtime 環境, 會優先選擇 platform 的 command 執行
- hook - 安裝好 plugin 後要執行的指令, 通常用來配置環境使用, 如果有定義 platform 且符合 runtime 環境, 會優先選擇 platform 的 command 執行
- ignoreGlobalFlags - 執行 plugin 時忽略 Global Flags
-
github.scopes - plugin 需要的 token 權限, slctl 會自動的補齊不足的權限, 執行
slctl init scopes
可查詢 slctl 預設要求的權限清單
Os 及 Arch 可參考: Golang environment variables
Plugin 本身沒有撰寫的語言限制, slctl 推薦並預設產生 golang 的範本, 選擇不同撰寫語言時, 需注意該語言本身的限制: 如執行 java plugin 的 runtime 必須有 JRE
slctl 已內含了幾種語言的範本, 使用 --lang
來指定產生語言範本
$ slctl plugin create foo --lang java
使用 plugin create langs
列出所有內含的範本語言
$ slctl plugin create langs
golang
java
nodejs
...
Slctl 在執行 plugin 時, 會將以下環境變數設置到系統變數中, 讓不同語言的 plugin 都可以從中取出:
-
golang -
os.LookupEnv("SL_TOKEN")
-
java -
System.getenv("SL_TOKEN")
-
nodejs -
process.env.SL_TOKEN
這些變數有個共同點都是 SL_ 開頭, 可以透過 plugin evns
查看變數清單:
$ slctl plugin envs
SL_PLUGIN
SL_HOME
SL_VERBOSE
SL_OFFLINE
SL_TOKEN
SL_PLUGIN_NAME
SL_PLUGIN_DIR
SL_BIN
...
執行 plugin 時, global flags 會被 slctl 擷取掉而 不會 傳給 plugin, 可以透過 plugin flags
查看 flags 清單:
$ slctl plugin flags
--home
--offline
--verbose
-v
...
若將 metadata.yaml
中的 ignoreGlobalFlags
設為 true, 則 slctl 不會做任何的截取而是將 flags 完整的傳入 plugin 中