- DB API: DB types and enums.
This module provides mappings between database columns and JS keys.
- JS API: low level database access
This module provides generic DB functions for performing SQL queries.
- DB API: DB mappings between columns and JS object keys.
This module provides mappings between database columns and JS keys.
- DB API: user configuration queries against the database.
This module provides queries for user configuration.
- DB API: generic queries against the database.
This module provides generic queries.
- DB API: package-based queries.
This module provides queries related to imports and exports of files.
- DB API: package-based queries.
This module provides queries related to packages.
- DB API: session related queries.
This module provides session related queries.
- DB API: zcl database access
This module provides queries for ZCL static queries.
- JS API: generator logic
- Templating API: C formatting helpers
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- Templating API: user-data specific helpers
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- Templating API: toplevel utility helpers
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- Templating API: static zcl helpers
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- Templating API: Overridable functions.
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- JS API: generator logic
- JS API: generator logic
- REST API: admin functions
This module provides the REST API to the admin functions.
- REST API: generation functions
This module provides the REST API to the generation.
- External IDE interface.
This module provides the interface to an extenal IDE: Simplicity Studio.
- REST API: static zcl functions
This module provides the REST API to the static zcl queries.
- REST API: generation functions
This module provides the REST API to the generation.
- REST API: user data
This module provides the REST API to the user specific data.
- JS API: http server
This module provides the HTTP server functionality.
- JS API: random utilities
- replyId
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- queryZcl
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- templateUtil
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- queryZcl
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- queryPackage
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- env
This file is used specifically and only for development. It installs
electron-debug
&vue-devtools
. There shouldn't be any need to modify this file, but it can be used to extend your development environment.- dbApi
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- axios
This module provides the API to Studio's Jetty server.
- yargs
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- path
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- queryZcl
This module provides the APIs for validating inputs to the database, and returning flags indicating if things were successful or not.
- env
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- fs
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- fs
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
- exportSessionKeyValues(db, sessionId) ⇒
Resolves to an array of objects that contain 'key' and 'value'
- exportEndpoints(db, sessionId) ⇒
Resolves to an array of endpoints.
- exportEndpointTypes(db, sessionId) ⇒
Resolves to an array of endpoint types.
- exportSessionPackages(db, sessionId)
Resolves with data for packages.
- exportDataIntoFile(db, sessionId, filePath) ⇒
Toplevel file that takes a given session ID and exports the data into the file
- createStateFromDatabase(db, sessionId) ⇒
Given a database and a session id, this method returns a promise that resolves with a state object that needs to be saved into a file.
- importSessionKeyValues(db, sessionId, keyValuePairs)
Resolves with a promise that imports session key values.
- readDataFromFile(filePath) ⇒
Reads the data from the file and resolves with the state object if all is good.
- writeStateToDatabase(db, state) ⇒
Given a state object, this method returns a promise that resolves with the succesfull writing into the database.
- importDataFromFile(db, filePath) ⇒
Writes the data from the file into a new session.
- doOpen(menuItem, browserWindow, event)
Perform a file->open operation.
- doSave(menuItem, browserWindow, event)
Perform a save, defering to save as if file is not yet selected.
- doSaveAs(menuItem, browserWindow, event)
Perform save as.
- generateInDir(browserWindow)
This function gets the directory where user wants the output and calls generateCode function which generates the code in the user selected output.
- setHandlebarTemplateDirectory(browserWindow)
This function gets the directory where user wants the output and calls generateCode function which generates the code in the user selected output.
- fileSave(db, browserWindow, filePath) ⇒
perform the save.
- fileOpen(db, filePaths)
Perform the do open action, possibly reading in multiple files.
- readAndProcessFile(db, filePath)
Process a single file, parsing it in as JSON and then possibly opening a new window if all is good.
- initMenu(port)
Initialize a menu.
- createOrShowWindow(port)
Call this function to create a new or show an existing preference window.
- startNormal(uiEnabled, showUrl, uiMode)
Start up application in a normal mode.
- startSelfCheck()
Start up application in self-check mode.
- startGeneration(output, genTemplateJsonFile, zclProperties, [zapFile]) ⇒
Performs headless regeneration for given parameters.
- clearDatabaseFile(path)
Move database file out of the way into the backup location.
- windowCreate(port, [filePath], [sessionId]) ⇒
Create a window, possibly with a given file path and with a desire to attach to a given sessionId
Win id will be passed on in the URL, and if sessionId is present, so will it.
- processCommandLineArguments(argv) ⇒
Process the command line arguments and resets the state in this file to the specified values.
- int8ToHex(value) ⇒
Takes an int8 value and turns it into a hex.
- int16ToHex(value) ⇒
Takes an int16 value and turns it into a hex.
- int32ToHex(value) ⇒
Takes an int8 value and turns it into a hex.
- stringToHex(value) ⇒
Converts a string to the hex value.
- hexToCBytes(value) ⇒
Takes the raw hex string, such as
abcd
and converts it into a C constant array, such as0xAB, 0xCD
.- bitOffset(binary)
Getting a binary string ("0001101010010") it returns the number of zero bits at the end.
- hexToBinary(hex)
Convert a hex number to a binary. Hex has to be in a format as obtained by intToHex methods above: no '0x' prefix and upper-case letters, as in "12AB".
- collectDataFromLibraryXml(ctx) ⇒
Promises to read the properties file, extract all the actual xml files, and resolve with the array of files.
- parseZclFiles(db, ctx) ⇒
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
- normalizeHexValue(value) ⇒
The Dotdot ZCL XML doesn't use the 0x prefix, but it's a nice thing to have and Silabs xml does use this so this helper function normalizes the use of hex
TODO: Is this the right thing to do?
- getNumBytesFromShortName(value) ⇒
The Dotdot ZCL XML doesn't have a length but it is embedded in the short name, we can scrape the value to get the size
TODO: Is this the right thing to do?
- prepareAttributes(attributes, side) ⇒
Prepare XML attributes for entry into the DB
- prepareCommands(commands, side) ⇒
Prepare XML commands for entry into the DB
- prepareCluster(cluster, isExtension, types) ⇒
Prepare XML cluster for insertion into the database. This method can also prepare clusterExtensions.
- prepareAtomic(type) ⇒
Parses xml type into the atomic object for insertion into the DB
- prepareBitmap(type, fromAttribute) ⇒
Parses xml type into the bitmap object for insertion into the DB
- prepareEnum(type) ⇒
Parses xml type into the enum object for insertion into the DB
- prepareStruct(type) ⇒
Parses xml type into the struct object for insertion into the DB
- prepareTypes(zclTypes, types)
Parses xml types into the types object for insertion into the DB
- prepareAttributeType(attribute, types, cluster)
Parses xml types into the types object for insertion into the DB
- prepareDeviceType(deviceType) ⇒
Preparation step for the device types.
- loadZclData(db, ctx) ⇒
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
- loadDotdotZcl(db, ctx) ⇒
Toplevel function that loads the xml library file and orchestrates the promise chain.
- readMetadataFile(ctx) ⇒
Reads the properties file into ctx.data and also calculates crc into ctx.crc
- recordToplevelPackage(ctx)
Records the toplevel package information and puts ctx.packageId into the context.
- recordVersion(db, ctx)
Records the version into the database.
- loadZcl(db, metadataFile) ⇒
Toplevel function that loads the zcl file and passes it off to the correct zcl loader.
- qualifyZclFile(db, info, parentPackageId) ⇒
Promises to qualify whether zcl file needs to be reloaded. If yes, the it will resolve with {filePath, data, packageId} If not, then it will resolve with {error}
- processZclPostLoading(db) ⇒
Promises to perform a post loading step.
- readZclFile(file) ⇒
Promises to read a file and resolve with the content
- parseZclFile(argument) ⇒
Promises to parse the ZCL file, expecting object of { filePath, data, packageId, msg }
- collectDataFromJsonFile(ctx) ⇒
Promises to read the JSON file and resolve all the data.
- collectDataFromPropertiesFile(ctx) ⇒
Promises to read the properties file, extract all the actual xml files, and resolve with the array of files.
- prepareBitmap(bm) ⇒
Prepare bitmap for database insertion.
- processBitmaps(db, filePath, packageId, data) ⇒
Processes bitmaps for DB insertion.
- prepareAtomic(a)
Prepare atomic to db insertion.
- processAtomics(db, filePath, packageId, data) ⇒
Processes atomic types for DB insertion.
- prepareClusterGlobalAttribute(cluster) ⇒
Prepares global attribute data.
- prepareCluster(cluster) ⇒
Prepare XML cluster for insertion into the database. This method can also prepare clusterExtensions.
- processClusters(db, filePath, packageId, data) ⇒
Process clusters for insertion into the database.
- processClusterGlobalAttributes(db, filePath, packageId, data) ⇒
Processes global attributes for insertion into the database.
- processClusterExtensions(db, filePath, packageId, data) ⇒
Cluster Extension contains attributes and commands in a same way as regular cluster, and it has an attribute code="0xXYZ" where code is a cluster code.
- processGlobals(db, filePath, packageId, data) ⇒
Processes the globals in the XML files. The
global
tag contains attributes and commands in a same way as cluster or clusterExtension- prepareDomain(domain) ⇒
Convert domain from XMl to domain for DB.
- processDomains(db, filePath, packageId, data) ⇒
Process domains for insertion.
- prepareStruct(struct) ⇒
Prepares structs for the insertion into the database.
- processStructs(db, filePath, packageId, data) ⇒
Processes structs.
- prepareEnum(en) ⇒
Prepares an enum for insertion into the database.
- processEnums(db, filePath, packageId, data) ⇒
Processes the enums.
- prepareDeviceType(deviceType) ⇒
Preparation step for the device types.
- processDeviceTypes(db, filePath, packageId, data) ⇒
Process all device types.
- processParsedZclData(db, argument) ⇒
After XML parser is done with the barebones parsing, this function branches the individual toplevel tags.
- parseZclFiles(db, ctx) ⇒
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
- loadSilabsZcl(db, ctx) ⇒
Toplevel function that loads the properties file and orchestrates the promise chain.
This module provides mappings between database columns and JS keys.
This module provides generic DB functions for performing SQL queries.
- [JS API: low level database access](#moduleJS API low level database access)
- [~dbBeginTransaction(db)](#moduleJS API low level database access..dbBeginTransaction) ⇒
- [~dbCommit(db)](#moduleJS API low level database access..dbCommit) ⇒
- [~dbRemove(db, query, args)](#moduleJS API low level database access..dbRemove) ⇒
- [~dbUpdate(db, query, args)](#moduleJS API low level database access..dbUpdate) ⇒
- [~dbInsert(db, query, args)](#moduleJS API low level database access..dbInsert) ⇒
- [~dbAll(db, query, args)](#moduleJS API low level database access..dbAll) ⇒
- [~dbGet(db, query, args)](#moduleJS API low level database access..dbGet) ⇒
- [~dbMultiSelect(db, sql, arrayOfArrays)](#moduleJS API low level database access..dbMultiSelect)
- [~dbMultiInsert(db, sql, arrayOfArrays)](#moduleJS API low level database access..dbMultiInsert) ⇒
- [~closeDatabase(database)](#moduleJS API low level database access..closeDatabase) ⇒
- [~initRamDatabase()](#moduleJS API low level database access..initRamDatabase) ⇒
- [~initDatabase(sqlitePath)](#moduleJS API low level database access..initDatabase) ⇒
- [~insertOrReplaceSetting(db, version)](#moduleJS API low level database access..insertOrReplaceSetting) ⇒
- [~loadSchema(db, schemaPath, appVersion)](#moduleJS API low level database access..loadSchema) ⇒
- [~initDatabaseAndLoadSchema(sqliteFile, schemaFile, zapVersion)](#moduleJS API low level database access..initDatabaseAndLoadSchema) ⇒
Returns a promise to begin a transaction
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves without an argument and rejects with an error from BEGIN TRANSACTION query.
Param | Type |
---|---|
db | * |
Returns a promise to execute a commit.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves without an argument or rejects with an error from COMMIT query.
Param | Type |
---|---|
db | * |
Returns a promise to execute a DELETE FROM query.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolve with the number of delete rows, or rejects with an error from query.
Param | Type |
---|---|
db | * |
query | * |
args | * |
Returns a promise to execute an update query.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves without an argument, or rejects with an error from the query.
Param | Type |
---|---|
db | * |
query | * |
args | * |
Returns a promise to execute an insert query.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with the rowid from the inserted row, or rejects with an error from the query.
Param | Type |
---|---|
db | * |
query | * |
args | * |
Returns a promise to execute a query to perform a select that returns all rows that match a query.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with the rows that got retrieved from the database, or rejects with an error from the query.
Param | Type |
---|---|
db | * |
query | * |
args | * |
Returns a promise to execute a query to perform a select that returns first row that matches a query.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with a single row that got retrieved from the database, or rejects with an error from the query.
Param | Type |
---|---|
db | * |
query | * |
args | * |
Returns a promise to perform a prepared statement, using data from array for SQL parameters. It resolves with an array of rows, containing the data, or rejects with an error.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Param | Type |
---|---|
db | * |
sql | * |
arrayOfArrays | * |
Returns a promise to perfom a prepared statement, using data from array for SQL parameters. It resolves with an array of rowids, or rejects with an error.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with the array of rowids for the rows that got inserted, or rejects with an error from the query.
Param | Type |
---|---|
db | * |
sql | * |
arrayOfArrays | * |
Returns a promise that will resolve when the database in question is closed. Rejects with an error if closing fails.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves without an argument or rejects with error from the database closing.
Param | Type |
---|---|
database | * |
Create in-memory database.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: Promise that resolve with the Db.
Returns a promise to initialize a database.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with the database object that got created, or rejects with an error if something went wrong.
Param | Type |
---|---|
sqlitePath | * |
Returns a promise to insert or replace a setting into the database.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with a rowid of created setting row or rejects with error if something goes wrong.
Param | Type |
---|---|
db | * |
version | * |
Returns a promise to load schema into a blank database, and inserts a version to the settings table.j
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: A promise that resolves with the same db that got passed in, or rejects with an error.
Param | Type |
---|---|
db | * |
schemaPath | * |
appVersion | * |
Init database and load the schema.
Kind: inner method of [JS API: low level database access
](#moduleJS API low level database access)
Returns: Promise that resolves into the database object.
Param | Type |
---|---|
sqliteFile | * |
schemaFile | * |
zapVersion | * |
This module provides mappings between database columns and JS keys.
This module provides queries for user configuration.
This module provides generic queries.
This module provides queries related to imports and exports of files.
This module provides queries related to packages.
This module provides session related queries.
This module provides queries for ZCL static queries.
- [DB API: zcl database access](#moduleDB API zcl database access)
- [~selectAllEnums(db)](#moduleDB API zcl database access..selectAllEnums) ⇒
- [~selectAllBitmaps(db)](#moduleDB API zcl database access..selectAllBitmaps) ⇒
- [~selectAllDomains(db)](#moduleDB API zcl database access..selectAllDomains) ⇒
- [~selectAllStructs(db)](#moduleDB API zcl database access..selectAllStructs) ⇒
- [~selectAllClusters(db)](#moduleDB API zcl database access..selectAllClusters) ⇒
- [~selectAllDeviceTypes(db)](#moduleDB API zcl database access..selectAllDeviceTypes) ⇒
- [~selectCommandsByClusterId(db, clusterId)](#moduleDB API zcl database access..selectCommandsByClusterId) ⇒
- [~insertGlobals(db, packageId, data)](#moduleDB API zcl database access..insertGlobals) ⇒
- [~insertClusterExtensions(db, packageId, data)](#moduleDB API zcl database access..insertClusterExtensions) ⇒
- [~insertGlobalAttributeDefault(db, packagaId, data)](#moduleDB API zcl database access..insertGlobalAttributeDefault) ⇒
- [~insertClusters(db, packageId, data)](#moduleDB API zcl database access..insertClusters) ⇒
- [~insertDeviceTypes(db, packageId, data)](#moduleDB API zcl database access..insertDeviceTypes) ⇒
- [~insertDeviceTypeAttributes(db, dtClusterRefDataPairs)](#moduleDB API zcl database access..insertDeviceTypeAttributes)
- [~insertDeviceTypeCommands(db, dtClusterRefDataPairs)](#moduleDB API zcl database access..insertDeviceTypeCommands)
- [~insertDomains(db, packageId, data)](#moduleDB API zcl database access..insertDomains) ⇒
- [~insertStructs(db, packageId, data)](#moduleDB API zcl database access..insertStructs) ⇒
- [~insertEnums(db, packageId, data)](#moduleDB API zcl database access..insertEnums) ⇒
- [~insertAtomics(db, packageId, data)](#moduleDB API zcl database access..insertAtomics)
- [~selectAtomicType(db, packageId, typeName)](#moduleDB API zcl database access..selectAtomicType)
- [~selectAtomicByName(db, name, packageId)](#moduleDB API zcl database access..selectAtomicByName)
- [~selectAllAtomics(db, packageId)](#moduleDB API zcl database access..selectAllAtomics)
- [~getAtomicSizeFromType(db, packageId, type)](#moduleDB API zcl database access..getAtomicSizeFromType)
- [~insertBitmaps(db, packageId, data)](#moduleDB API zcl database access..insertBitmaps) ⇒
- [~exportClustersAndEndpointDetailsFromEndpointTypes(db, endpointTypeId)](#moduleDB API zcl database access..exportClustersAndEndpointDetailsFromEndpointTypes) ⇒
- [~exportCommandDetailsFromAllEndpointTypesAndClusters(db, endpointTypeId)](#moduleDB API zcl database access..exportCommandDetailsFromAllEndpointTypesAndClusters) ⇒
- [~selectCommandArgumentsCountByCommandId(db, commandId, [packageId])](#moduleDB API zcl database access..selectCommandArgumentsCountByCommandId) ⇒
- [~selectCommandArgumentsByCommandId(db, commandId, [packageId])](#moduleDB API zcl database access..selectCommandArgumentsByCommandId) ⇒
- [~determineType(db, packageId, type)](#moduleDB API zcl database access..determineType)
- [~exportAllClustersDetailsFromEndpointTypes(db, endpointTypeId)](#moduleDB API zcl database access..exportAllClustersDetailsFromEndpointTypes) ⇒
- [~exportCommandDetailsFromAllEndpointTypeCluster(db, endpointTypeId)](#moduleDB API zcl database access..exportCommandDetailsFromAllEndpointTypeCluster) ⇒
Retrieves all the enums in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of enums.
Param | Type |
---|---|
db | * |
Retrieves all the bitmaps in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of bitmaps.
Param | Type |
---|---|
db | * |
Retrieves all the domains in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of domains.
Param | Type |
---|---|
db | * |
Retrieves all the structs in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of structs.
Param | Type |
---|---|
db | * |
Retrieves all the clusters in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of clusters.
Param | Type |
---|---|
db | * |
Retrieves all the device types in the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the rows of device types.
Param | Type |
---|---|
db | * |
Retrieves commands for a given cluster Id. This method DOES NOT retrieve global commands, since those have a cluster_ref = null
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: promise of an array of command rows, which represent per-cluster commands, excluding global commands.
Param | Type |
---|---|
db | * |
clusterId | * |
Inserts globals into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise of globals insertion.
Param | Type |
---|---|
db | * |
packageId | * |
data | * |
Inserts cluster extensions into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise of cluster extension insertion.
Param | Type |
---|---|
db | * |
packageId | * |
data | * |
Inserts global attribute defaults into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise of data insertion.
Param | Type | Description |
---|---|---|
db | * |
|
packagaId | * |
|
data | * |
array of objects that contain: code, manufacturerCode and subarrays of globalAttribute[] which contain: side, code, value |
Inserts clusters into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise of cluster insertion.
Param | Type | Description |
---|---|---|
db | * |
|
packageId | * |
|
data | * |
an array of objects that must contain: code, name, description, define. It also contains commands: and attributes: |
Inserts device types into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise of an insertion of device types.
Param | Type | Description |
---|---|---|
db | * |
|
packageId | * |
|
data | * |
an array of objects that must contain: code, name, description |
This handles the loading of device type attribute requirements into the database. There is a need to post-process to attach the actual attribute ref after the fact
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
dtClusterRefDataPairs | * |
This handles the loading of device type command requirements into the database. There is a need to post-process to attach the actual command ref after the fact
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
dtClusterRefDataPairs | * |
Inserts domains into the database. data is an array of objects that must contain: name
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise that resolves with an array of rowids of all inserted domains.
Param | Type |
---|---|
db | * |
packageId | * |
data | * |
Inserts structs into the database. data is an array of objects that must contain: name
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise that resolves with an array of struct item rowids.
Param | Type |
---|---|
db | * |
packageId | * |
data | * |
Inserts enums into the database.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise of enum insertion.
Param | Type | Description |
---|---|---|
db | * |
|
packageId | * |
|
data | * |
an array of objects that must contain: name, type |
Insert atomics into the database. Data is an array of objects that must contains: name, id, description. Object might also contain 'size', but possibly not.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
packageId | * |
data | * |
Locates atomic type based on a type name.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
packageId | * |
typeName | * |
Retrieve the atomic by name, returning promise that resolves into an atomic, or null.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
name | * |
packageId | * |
Retrieves all atomic types under a given package Id.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
packageId | * |
Retrieves the size from atomic type.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
packageId | * |
type | * |
Inserts bitmaps into the database. Data is an array of objects that must contain: name, type
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise of bitmap insertions.
Param | Type | Description |
---|---|---|
db | * |
|
packageId | * |
|
data | * |
Array of object containing 'name' and 'type'. |
Exports clusters and endpoint ids
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the data that contains cluster
and endpoint id references
Param | Type |
---|---|
db | * |
endpointTypeId | * |
DB API: zcl database access~exportCommandDetailsFromAllEndpointTypesAndClusters(db, endpointTypeId) ⇒
Returns a promise of data for commands inside an endpoint type.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the command data.
Param | Type |
---|---|
db | * |
endpointTypeId | * |
Get the number of command arguments for a command
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise with number of command arguments for a command
Param | Type | Default |
---|---|---|
db | * |
|
commandId | * |
|
[packageId] | * |
|
Extract the command arguments for a command
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: A promise with command arguments for a command
Param | Type | Default |
---|---|---|
db | * |
|
commandId | * |
|
[packageId] | * |
|
Returns a promise that resolves into one of the zclType enum values.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Param | Type |
---|---|
db | * |
packageId | * |
type | * |
Exports clusters to an externalized form.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the data that should go into the external form.
Param | Type |
---|---|
db | * |
endpointTypeId | * |
Returns a promise of data for commands inside all existing endpoint types.
Kind: inner method of [DB API: zcl database access
](#moduleDB API zcl database access)
Returns: Promise that resolves with the command data.
Param | Type |
---|---|
db | * |
endpointTypeId | * |
- [JS API: generator logic](#moduleJS API generator logic)
- [~loadGenTemplate()](#moduleJS API generator logic..loadGenTemplate) ⇒
- [~recordTemplatesPackage(context)](#moduleJS API generator logic..recordTemplatesPackage) ⇒
- [~loadTemplates(db, genTemplatesJson)](#moduleJS API generator logic..loadTemplates) ⇒
- [~generateAllTemplates(genResult, genTemplateJsonPkg, generateOnly)](#moduleJS API generator logic..generateAllTemplates) ⇒
- [~generateSingleTemplate(genResult, singleTemplatePkg)](#moduleJS API generator logic..generateSingleTemplate) ⇒
- [~generate(db, packageId)](#moduleJS API generator logic..generate) ⇒
- [~generateGenerationContent(genResult)](#moduleJS API generator logic..generateGenerationContent)
- [~generateAndWriteFiles(db, sessionId, packageId, outputDirectory)](#moduleJS API generator logic..generateAndWriteFiles) ⇒
- [~contentIndexer(content)](#moduleJS API generator logic..contentIndexer)
- [~generateSingleFileForPreview(db, sessionId, fileName)](#moduleJS API generator logic..generateSingleFileForPreview) ⇒
- [~produceContent(db, sessionId, singlePkg, overridePath:)](#moduleJS API generator logic..produceContent) ⇒
- [~wrapOverridable(originalFn, overrideFn)](#moduleJS API generator logic..wrapOverridable) ⇒
- [~loadOverridable(genTemplatePackageId)](#moduleJS API generator logic..loadOverridable)
- [~loadHelper(path)](#moduleJS API generator logic..loadHelper)
- [~initializeGlobalHelpers()](#moduleJS API generator logic..initializeGlobalHelpers)
- [~makeSynchronizablePromise(promise)](#moduleJS API generator logic..makeSynchronizablePromise)
- [~collectBlocks(resultArray, options, context)](#moduleJS API generator logic..collectBlocks) ⇒
- [~ensureZclPackageId(context)](#moduleJS API generator logic..ensureZclPackageId) ⇒
- [~ensureTemplatePackageId(context)](#moduleJS API generator logic..ensureTemplatePackageId) ⇒
- [~templatePromise(global, promise)](#moduleJS API generator logic..templatePromise)
Given a path, it will read generation template object into memory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: context.templates, context.crc
Param | Type |
---|---|
context.path | * |
Given a loading context, it records the package into the packages table and adds the packageId field into the resolved context.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the same context passed in, except packageId added to it
Param | Type |
---|---|
context | * |
Main API function to load templates from a gen-template.json file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: the loading context, contains: db, path, crc, packageId and templateData
Param | Type | Description |
---|---|---|
db | * |
Database |
genTemplatesJson | * |
Path to the JSON file |
Generates all the templates inside a toplevel package.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with genResult, that contains all the generated templates, keyed by their 'output'
Param | Type | Default | Description |
---|---|---|---|
genResult | * |
||
genTemplateJsonPkg | * |
Package that points to genTemplate.json file | |
generateOnly | * |
|
if NULL then generate all templates, else only generate template whose out file name matches this. |
Function that generates a single package and adds it to the generation result.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the genResult, with newly generated content added.
Param | Type | Description |
---|---|---|
genResult | * |
|
singleTemplatePkg | * |
Single template package. |
Main API function to generate stuff.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves into a generation result.
Param | Type | Description |
---|---|---|
db | * |
Database |
packageId | * |
packageId Template package id. It can be either single template or gen template json. |
Returns a promise that resolves into a content that should be written out to gen result file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genResult | * |
Generate files and write them into the given directory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: a promise which will resolve when all the files are written.
Param | Type |
---|---|
db | * |
sessionId | * |
packageId | * |
outputDirectory | * |
This function takes a string, and resolves a preview object out of it.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type | Description |
---|---|---|
content | * |
String to form into preview. |
Generates a single file and feeds it back for preview.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves into a preview object.
Param | Type |
---|---|
db | * |
sessionId | * |
fileName | * |
Given db connection, session and a single template package, produce the output.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with the 'utf8' string that contains the generated content.
Param | Type | Description |
---|---|---|
db | * |
|
sessionId | * |
|
singlePkg | * |
|
overridePath: | * |
if passed, it provides a path to the override file that can override the overridable.js |
This function attemps to call override function, but if override function throws an exception, it calls the original function.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: result from override function, unless it throws an exception, in which case return result from original function.
Param | Type |
---|---|
originalFn | * |
overrideFn | * |
This function is responsible to load the overridable function container.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genTemplatePackageId | * |
Function that loads the helpers.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
path | * |
Global helper initialization
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
All promises used by the templates should be synchronizable.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
promise | * |
Helpful function that collects the individual blocks by using elements of an array as a context, executing promises for each, and collecting them into the outgoing string.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with a content string.
Param | Type | Description |
---|---|---|
resultArray | * |
|
options | * |
Options passed from a block helper. |
context | * |
The context from within this was called. |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Every helper that returns a promise, should not return the promise directly. So instead of returning the promise directly, it should return: return templatePromise(this.global, promise)
This will ensure that after tag works as expected.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
global | * |
promise | * |
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- [Templating API: C formatting helpers](#moduleTemplating API C formatting helpers)
- [~asMacro(label)](#moduleTemplating API C formatting helpers..asMacro) ⇒
- [~asOffset(hex)](#moduleTemplating API C formatting helpers..asOffset)
- [~asDelimitedMacro(label)](#moduleTemplating API C formatting helpers..asDelimitedMacro)
- [~asHex(label)](#moduleTemplating API C formatting helpers..asHex) ⇒
- [~asUnderlyingType(value)](#moduleTemplating API C formatting helpers..asUnderlyingType)
- [~asType(label)](#moduleTemplating API C formatting helpers..asType) ⇒
- [~asSymbol(label)](#moduleTemplating API C formatting helpers..asSymbol) ⇒
- [~asBytes(value)](#moduleTemplating API C formatting helpers..asBytes)
- [~asCamelCased(str)](#moduleTemplating API C formatting helpers..asCamelCased) ⇒
- [~cleanseLabel(label)](#moduleTemplating API C formatting helpers..cleanseLabel)
- [~asUnderscoreLowercase(str)](#moduleTemplating API C formatting helpers..asUnderscoreLowercase) ⇒
- [~asSpacedLowercase(str)](#moduleTemplating API C formatting helpers..asSpacedLowercase) ⇒
- [~asUnderscoreUppercase(str)](#moduleTemplating API C formatting helpers..asUnderscoreUppercase) ⇒
- [~dataTypeForBitmap(db, bitmap_name, packageId)](#moduleTemplating API C formatting helpers..dataTypeForBitmap)
- [~dataTypeForEnum(db, enum_name, packageId)](#moduleTemplating API C formatting helpers..dataTypeForEnum)
Formats label as a C macro. This method performs a very simply substition of illegal characters, such as ' ', ':' and such into a '_' character.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: Label formatted as C macro.
Param | Type |
---|---|
label | * |
Given a hex number, it prints the offset, which is the index of the first non-zero bit.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
hex | * |
Takes a label, and delimits is on camelcasing. For example: VerySimpleLabel will turn into VERY_SIMPLE_LABEL
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
label | * |
Formats label as a C hex constant. If value starts as 0x or 0X it is already treated as hex, otherwise it is assumed decimal and converted to hex.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: Label formatted as C hex constant.
Param | Type |
---|---|
label | * |
Converts the actual zcl type into an underlying usable C type.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
value | * |
Formats label as a C type.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: Label formatted as C type.
Param | Type |
---|---|
label | * |
Formats label as a C symbol.
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: Label formatted as C symbol.
Param | Type |
---|---|
label | * |
Given a default value of attribute, this method converts it into bytes
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
value | * |
Given a string convert it into a camelCased string
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: a spaced out string in lowercase
Param | Type |
---|---|
str | * |
returns a string after converting ':' and '-' into '_'
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
label | * |
Given a camel case string, convert it into one with underscore and lowercase
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: String in lowercase with underscores
Param | Type |
---|---|
str | * |
Given a camel case string convert it into one with space and lowercase
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: a spaced out string in lowercase
Param | Type |
---|---|
str | * |
Given a camel case string convert it into one with underscore and uppercase
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Returns: String in uppercase with underscores
Param | Type |
---|---|
str | * |
Returns the type of bitmap
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
db | * |
bitmap_name | * |
packageId | * |
Returns the type of enum
Kind: inner method of [Templating API: C formatting helpers
](#moduleTemplating API C formatting helpers)
Param | Type |
---|---|
db | * |
enum_name | * |
packageId | * |
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- [Templating API: user-data specific helpers](#moduleTemplating API user-data specific helpers)
- [~user_endpoint_types(options)](#moduleTemplating API user-data specific helpers..user_endpoint_types)
- [~user_clusters(options)](#moduleTemplating API user-data specific helpers..user_clusters)
- [~user_cluster_attributes(options)](#moduleTemplating API user-data specific helpers..user_cluster_attributes) ⇒
- [~user_cluster_commands(options)](#moduleTemplating API user-data specific helpers..user_cluster_commands) ⇒
- [~user_all_attributes(options)](#moduleTemplating API user-data specific helpers..user_all_attributes) ⇒
- [~all_user_cluster_commands(options)](#moduleTemplating API user-data specific helpers..all_user_cluster_commands) ⇒
- [~all_user_clusters(options)](#moduleTemplating API user-data specific helpers..all_user_clusters) ⇒
- [~user_cluster_command_count_with_cli()](#moduleTemplating API user-data specific helpers..user_cluster_command_count_with_cli)
- [~user_cluster_commands_all_endpoints(options)](#moduleTemplating API user-data specific helpers..user_cluster_commands_all_endpoints) ⇒
Creates block iterator helper over the endpoint types.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Param | Type |
---|---|
options | * |
Creates cluster iterator over the endpoint types. This works ony inside user_endpoint_types.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Param | Type |
---|---|
options | * |
Creates endpoint type cluster attribute iterator. This works only inside user_clusters.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster attributes.
Param | Type |
---|---|
options | * |
Creates endpoint type cluster command iterator. This works only inside user_clusters.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster commands.
Param | Type |
---|---|
options | * |
Iterates over all attributes required by the user configuration.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster commands.
Param | Type |
---|---|
options | * |
Creates endpoint type cluster command iterator. This fetches all commands which have been enabled on added endpoints
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster commands.
Param | Type |
---|---|
options | * |
Creates cluster command iterator for all endpoints.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster commands.
Param | Type |
---|---|
options | * |
Get the count of the number of clusters commands with cli for a cluster. This is used under a cluster block helper
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Creates endpoint type cluster command iterator. This works only inside cluster block helpers.
Kind: inner method of [Templating API: user-data specific helpers
](#moduleTemplating API user-data specific helpers)
Returns: Promise of the resolved blocks iterating over cluster commands.
Param | Type |
---|---|
options | * |
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- [Templating API: toplevel utility helpers](#moduleTemplating API toplevel utility helpers)
- [~zap_header()](#moduleTemplating API toplevel utility helpers..zap_header) ⇒
- [~ident()](#moduleTemplating API toplevel utility helpers..ident) ⇒
- [~template_options(category, options)](#moduleTemplating API toplevel utility helpers..template_options)
- [~first(options)](#moduleTemplating API toplevel utility helpers..first) ⇒
- [~last(options)](#moduleTemplating API toplevel utility helpers..last) ⇒
- [~middle(options)](#moduleTemplating API toplevel utility helpers..middle) ⇒
- [~template_option_with_code(options, key)](#moduleTemplating API toplevel utility helpers..template_option_with_code)
- [~isEqual(string_a, string_b)](#moduleTemplating API toplevel utility helpers..isEqual)
- [~trim_string(str)](#moduleTemplating API toplevel utility helpers..trim_string) ⇒
- [~asLastWord(str)](#moduleTemplating API toplevel utility helpers..asLastWord)
- [~iterate()](#moduleTemplating API toplevel utility helpers..iterate)
Produces the top-of-the-file header for a C file.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: The header content
Simple helper that produces an approved size of identation.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: whitespace that is the identation.
Block helper that iterates over the package options of a given category.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Param | Type |
---|---|
category | * |
options | * |
Inside an iterator, this helper allows you to specify the content that will be output only during the first element.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: content, if it's the first element inside an operator, empty otherwise.
Param | Type |
---|---|
options | * |
Inside an iterator, this helper allows you to specify the content that will be output only during the last element.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: content, if it's the last element inside an operator, empty otherwise.
Param | Type |
---|---|
options | * |
Inside an iterator, this helper allows you to specify the content that will be output only during the non-first and no-last element.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: content, if it's the middle element inside an operator, empty otherwise.
Param | Type |
---|---|
options | * |
This fetches a promise which returns template options if provided
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Param | Type |
---|---|
options | * |
key | * |
This returns a boolean if the 2 strings are same
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Param | Type |
---|---|
string_a | * |
string_b | * |
Remove leading and trailing spaces from a string
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Returns: A string with no leading and trailing spaces
Param | Type |
---|---|
str | * |
Split the string based on spaces and return the last word
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
Param | Type |
---|---|
str | * |
Iteration block.
Kind: inner method of [Templating API: toplevel utility helpers
](#moduleTemplating API toplevel utility helpers)
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- [Templating API: static zcl helpers](#moduleTemplating API static zcl helpers)
- [~zcl_bitmaps(options)](#moduleTemplating API static zcl helpers..zcl_bitmaps) ⇒
- [~zcl_bitmap_items(options)](#moduleTemplating API static zcl helpers..zcl_bitmap_items)
- [~zcl_enums(options)](#moduleTemplating API static zcl helpers..zcl_enums) ⇒
- [~zcl_enum_items(options)](#moduleTemplating API static zcl helpers..zcl_enum_items)
- [~zcl_structs(options)](#moduleTemplating API static zcl helpers..zcl_structs) ⇒
- [~zcl_struct_items(options)](#moduleTemplating API static zcl helpers..zcl_struct_items) ⇒
- [~zcl_clusters(options)](#moduleTemplating API static zcl helpers..zcl_clusters) ⇒
- [~zcl_commands(options)](#moduleTemplating API static zcl helpers..zcl_commands) ⇒
- [~zcl_global_commands(options)](#moduleTemplating API static zcl helpers..zcl_global_commands) ⇒
- [~zcl_attributes(options)](#moduleTemplating API static zcl helpers..zcl_attributes) ⇒
- [~zcl_attributes_client(options)](#moduleTemplating API static zcl helpers..zcl_attributes_client) ⇒
- [~zcl_attributes_server(options)](#moduleTemplating API static zcl helpers..zcl_attributes_server) ⇒
- [~zcl_atomics(options)](#moduleTemplating API static zcl helpers..zcl_atomics) ⇒
- [~zcl_cluster_largest_label_length()](#moduleTemplating API static zcl helpers..zcl_cluster_largest_label_length) ⇒
- [~largestLabelLength(An)](#moduleTemplating API static zcl helpers..largestLabelLength) ⇒
- [~zcl_command_arguments_count(commandId)](#moduleTemplating API static zcl helpers..zcl_command_arguments_count) ⇒
- [~zcl_command_arguments(options)](#moduleTemplating API static zcl helpers..zcl_command_arguments) ⇒
- [~zcl_command_argument_data_type(typeName, options)](#moduleTemplating API static zcl helpers..zcl_command_argument_data_type)
- [~isEnum(db, enum_name, packageId)](#moduleTemplating API static zcl helpers..isEnum) ⇒
- [~isStruct(db, struct_name, packageId)](#moduleTemplating API static zcl helpers..isStruct) ⇒
- [~isBitmap(db, bitmap_name, packageId)](#moduleTemplating API static zcl helpers..isBitmap) ⇒
- [~isClient(side)](#moduleTemplating API static zcl helpers..isClient) ⇒
Block helper iterating over all bitmaps.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Iterates over enum items. Valid only inside zcl_enums.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Param | Type |
---|---|
options | * |
Block helper iterating over all enums.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Iterates over enum items. Valid only inside zcl_enums.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Param | Type |
---|---|
options | * |
Block helper iterating over all structs. function macroList(options)
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Block helper iterating over all struct items. Valid only inside zcl_structs.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Block helper iterating over all clusters.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Block helper iterating over all commands.
There are two modes of this helper:
when used in a global context, it iterates over ALL commands in the database.
when used inside a zcl_cluster
block helper, it iterates only over the commands for that cluster.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Helper to iterate over all global commands.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of global command iteration.
Param | Type |
---|---|
options | * |
Iterator over the attributes. If it is used at toplevel, if iterates over all the attributes in the database. If used within zcl_cluster context, it iterates over all the attributes that belong to that cluster.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of attribute iteration.
Param | Type |
---|---|
options | * |
Iterator over the client attributes. If it is used at toplevel, if iterates over all the client attributes in the database. If used within zcl_cluster context, it iterates over all the client attributes that belong to that cluster.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of attribute iteration.
Param | Type |
---|---|
options | * |
Iterator over the server attributes. If it is used at toplevel, if iterates over all the server attributes in the database. If used within zcl_cluster context, it iterates over all the server attributes that belong to that cluster.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of attribute iteration.
Param | Type |
---|---|
options | * |
Block helper iterating over all atomic types.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
options | * |
Given: N/A
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: the length of largest cluster name in a list of clusters
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: the length of largest object name in an array. Helper for
zcl_cluster_largest_label_length
Param | Type | Description |
---|---|---|
An | * |
Array |
Helper to extract the number of command arguments in a command
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Number of command arguments as an integer
Param | Type |
---|---|
commandId | * |
Block helper iterating over command arguments within a command
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of command argument iteration.
Param | Type |
---|---|
options | * |
Helper that deals with the type of the argument.
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Param | Type |
---|---|
typeName | * |
options | * |
Local function that checks if an enum by the name exists
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
db | * |
enum_name | * |
packageId | * |
Local function that checks if an enum by the name exists
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
db | * |
struct_name | * |
packageId | * |
Local function that checks if a bitmap by the name exists
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: Promise of content.
Param | Type |
---|---|
db | * |
bitmap_name | * |
packageId | * |
Checks if the side is client or not
Kind: inner method of [Templating API: static zcl helpers
](#moduleTemplating API static zcl helpers)
Returns: boolean
Param | Type |
---|---|
side | * |
This module contains the API for templating. For more detailed instructions, read {@tutorial template-tutorial}
- [JS API: generator logic](#moduleJS API generator logic)
- [~loadGenTemplate()](#moduleJS API generator logic..loadGenTemplate) ⇒
- [~recordTemplatesPackage(context)](#moduleJS API generator logic..recordTemplatesPackage) ⇒
- [~loadTemplates(db, genTemplatesJson)](#moduleJS API generator logic..loadTemplates) ⇒
- [~generateAllTemplates(genResult, genTemplateJsonPkg, generateOnly)](#moduleJS API generator logic..generateAllTemplates) ⇒
- [~generateSingleTemplate(genResult, singleTemplatePkg)](#moduleJS API generator logic..generateSingleTemplate) ⇒
- [~generate(db, packageId)](#moduleJS API generator logic..generate) ⇒
- [~generateGenerationContent(genResult)](#moduleJS API generator logic..generateGenerationContent)
- [~generateAndWriteFiles(db, sessionId, packageId, outputDirectory)](#moduleJS API generator logic..generateAndWriteFiles) ⇒
- [~contentIndexer(content)](#moduleJS API generator logic..contentIndexer)
- [~generateSingleFileForPreview(db, sessionId, fileName)](#moduleJS API generator logic..generateSingleFileForPreview) ⇒
- [~produceContent(db, sessionId, singlePkg, overridePath:)](#moduleJS API generator logic..produceContent) ⇒
- [~wrapOverridable(originalFn, overrideFn)](#moduleJS API generator logic..wrapOverridable) ⇒
- [~loadOverridable(genTemplatePackageId)](#moduleJS API generator logic..loadOverridable)
- [~loadHelper(path)](#moduleJS API generator logic..loadHelper)
- [~initializeGlobalHelpers()](#moduleJS API generator logic..initializeGlobalHelpers)
- [~makeSynchronizablePromise(promise)](#moduleJS API generator logic..makeSynchronizablePromise)
- [~collectBlocks(resultArray, options, context)](#moduleJS API generator logic..collectBlocks) ⇒
- [~ensureZclPackageId(context)](#moduleJS API generator logic..ensureZclPackageId) ⇒
- [~ensureTemplatePackageId(context)](#moduleJS API generator logic..ensureTemplatePackageId) ⇒
- [~templatePromise(global, promise)](#moduleJS API generator logic..templatePromise)
Given a path, it will read generation template object into memory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: context.templates, context.crc
Param | Type |
---|---|
context.path | * |
Given a loading context, it records the package into the packages table and adds the packageId field into the resolved context.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the same context passed in, except packageId added to it
Param | Type |
---|---|
context | * |
Main API function to load templates from a gen-template.json file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: the loading context, contains: db, path, crc, packageId and templateData
Param | Type | Description |
---|---|---|
db | * |
Database |
genTemplatesJson | * |
Path to the JSON file |
Generates all the templates inside a toplevel package.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with genResult, that contains all the generated templates, keyed by their 'output'
Param | Type | Default | Description |
---|---|---|---|
genResult | * |
||
genTemplateJsonPkg | * |
Package that points to genTemplate.json file | |
generateOnly | * |
|
if NULL then generate all templates, else only generate template whose out file name matches this. |
Function that generates a single package and adds it to the generation result.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the genResult, with newly generated content added.
Param | Type | Description |
---|---|---|
genResult | * |
|
singleTemplatePkg | * |
Single template package. |
Main API function to generate stuff.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves into a generation result.
Param | Type | Description |
---|---|---|
db | * |
Database |
packageId | * |
packageId Template package id. It can be either single template or gen template json. |
Returns a promise that resolves into a content that should be written out to gen result file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genResult | * |
Generate files and write them into the given directory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: a promise which will resolve when all the files are written.
Param | Type |
---|---|
db | * |
sessionId | * |
packageId | * |
outputDirectory | * |
This function takes a string, and resolves a preview object out of it.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type | Description |
---|---|---|
content | * |
String to form into preview. |
Generates a single file and feeds it back for preview.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves into a preview object.
Param | Type |
---|---|
db | * |
sessionId | * |
fileName | * |
Given db connection, session and a single template package, produce the output.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with the 'utf8' string that contains the generated content.
Param | Type | Description |
---|---|---|
db | * |
|
sessionId | * |
|
singlePkg | * |
|
overridePath: | * |
if passed, it provides a path to the override file that can override the overridable.js |
This function attemps to call override function, but if override function throws an exception, it calls the original function.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: result from override function, unless it throws an exception, in which case return result from original function.
Param | Type |
---|---|
originalFn | * |
overrideFn | * |
This function is responsible to load the overridable function container.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genTemplatePackageId | * |
Function that loads the helpers.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
path | * |
Global helper initialization
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
All promises used by the templates should be synchronizable.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
promise | * |
Helpful function that collects the individual blocks by using elements of an array as a context, executing promises for each, and collecting them into the outgoing string.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with a content string.
Param | Type | Description |
---|---|---|
resultArray | * |
|
options | * |
Options passed from a block helper. |
context | * |
The context from within this was called. |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Every helper that returns a promise, should not return the promise directly. So instead of returning the promise directly, it should return: return templatePromise(this.global, promise)
This will ensure that after tag works as expected.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
global | * |
promise | * |
- [JS API: generator logic](#moduleJS API generator logic)
- [~loadGenTemplate()](#moduleJS API generator logic..loadGenTemplate) ⇒
- [~recordTemplatesPackage(context)](#moduleJS API generator logic..recordTemplatesPackage) ⇒
- [~loadTemplates(db, genTemplatesJson)](#moduleJS API generator logic..loadTemplates) ⇒
- [~generateAllTemplates(genResult, genTemplateJsonPkg, generateOnly)](#moduleJS API generator logic..generateAllTemplates) ⇒
- [~generateSingleTemplate(genResult, singleTemplatePkg)](#moduleJS API generator logic..generateSingleTemplate) ⇒
- [~generate(db, packageId)](#moduleJS API generator logic..generate) ⇒
- [~generateGenerationContent(genResult)](#moduleJS API generator logic..generateGenerationContent)
- [~generateAndWriteFiles(db, sessionId, packageId, outputDirectory)](#moduleJS API generator logic..generateAndWriteFiles) ⇒
- [~contentIndexer(content)](#moduleJS API generator logic..contentIndexer)
- [~generateSingleFileForPreview(db, sessionId, fileName)](#moduleJS API generator logic..generateSingleFileForPreview) ⇒
- [~produceContent(db, sessionId, singlePkg, overridePath:)](#moduleJS API generator logic..produceContent) ⇒
- [~wrapOverridable(originalFn, overrideFn)](#moduleJS API generator logic..wrapOverridable) ⇒
- [~loadOverridable(genTemplatePackageId)](#moduleJS API generator logic..loadOverridable)
- [~loadHelper(path)](#moduleJS API generator logic..loadHelper)
- [~initializeGlobalHelpers()](#moduleJS API generator logic..initializeGlobalHelpers)
- [~makeSynchronizablePromise(promise)](#moduleJS API generator logic..makeSynchronizablePromise)
- [~collectBlocks(resultArray, options, context)](#moduleJS API generator logic..collectBlocks) ⇒
- [~ensureZclPackageId(context)](#moduleJS API generator logic..ensureZclPackageId) ⇒
- [~ensureTemplatePackageId(context)](#moduleJS API generator logic..ensureTemplatePackageId) ⇒
- [~templatePromise(global, promise)](#moduleJS API generator logic..templatePromise)
Given a path, it will read generation template object into memory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: context.templates, context.crc
Param | Type |
---|---|
context.path | * |
Given a loading context, it records the package into the packages table and adds the packageId field into the resolved context.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the same context passed in, except packageId added to it
Param | Type |
---|---|
context | * |
Main API function to load templates from a gen-template.json file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: the loading context, contains: db, path, crc, packageId and templateData
Param | Type | Description |
---|---|---|
db | * |
Database |
genTemplatesJson | * |
Path to the JSON file |
Generates all the templates inside a toplevel package.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with genResult, that contains all the generated templates, keyed by their 'output'
Param | Type | Default | Description |
---|---|---|---|
genResult | * |
||
genTemplateJsonPkg | * |
Package that points to genTemplate.json file | |
generateOnly | * |
|
if NULL then generate all templates, else only generate template whose out file name matches this. |
Function that generates a single package and adds it to the generation result.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the genResult, with newly generated content added.
Param | Type | Description |
---|---|---|
genResult | * |
|
singleTemplatePkg | * |
Single template package. |
Main API function to generate stuff.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves into a generation result.
Param | Type | Description |
---|---|---|
db | * |
Database |
packageId | * |
packageId Template package id. It can be either single template or gen template json. |
Returns a promise that resolves into a content that should be written out to gen result file.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genResult | * |
Generate files and write them into the given directory.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: a promise which will resolve when all the files are written.
Param | Type |
---|---|
db | * |
sessionId | * |
packageId | * |
outputDirectory | * |
This function takes a string, and resolves a preview object out of it.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type | Description |
---|---|---|
content | * |
String to form into preview. |
Generates a single file and feeds it back for preview.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves into a preview object.
Param | Type |
---|---|
db | * |
sessionId | * |
fileName | * |
Given db connection, session and a single template package, produce the output.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with the 'utf8' string that contains the generated content.
Param | Type | Description |
---|---|---|
db | * |
|
sessionId | * |
|
singlePkg | * |
|
overridePath: | * |
if passed, it provides a path to the override file that can override the overridable.js |
This function attemps to call override function, but if override function throws an exception, it calls the original function.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: result from override function, unless it throws an exception, in which case return result from original function.
Param | Type |
---|---|
originalFn | * |
overrideFn | * |
This function is responsible to load the overridable function container.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
genTemplatePackageId | * |
Function that loads the helpers.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
path | * |
Global helper initialization
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
All promises used by the templates should be synchronizable.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
promise | * |
Helpful function that collects the individual blocks by using elements of an array as a context, executing promises for each, and collecting them into the outgoing string.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: Promise that resolves with a content string.
Param | Type | Description |
---|---|---|
resultArray | * |
|
options | * |
Options passed from a block helper. |
context | * |
The context from within this was called. |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Returns the promise that resolves with the ZCL properties package id.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Returns: promise that resolves with the package id.
Param | Type |
---|---|
context | * |
Every helper that returns a promise, should not return the promise directly. So instead of returning the promise directly, it should return: return templatePromise(this.global, promise)
This will ensure that after tag works as expected.
Kind: inner method of [JS API: generator logic
](#moduleJS API generator logic)
Param | Type |
---|---|
global | * |
promise | * |
This module provides the REST API to the admin functions.
API: /sql Request JSON:
{ sql: SQL Query }
Response JSON:
{ result: Array of rows. }
Kind: inner method of [REST API: admin functions
](#moduleREST API admin functions)
Param | Type |
---|---|
db | * |
app | * |
This module provides the REST API to the generation.
- [REST API: generation functions](#moduleREST API generation functions)
- [~registerGenerationApi(db, app)](#moduleREST API generation functions..registerGenerationApi)
- [~registerUcComponentApi(db, app)](#moduleREST API generation functions..registerUcComponentApi)
Kind: inner method of [REST API: generation functions
](#moduleREST API generation functions)
Param | Type |
---|---|
db | * |
app | * |
Register server side REST API for front-end to interact with Studio components.
Kind: inner method of [REST API: generation functions
](#moduleREST API generation functions)
Param | Type |
---|---|
db | * |
app | * |
This module provides the interface to an extenal IDE: Simplicity Studio.
This module provides the REST API to the static zcl queries.
API: /zcl/:entity/:id
Kind: inner method of [REST API: static zcl functions
](#moduleREST API static zcl functions)
Param | Type | Description |
---|---|---|
app | * |
Express instance. |
This module provides the REST API to the generation.
- [REST API: generation functions](#moduleREST API generation functions)
- [~registerGenerationApi(db, app)](#moduleREST API generation functions..registerGenerationApi)
- [~registerUcComponentApi(db, app)](#moduleREST API generation functions..registerUcComponentApi)
Kind: inner method of [REST API: generation functions
](#moduleREST API generation functions)
Param | Type |
---|---|
db | * |
app | * |
Register server side REST API for front-end to interact with Studio components.
Kind: inner method of [REST API: generation functions
](#moduleREST API generation functions)
Param | Type |
---|---|
db | * |
app | * |
This module provides the REST API to the user specific data.
This module provides the HTTP server functionality.
- [JS API: http server](#moduleJS API http server)
- [~registerRestApi(filename, db, app)](#moduleJS API http server..registerRestApi)
- [~initHttpServer(db, port)](#moduleJS API http server..initHttpServer) ⇒
- [~shutdownHttpServer()](#moduleJS API http server..shutdownHttpServer) ⇒
- [~httpServerPort()](#moduleJS API http server..httpServerPort) ⇒
This function is used to register a rest module, which exports get/post/etc. arrays.
Kind: inner method of [JS API: http server
](#moduleJS API http server)
Param | Type |
---|---|
filename | * |
db | * |
app | * |
Promises to initialize the http server on a given port using a given database.
Kind: inner method of [JS API: http server
](#moduleJS API http server)
Returns: A promise that resolves with an express app.
Param | Type | Description |
---|---|---|
db | * |
Database object to use. |
port | * |
Port for the HTTP server. |
Promises to shut down the http server.
Kind: inner method of [JS API: http server
](#moduleJS API http server)
Returns: Promise that resolves when server is shut down.
Port http server is listening on.
Kind: inner method of [JS API: http server
](#moduleJS API http server)
Returns: port
- [JS API: random utilities](#moduleJS API random utilities)
- [~calculateCrc(context)](#moduleJS API random utilities..calculateCrc) ⇒
- [~initializeSessionPackage(db, sessionId)](#moduleJS API random utilities..initializeSessionPackage) ⇒
- [~createBackupFile(path)](#moduleJS API random utilities..createBackupFile)
- [~getSessionKeyFromBrowserWindow(browserWindow)](#moduleJS API random utilities..getSessionKeyFromBrowserWindow)
Promises to calculate the CRC of the file, and resolve with an object { filePath, data, actualCrc }
Kind: inner method of [JS API: random utilities
](#moduleJS API random utilities)
Returns: Promise that resolves with the same object, just adds the 'crc' key into it.
Param | Type | Description |
---|---|---|
context | * |
that contains 'filePath' and 'data' keys for the file and contents of the file. |
This function assigns a proper package ID to the session.
Kind: inner method of [JS API: random utilities
](#moduleJS API random utilities)
Returns: Promise that resolves with the session id for chaining.
Param | Type |
---|---|
db | * |
sessionId | * |
Move database file out of the way into the backup location.
Kind: inner method of [JS API: random utilities
](#moduleJS API random utilities)
Param | Type |
---|---|
path | * |
Returns a promise that resolves into the session key.
Kind: inner method of [JS API: random utilities
](#moduleJS API random utilities)
Param | Type |
---|---|
browserWindow | * |
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This file is used specifically and only for development. It installs
electron-debug
& vue-devtools
. There shouldn't be any need to
modify this file, but it can be used to extend your development
environment.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This module provides the API to Studio's Jetty server.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This module provides the APIs for validating inputs to the database, and returning flags indicating if things were successful or not.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright (c) 2020 Silicon Labs
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Resolves to an array of objects that contain 'key' and 'value'
Kind: global function
Returns: Promise to retrieve all session key values.
Param | Type |
---|---|
db | * |
sessionId | * |
Resolves to an array of endpoints.
Kind: global function
Returns: Promise to retrieve all endpoints.
Param | Type |
---|---|
db | * |
sessionId | * |
Resolves to an array of endpoint types.
Kind: global function
Returns: Promise to retrieve all endpoint types.
Param | Type |
---|---|
db | * |
sessionId | * |
Resolves with data for packages.
Kind: global function
Param | Type |
---|---|
db | * |
sessionId | * |
Toplevel file that takes a given session ID and exports the data into the file
Kind: global function
Returns: A promise that resolves with the path of the file written.
Param | Type |
---|---|
db | * |
sessionId | * |
filePath | * |
Given a database and a session id, this method returns a promise that resolves with a state object that needs to be saved into a file.
Kind: global function
Returns: state object that needs to be saved into a file.
Param | Type |
---|---|
db | * |
sessionId | * |
Resolves with a promise that imports session key values.
Kind: global function
Param | Type |
---|---|
db | * |
sessionId | * |
keyValuePairs | * |
Reads the data from the file and resolves with the state object if all is good.
Kind: global function
Returns: Promise of file reading.
Param | Type |
---|---|
filePath | * |
Given a state object, this method returns a promise that resolves with the succesfull writing into the database.
Kind: global function
Returns: a promise that resolves into a sessionId that was created.
Param | Type |
---|---|
db | * |
state | * |
Writes the data from the file into a new session.
Kind: global function
Returns: a promise that resolves with the session Id of the written data.
Param | Type |
---|---|
db | * |
filePath | * |
Perform a file->open operation.
Kind: global function
Param | Type |
---|---|
menuItem | * |
browserWindow | * |
event | * |
Perform a save, defering to save as if file is not yet selected.
Kind: global function
Param | Type |
---|---|
menuItem | * |
browserWindow | * |
event | * |
Perform save as.
Kind: global function
Param | Type |
---|---|
menuItem | * |
browserWindow | * |
event | * |
This function gets the directory where user wants the output and calls generateCode function which generates the code in the user selected output.
Kind: global function
Param | Type |
---|---|
browserWindow | * |
This function gets the directory where user wants the output and calls generateCode function which generates the code in the user selected output.
Kind: global function
Param | Type |
---|---|
browserWindow | * |
perform the save.
Kind: global function
Returns: Promise of saving.
Param | Type |
---|---|
db | * |
browserWindow | * |
filePath | * |
Perform the do open action, possibly reading in multiple files.
Kind: global function
Param | Type |
---|---|
db | * |
filePaths | * |
Process a single file, parsing it in as JSON and then possibly opening a new window if all is good.
Kind: global function
Param | Type |
---|---|
db | * |
filePath | * |
Initialize a menu.
Kind: global function
Param | Type |
---|---|
port | * |
Call this function to create a new or show an existing preference window.
Kind: global function
Param | Type |
---|---|
port | * |
Start up application in a normal mode.
Kind: global function
Param | Type |
---|---|
uiEnabled | * |
showUrl | * |
uiMode | * |
Start up application in self-check mode.
Performs headless regeneration for given parameters.
Kind: global function
Returns: Nothing, triggers app.quit()
Param | Type | Default | Description |
---|---|---|---|
output | * |
Directory where to write files. | |
genTemplateJsonFile | * |
gen-teplate.json file to use for template loading. | |
zclProperties | * |
zcl.properties file to use for ZCL properties. | |
[zapFile] | * |
|
.zap file that contains application stater, or null if generating from clean state. |
Move database file out of the way into the backup location.
Kind: global function
Param | Type |
---|---|
path | * |
Create a window, possibly with a given file path and with a desire to attach to a given sessionId
Win id will be passed on in the URL, and if sessionId is present, so will it.
Kind: global function
Returns: BrowserWindow that got created
Param | Type | Default |
---|---|---|
port | * |
|
[filePath] | * |
|
[sessionId] | * |
|
Process the command line arguments and resets the state in this file to the specified values.
Kind: global function
Returns: parsed argv object
Param | Type |
---|---|
argv | * |
Takes an int8 value and turns it into a hex.
Kind: global function
Returns: hex string, 2 characters long without '0x'
Param | Type |
---|---|
value | * |
Takes an int16 value and turns it into a hex.
Kind: global function
Returns: hex string, 4 characters long without '0x'
Param | Type |
---|---|
value | * |
Takes an int8 value and turns it into a hex.
Kind: global function
Returns: hex string, 8 characters long without '0x'
Param | Type |
---|---|
value | * |
Converts a string to the hex value.
Kind: global function
Returns: hex string, value.length * 2 + 2 characters long. It appends the terminating NULL, so 0x00 is at the end.
Param | Type |
---|---|
value | * |
Takes the raw hex string, such as abcd
and
converts it into a C constant array, such as
0xAB, 0xCD
.
Kind: global function
Returns: C byte array
Param | Type |
---|---|
value | * |
Getting a binary string ("0001101010010") it returns the number of zero bits at the end.
Kind: global function
Param | Type |
---|---|
binary | * |
Convert a hex number to a binary. Hex has to be in a format as obtained by intToHex methods above: no '0x' prefix and upper-case letters, as in "12AB".
Kind: global function
Param | Type |
---|---|
hex | * |
Promises to read the properties file, extract all the actual xml files, and resolve with the array of files.
Kind: global function
Returns: Promise of resolved files.
Param | Type | Description |
---|---|---|
ctx | * |
Context which contains information about the metadataFiles and data |
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
Kind: global function
Returns: Promise that resolves when all the individual promises of each file pass.
Param | Type |
---|---|
db | * |
ctx | * |
The Dotdot ZCL XML doesn't use the 0x prefix, but it's a nice thing to have and Silabs xml does use this so this helper function normalizes the use of hex
TODO: Is this the right thing to do?
Kind: global function
Returns: Either the normalized hex string (with the 0x prefix) or the original
Param | Type | Description |
---|---|---|
value | * |
the string value to be normalized |
The Dotdot ZCL XML doesn't have a length but it is embedded in the short name, we can scrape the value to get the size
TODO: Is this the right thing to do?
Kind: global function
Returns: size in bytes or 0 if the # of bytes could not be determined
Param | Type | Description |
---|---|---|
value | * |
the string value to be scraped |
Prepare XML attributes for entry into the DB
Kind: global function
Returns: Array containing all data from XML ready to be inserted into the DB.
Param | Type | Description |
---|---|---|
attributes | * |
an array of attributes |
side | * |
the side the attribute is on either "client" or "server" |
Prepare XML commands for entry into the DB
Kind: global function
Returns: Array containing all data from XML ready to be inserted in to the DB.
Param | Type | Description |
---|---|---|
commands | * |
an array of commands |
side | * |
the side the command is on either "client" or "server" |
Prepare XML cluster for insertion into the database. This method can also prepare clusterExtensions.
Kind: global function
Returns: Object containing all data from XML.
Param | Type | Default | Description |
---|---|---|---|
cluster | * |
||
isExtension | * |
false |
if this is an extension or not (there are none in dotdot xml) |
types | * |
types object into which cluster can put types it might have |
Parses xml type into the atomic object for insertion into the DB
Kind: global function
Returns: object ready for insertion into the DB
Param | Type | Description |
---|---|---|
type | * |
an xml object which conforms to the atomic format in the dotdot xml |
Parses xml type into the bitmap object for insertion into the DB
Kind: global function
Returns: object ready for insertion into the DB
Param | Type | Default | Description |
---|---|---|---|
type | * |
an xml object which conforms to the bitmap format in the dotdot xml | |
fromAttribute | * |
false |
a boolean indicating if this is coming from an attribute or not |
Parses xml type into the enum object for insertion into the DB
Kind: global function
Returns: object ready for insertion into the DB
Param | Type | Description |
---|---|---|
type | * |
an xml object which conforms to the enum format in the dotdot xml |
Parses xml type into the struct object for insertion into the DB
Kind: global function
Returns: object ready for insertion into the DB
Param | Type | Description |
---|---|---|
type | * |
an xml object which conforms to the struct format in the dotdot xml |
Parses xml types into the types object for insertion into the DB
Kind: global function
Param | Type | Description |
---|---|---|
zclTypes | * |
an array of xml types |
types | * |
an object which includes arrays for enums, bitmaps etc... |
Parses xml types into the types object for insertion into the DB
Kind: global function
Param | Type | Description |
---|---|---|
attribute | * |
an attribute with the type in it |
types | * |
an object which includes arrays for enums, bitmaps etc... |
cluster | * |
the cluster that the attribute belongs to (used presently for uniqueness of the type name) |
Preparation step for the device types.
Kind: global function
Returns: an object containing the prepared device types.
Param | Type |
---|---|
deviceType | * |
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
Kind: global function
Returns: Promise that resolves when all the individual promises of each file pass.
Param | Type |
---|---|
db | * |
ctx | * |
Toplevel function that loads the xml library file and orchestrates the promise chain.
Kind: global function
Returns: a Promise that resolves with the db.
Param | Type | Description |
---|---|---|
db | * |
|
ctx | * |
Context of loading. |
Reads the properties file into ctx.data and also calculates crc into ctx.crc
Kind: global function
Returns: Promise to populate data, filePath and crc into the context.
Param | Type |
---|---|
ctx | * |
Records the toplevel package information and puts ctx.packageId into the context.
Kind: global function
Param | Type |
---|---|
ctx | * |
Records the version into the database.
Kind: global function
Param | Type |
---|---|
db | * |
ctx | * |
Toplevel function that loads the zcl file and passes it off to the correct zcl loader.
Kind: global function
Returns: a Promise that resolves with the db.
Param | Type |
---|---|
db | * |
metadataFile | * |
Promises to qualify whether zcl file needs to be reloaded. If yes, the it will resolve with {filePath, data, packageId} If not, then it will resolve with {error}
Kind: global function
Returns: Promise that resolves int he object of data.
Param | Type |
---|---|
db | * |
info | * |
parentPackageId | * |
Promises to perform a post loading step.
Kind: global function
Returns: Promise to deal with the post-loading cleanup.
Param | Type |
---|---|
db | * |
Promises to read a file and resolve with the content
Kind: global function
Returns: promise that resolves as readFile
Param | Type |
---|---|
file | * |
Promises to parse the ZCL file, expecting object of { filePath, data, packageId, msg }
Kind: global function
Returns: promise that resolves with the array [filePath,result,packageId,msg]
Param | Type |
---|---|
argument | * |
Promises to read the JSON file and resolve all the data.
Kind: global function
Returns: Promise of resolved file.
Param | Type | Description |
---|---|---|
ctx | * |
Context containing information about the file |
Promises to read the properties file, extract all the actual xml files, and resolve with the array of files.
Kind: global function
Returns: Promise of resolved files.
Param | Type | Description |
---|---|---|
ctx | * |
Context which contains information about the propertiesFiles and data |
Prepare bitmap for database insertion.
Kind: global function
Returns: Object for insertion into the database
Param | Type |
---|---|
bm | * |
Processes bitmaps for DB insertion.
Kind: global function
Returns: Promise of inserted bitmaps
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Prepare atomic to db insertion.
Kind: global function
Param | Type |
---|---|
a | * |
Processes atomic types for DB insertion.
Kind: global function
Returns: Promise of inserted bitmaps
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Prepares global attribute data.
Kind: global function
Returns: Object containing the data from XML.
Param | Type |
---|---|
cluster | * |
Prepare XML cluster for insertion into the database. This method can also prepare clusterExtensions.
Kind: global function
Returns: Object containing all data from XML.
Param | Type |
---|---|
cluster | * |
Process clusters for insertion into the database.
Kind: global function
Returns: Promise of cluster insertion.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Processes global attributes for insertion into the database.
Kind: global function
Returns: Promise of inserted data.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Cluster Extension contains attributes and commands in a same way as regular cluster, and it has an attribute code="0xXYZ" where code is a cluster code.
Kind: global function
Returns: promise to resolve the clusterExtension tags
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Processes the globals in the XML files. The global
tag contains
attributes and commands in a same way as cluster or clusterExtension
Kind: global function
Returns: promise to resolve the globals
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Convert domain from XMl to domain for DB.
Kind: global function
Returns: Domain object for DB.
Param | Type |
---|---|
domain | * |
Process domains for insertion.
Kind: global function
Returns: Promise of database insertion of domains.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Prepares structs for the insertion into the database.
Kind: global function
Returns: Object ready to insert into the database.
Param | Type |
---|---|
struct | * |
Processes structs.
Kind: global function
Returns: Promise of inserted structs.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Prepares an enum for insertion into the database.
Kind: global function
Returns: An object ready to go to the database.
Param | Type |
---|---|
en | * |
Processes the enums.
Kind: global function
Returns: A promise of inserted enums.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
Preparation step for the device types.
Kind: global function
Returns: an object containing the prepared device types.
Param | Type |
---|---|
deviceType | * |
Process all device types.
Kind: global function
Returns: Promise of a resolved device types.
Param | Type |
---|---|
db | * |
filePath | * |
packageId | * |
data | * |
After XML parser is done with the barebones parsing, this function branches the individual toplevel tags.
Kind: global function
Returns: promise that resolves when all the subtags are parsed.
Param | Type |
---|---|
db | * |
argument | * |
Promises to iterate over all the XML files and returns an aggregate promise that will be resolved when all the XML files are done, or rejected if at least one fails.
Kind: global function
Returns: Promise that resolves when all the individual promises of each file pass.
Param | Type |
---|---|
db | * |
ctx | * |
Toplevel function that loads the properties file and orchestrates the promise chain.
Kind: global function
Returns: a Promise that resolves with the db.
Param | Type | Description |
---|---|---|
db | * |
|
ctx | * |
The context of loading. |