Ginue is the CLI tool to edit settings of kintone via kintone REST API.
kintone REST APIでkintoneアプリの設定情報を編集するためのCLI版ツールです。
グローバルにインストールする場合
$ npm install -g ginue
or
$ yarn global add ginue
プロジェクトごとにインストールする場合
$ npm install --save-dev ginue
or
$ yarn add --dev ginue
Gitライクな一連のコマンドを提供します。
- ginue pull : kintoneの設定情報を取得します。
- ginue push : kintoneの設定情報を送信します。
- ginue deploy : kintoneアプリの設定を運用環境へ反映します。
- ginue reset : kintoneアプリの設定の変更をキャンセルします。
- ginue erd :(実験的機能)kintoneアプリのルックアップ関係を解析してER図を作成します。
-v, --version Output version information
-h, --help Output usage information
-d, --domain=<DOMAIN> kintone domain name
-u, --user=<USER> kintone username
-p, --password=<PASSWORD> kintone password
-a, --app=<APP-ID> kintone app IDs
-g, --guest=<GUEST-SPACE-ID> kintone guest space ID
-b, --basic=<USER[:PASSWORD]> kintone Basic Authentication user and password
-A, --appName=<APP-NAME> Set target app name
-l, --location=<LOCATION> Location of settings file
-t, --fileType=<FILE-TYPE> Set file type 'json'(default) or 'js'
domain
user
password
app
オプションを省略した場合、標準入力を求められます。- アプリID(
app
オプション or 標準入力)はカンマ区切りで複数指定可能です。 - ゲストスペース内のアプリ情報を取得する場合は
guest
オプションが必須です。 - Basic認証を使用する場合は
basic
オプションが必須です。パスワードを省略した場合、標準入力を求められます。 location
オプションを指定すると、kintone設定情報ファイルの保存フォルダを指定できます。(省略時はカレントディレクトリ)fileType
オプションにjs
を指定すると、kintone設定情報ファイルを.json
ではなく.js
フォーマットで扱います。- コマンドライン引数のほか、後述する
.ginuerc
や.netrc
でもオプション指定が可能ですusername
,password
,basic
については環境変数でも設定可能です。(GINUE_USERNAME
,GINUE_PASSWORD
,GINUE_BASIC
)- 優先順位は
環境変数 < .netrc < .ginuerc < 引数
コマンドを実行するディレクトリに.ginuerc
という設定ファイルを作成すると、ginue
実行時に自動的に読み込まれてオプション指定を省略できます。プロジェクト単位で.ginuerc
を作成すると便利です。
- フォーマットはJSON/JS/YAMLの3種類に対応しています。
- .ginuerc.json
{ "location": "kintone-settings", "domain": "ginue.cybozu.com", "username": "Administrator", "password": "myKintonePassword", "app": [10, 11, 12], "guest": 5 }
- .ginuerc.js
module.exports = { location: 'kintone-settings', domain: 'ginue.cybozu.com', username: 'Administrator', password: 'myKintonePassword', app: [10, 11, 12], guest: 5, }
- .ginuerc.yml
location: kintone-settings domain: ginue.cybozu.com username: Administrator password: myKintonePassword app: - 10 - 11 - 12 guest: 5
env
プロパティを使用すると、異なる環境のアプリをグルーピングできます。- 各環境別にオブジェクトを作成し、プロパティは環境名として自由に設定します。(ex.
development
,production
) ginue pull
時には各環境ごとにディレクトリが作成され、配下にJSONファイルが保存されます。- デフォルトでは環境名=ディレクトリ名
- 各環境に
location
プロパティを指定すると、location
の値=ディレクトリ名 - トップレベルに
location
プロパティを指定すると、location
のディレクトリ配下に、各環境のサブディレクトリを作成
- 各環境別にオブジェクトを作成し、プロパティは環境名として自由に設定します。(ex.
app
プロパティにオブジェクトを指定すると、アプリIDではなくアプリ名のディレクトリにJSONが保存されます。- その場合、各種
ginue
コマンドの引数にappName
オプションを指定することで、特定のアプリのみを処理できます。
- その場合、各種
{
"location": "kintone-settings",
"env": {
"development": {
"domain": "ginue-dev.cybozu.com",
"username": "Administrator",
"password": "myKintonePassword",
"app": {
"user": 128,
"order": 129,
"bill": 130
},
"basic": "Administrator:myBasicAuthPassword"
},
"production": {
"location": "__PRODUCTION__",
"domain": "ginue.cybozu.com",
"username": "Administrator",
"password": "myKintonePassword",
"app": {
"user": 10,
"order": 11,
"bill": 12
},
"guest": 5
}
}
}
- カレントにアプリID名のディレクトリが作成され、その中に全JSONファイルが保存されます。
- APIのレスポンス上は全JSONに
revision
要素が含まれますが、保存される各JSONファイルではrevision
要素が省略され、代わりにrevision.json
というファイルを単独で作成します。(更新時のdiffがシンプルになるため) preview
オプションを指定すると<env>-preview
ディレクトリが作成され、kintoneテスト環境のJSONファイルを別途保存します。運用環境へ反映する前の状態を確認したい場合は有効にしてください。.ginuerc
に"preview": true
を設定すると常時有効になります。
実行例
$ ginue pull -d ginue.cybozu.com -g 5 -a 10,11,12 -u Administrator
$ ginue pull -d ginue.cybozu.com -b Administrator -a 10,11,12 -u Administrator -l kintone-settings
$ ginue pull -A user --preview
ginue pull
で保存済みのJSONファイルを、kintoneにアップロードします。- 環境名を単独で指定すれば同じ環境にアップロードします。
- 環境名をコロン区切りで
<from>:<to>
のように書くと、ローカルの<from>
ディレクトリ配下に保存されたJSONファイルを<to>
環境にアップロードします。 - 実行後はkintoneのテスト環境が変更された状態になるので、kintoneの設定画面で「アプリを更新」「変更を中止」ボタンをクリックするか、
ginue deploy
ginue reset
コマンドを使用してください。
実行例
$ ginue push development
$ ginue push development:production
$ ginue push development:production -A user
- アプリの設定の運用環境への反映を行います。
実行例
$ ginue deploy development
$ ginue deploy development -A user
- アプリの設定の変更をキャンセルします。
実行例
$ ginue reset development
$ ginue reset development -A user
⚠️ 実験的機能です。仕様は大きく変更される可能性があります。ginue pull
で保存済みのJSONファイルからkintoneアプリのルックアップ関係を解析して、ER図を作成します。- 各
env
ディレクトリの直下に、PlantUML形式のファイルerd.pu
を保存します。 - 画像ファイルは作成しないので、任意の方法でPlantUMLをレンダリングしてください。
実行例
$ ginue erd development