Thing Specification Language(TSL)とは、エンド側とサーバー間の設定のために提供される記述ファイルであり、エンド側でサポートされている設定項目と設定項目に応じた制約を記述するために使用されます。
概要
SenseLinkプラットフォームはTSLを定義するためにデバイスをサポートします。デバイスの実際の設定(プロパティ、ステータス)から成るデータモデルによって、クラウドを介したデバイス管理が円滑化されます。
パラメーターの命名、パラメーターの型、制御型、製品の各機能のチェックルールなど
デバイスの周辺機器の状態です。プラットフォームは書き込みを行わずに読み込みだけを行い、ドアマグネットの状態、サーマルイメージングシステムの接続状態、Bluetoothロックバッテリーなど、最新の状態のみを保持します
TSL
TSLとは、デバイスが最初にSenseLinkにアクセスする際にデバイスからレポートされるJSON形式のファイルであり、バックエンドに保存されます。Webでデバイスの詳細を表示すると、デバイスに対応するTSLとTSLの値がWebで動的に読み込まれます。これにより、バックエンドのサービスを更新することなく、クラウド上のリモート設定機能とデバイスのローカル機能の一貫性を確保することができます。
TSLの使用フロー
必要な言語パッケージを作成します。形式については、TSLの国際化 を参照してください。
開発が完了したら、デバイス上でプロパティやイベントをレポートし、プロパティを設定してクラウド上のサービスを呼び出してインターフェースの呼び出しステップ更新プロセスを表示することができます。
デバイスからレポートされた属性、イベント、および完了済サービスの呼び出しデータは、データ照合の通過後、SenseLinkコンソール内の対応するデバイスのデバイス詳細ページのデバイス設定タブに表示されます。
TSLの構造
TSLはトップレベルに「engineVersion」「modelVersion」「deviceType」を持つjsonファイルです。「properties」「status」は前述したパラメータの設定項目です。
{
"engineVersion": "0.0.1",//エンジンのバージョン
"modelVersion": "0.0.1", //モデルのバージョン
"deviceType": "sps", // デバイスのタイプ
"properties": [/*... */], // 機能の設定項目
"status": [/*...*/]// デバイスの周辺機器の状態
}
プロパティ
プロパティは、それぞれが複数の設定項目を持ついくつかのモジュールで構成されています。fields
要素とも呼ばれる各設定項目はそれぞれの設定項目を説明し、機能を定義します。
{
"properties": [{
"name": "group-name",
"fields": [{ // 設定項目集
"key": { // 設定項目の名前の記述
"name": "product_customer", // 名前
"desc": "vendor-customer" // 名前を記述するために使用され、実用的な目的はありません
},
"value": {} // 設定項目の任意の値の記述
]
}]
}
フィールドはキーと値で構成されています。キーは設定項目の名前を示し、値は設定項目の任意の値、スタイル、ステータスを含む定義です。一部のフィールドの説明は以下の通りです。その他の設定については、[TSL data structure](#TSLdata structure)をご参照ください。
type:必須、設定項目の値の型(int、float、string、boolean、その他)を示しています
ranges:任意、typeがintやfloatなどの場合に、min
:最小値、max
:最大値、default
:デフォルト値を含む値の区間を示します。
ui:任意、デフォルトはtext、Web/デバイスの入力制御スタイルを示すために使用されます。
ui
に設定可能な値の一覧:
options:任意で、Valueが枯渇し得る場合(wiegand32、wiegand34、およびwiegand2602など)、一般的にui
のselect
で使用されます。
ステータス
デバイスの周辺機器の状態を意味します。プラットフォームは書き込みは行わずに読み込みのみを行い、最新の状態のみを保持します。JSONファイルには、名前に対応する name
、enable
、および options
、表示の有無、および任意の値が含まれます。詳細については、TSLのデータ構造をご参照ください。
TSLの国際化
デバイス/Web上のシステム内の全てのTSLのデバイスタイプ、属性、およびステータスの表示名を定義し、言語ごとに別々に保存します。TSLの国際化は、TSLの値と名前をクラウドコンソール向けに分かりやすく説明し、操作の難易度を下げることを目的としています。各言語パッケージはJSON形式のファイルで構成され、対応するキーはTSLの対応する部分の翻訳です。
デバイスタイプのセット。例:"deviceType":"spse"
TSLのカテゴリー化名、プロパティ内の名前の翻訳。
例:properties[{"name":"general",...}]
設定項目名、プロパティ内のフィールドの全ての「name」フィールド
設定に対応する値、ステータス内の値を含むTSL内の全ての値
デバイスの周辺機器の状態の表示名、ステータス内の「name」フィールド
共通の翻訳。
例:"modelVersion":"Device model version"
データ構造の詳細については、言語パッケージのデータ構造をご参照ください
付録
更新プロセス
言語パッケージのデータ構造
言語パッケージのデータ構造例は、以下の通りです。
{
"versionInfo": {
"version": "0.0.1",
"log": "",
"updated": "2020-04-21 12:00:00"
},
"common": {
"modelVersion": "Device model version"
},
"deviceTypes": {
"sps": "SensePass"
},
"groups": {
"general": "General Settings"
},
"fields": {
"identify_mode": "identify_mode"
},
"values": {
"enable": "Enable",
"disable": "Disable"
},
"status": {
"door_status": "Magnetism Status"
}
}
TSLのデータ構造
TSL の JSON フィールドの構造例は、以下の通りです:
{
"engineVersion": "0.0.1",//エンジンのバージョン
"modelVersion": "0.0.1", //モデルのバージョン
"deviceType": "sps",
"properties": [{
"name": "features",
"fields": [{
"key": {
"name": "identify_mode",
"desc": "Enabled State"
},
"value": {
"required": true, // 必須であるか否か。設定されていない場合、デフォルトは任意です。
"type": "int", //データのタイプ、numeric、boolean、または string を設定する必要があります。
"editable": true, // 編集可能であるか否か。設定されていない場合、デフォルトは編集不可です。
/*
** UI のコンポーネントは次のタイプから設定する必要があります
*** ナンバーピッカー:number
*** ドロップダウンボックス:select
*** 複数選択ボックス:checkbox
*** ラジオボタン:radio
*** タイムピッカー:date
*** 1行のテキスト入力:text
*** 複数行のテキスト入力:textarea
*** 画像のアップロードと表示:image
*** デフォルトは text です。
*/
"ui": "select",
"ranges": [{
"min": 1,
"max": 2,
"enable": "{open_way}==2", //js expression string または boolean 値です。設定されていない場合はデフォルトで有効です。中括弧内のフィールドは差し替えられる値を示しています(open_wayの値が2の場合、式は"2==2"と解析されます)。
"default": 1.5
},{
"min": 3,
"max": 4,
"enable": "{open_way}==3",//js expression stringまたはBoolean値です。設定されていない場合はデフォルトで有効です。
"default": 3.5
}],
"step": 0.5,//値のみに対するステップのサイズです。
"precision": 1,//精密さ。小数位の正確な数、非負整数を示し、数値に対してのみ有効であり、任意です。
"mult": true, //複数選択か否か、任意。設定されていない場合、引渡されるパラメーターはデフォルトで単一値です。複数値はドロップダウンと複数選択ボックスに対してのみ有効です。
"enable": "{open_way}==1", // js expression stringまたはboolean値であり、任意です。リンケージ制御によるフィールドの表示・非表示を示します。enableプロパティが設定されていない場合はデフォルトで有効です。
"size": 20, // 文字列の長さ、任意です。stringとimage base64に対してのみ有効です。
"timeFormat": "yyyy-MM-dd HH:mm:ss", //uiがdateの場合、日付形式を設定する必要があります。hhは12時間を意味し、HHは24時間を意味します。
"options": [{
"value": 0,
"name": "off",
"enable": "{open_way}==2", // js expression stringまたはboolean値です。trueを返し、これは選択された値が候補項目で使用可能であることを意味します。enableプロパティが設定されていない場合はデフォルトで有効です。
}, {
"value": 1,
"name": "on", // js expression stringまたはboolean値です。trueを返し、これは選択された値が候補項目で使用可能であることを意味します。enableプロパティが設定されていない場合はデフォルトで有効です。
"enable": "{open_way}==3"
}],
//watch: ステータスのlisten状態であることを意味します。
/*
** 以下の例は、現在のフィールドの値がuse_modeに関連していることを意味します。
** use_modeが変更されると、現在のフィールドの値は式が実行された後の値になります "{use_mode}==2?1.5:{use_mode}==1?2:{recognition_distance}"
*/
"watch":{
"use_mode": "{use_mode}==2?1.5:{use_mode}==1?2:{recognition_distance}"
}
},
}]
}],
"status": [{
"name": "wifi",
"enable": true, // js expression stringまたはboolean値です。このフィールドの表示条件を制御します。enableプロパティが設定されていない場合はデフォルトで有効です。
"options": [{
"value": 0,
"name": "off",
"enable": "{open_way}==2", // js expression stringまたはboolean値です。trueを返し、これは選択された値が候補項目で使用可能であることを意味します。enableプロパティが設定されていない場合はデフォルトで有効です。
},{
"value": 1,
"name": "on",
"enable": "{open_way}==1", // js expression stringまたはboolean値です。trueを返し、これは選択された値が候補項目で使用可能であることを意味します。enableプロパティが設定されていない場合はデフォルトで有効です。
}],
}]
}