The Function Store is a curated index of OpenFaaS functions which have been tested by the community and chosen for their experience.
See the announcement here
- How much does this cost?
It's free
- What's happening conceptually?
The concept is that we will keep a curated list of interesting functions that you can deploy in one-click to your existing OpenFaaS API Gateway using the UI. We do not need access to your API gateway.
We may update the CLI to make use of the store future too.
- Where are functions hosted?
In any public Docker registry whether that be the Docker Hub, Quay or elsewhere.
- Where is the list/definition kept?
We are using a .json file in this repository and GitHub's raw download CDN.
- Why is it called a store if I don't have to pay money?
See also: Google Play Store/Apple App Store.
If you'd like to make a submission then raise an issue to propose it. This should follow the CONTRIBUTION guide for OpenFaaS.
Here are two example function definitions.
[
{
"title": "Inception",
"description": "This is a forked version of the work by Magnus Erik Hvass Pedersen - it has been re-packaged as an OpenFaaS serverless function.",
"image": "alexellis/inception",
"name": "inception",
"fprocess": "python3 index.py",
"network": "func_functions",
"repo_url": "https://github.com/faas-and-furious/inception-function",
"labels": {
"com.openfaas.ui.ext": "json"
},
"environment": {
"write_timeout": "30"
}
}
]
{
"version": "0.2.0",
"functions": [
{
"title": "NodeInfo",
"name": "nodeinfo",
"description": "Get info about the machine that you're deployed on. Tells CPU count, hostname, OS, and Uptime",
"images": {
"arm64": "functions/nodeinfo:arm64",
"armhf": "functions/nodeinfo:latest-armhf",
"x86_64": "functions/nodeinfo:latest"
},
"labels": {
"com.openfaas.ui.ext": "json"
},
"environment": {
"write_timeout": "30"
},
"fprocess": "node main.js",
"network": "func_functions",
"repo_url": "https://github.com/openfaas/faas/tree/master/sample-functions/NodeInfo"
}
]
}
labels
You can set the file extension used by the UI to download a result from your function i.e. csv/mp3/txt
environment
Set timeouts etc
The Template Store contains all the templates from OpenFaaS and OpenFaaS-Incubator organizations, along with user-defined templates which have been approved by the community.
If you'd like to see your template in the official store follow these steps:
- Open an issue to propose the template and include a link to your template repository. This should follow the CONTRIBUTION guide for OpenFaaS.
- Await feedback on, and subsequent approval of, your proposal from the community.
- Add your template to the
templates.json
file. Here is example of a template definition:
{
"template": "go",
"platform": "x86_64",
"language": "Go",
"source": "openfaas",
"description": "Classic Golang template",
"repo": "https://github.com/openfaas/templates",
"official": "true"
},
- Open PR for your template to be merged in the Template Store
Once merged you can see your template displayed by typing faas-cli template store list
in the terminal.
Those are the custom templates created by the community: