ts-func v0.3.0
ts-func
Generate Azure Function App Configs from TypeScript and JavaScript!
Usage
Add a .tsfuncrc.ts
file, and then use ts-func
to compile and clean up generated function.json
for your app.
> ts-func --help
usage: ts-func [-h] [-v] [cleanup | compile] ...
TS Func: Azure function.json generator
optional arguments:
-h, --help show this help message and exit
-v, --version show program's version number and exit
Commands:
[cleanup | compile]
cleanup Clean up the current working directory of all emitted function.json.
compile Compile .tsfuncrc.(ts|js) in the current working directory and emit function.json.
~> ts-func compile --help
usage: ts-func compile [-h] [--noEmit] [--ignoreScripts]
optional arguments:
-h, --help show this help message and exit
--noEmit, -n Do not make any changes to the target directory.
--ignoreScripts, -i Ignore `scriptFile` properties; passes them unmodified to the output json.
How it works
Define a JavaScript or TypeScript file at the root of your project named .tsfuncrc
; can be either .js
or .ts
.
This file is the configuration entry point for generating folders and function.json
files in the root of the current working directory with a scheme of <EXPORT_NAME>/function.json
. Function configurations must be named exports of either an object implementing AzureFunctionSchema
or a function which returns AzureFunctionSchema
object. Function exports may be either synchronous or async, they'll be await
-ed either way.
Additional options may be passed to ts-func
by exporting a default object with the options defined as desired. These options will be merged with the internal defaults and used when generating the Function App configurations. The options must be either export default
in TypeScript, or explicitly named default
in JavaScript in order to be picked up and not treated like a function configuration.
This config file is usable code; you can do anything you want, including importing the Azure Function Schema objects from other files and entry points, so long as the desired exports are named and follow the criteria outlined above.
See the sample .tsfuncrc.ts
in the root of this project for inspiration.
Requires Node v12 or better.
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago