diff --git a/README.md b/README.md index 0f0f6bbf..f1681757 100644 --- a/README.md +++ b/README.md @@ -18,8 +18,6 @@ See: `faas-cli template store list` to see which templates are both: recommended |:-----|:---------|:--------|:-----------|:---------|:---- | dockerfile | Dockerfile | N/A | Alpine Linux | classic | [Dockerfile template](https://github.com/openfaas/templates/tree/master/template/dockerfile) | go | Go | 1.22 | Alpine Linux | classic | [Legacy Go template (deprecated)](https://github.com/openfaas/templates/tree/master/template/go) -| node16 | NodeJS | 16 | Alpine Linux | of-watchdog | [NodeJS template (deprecated)](https://github.com/openfaas/templates/tree/master/template/node16) -| node17 | NodeJS | 17 | Alpine Linux | of-watchdog | [NodeJS template (deprecated)](https://github.com/openfaas/templates/tree/master/template/node17) | node18 | NodeJS | 18 | Alpine Linux | of-watchdog | [NodeJS template (deprecated)](https://github.com/openfaas/templates/tree/master/template/node18) | node20 | NodeJS | 20 | Alpine Linux | of-watchdog | [NodeJS template](https://github.com/openfaas/templates/tree/master/template/node20) | bun-express | Bun | 1.0 | Alpine Linux | of-watchdog | [NodeJS template](https://github.com/openfaas/templates/tree/master/template/bun-express) diff --git a/template/node16/.dockerignore b/template/node16/.dockerignore deleted file mode 100644 index e84c3fba..00000000 --- a/template/node16/.dockerignore +++ /dev/null @@ -1 +0,0 @@ -*/node_modules diff --git a/template/node16/Dockerfile b/template/node16/Dockerfile deleted file mode 100644 index c6025350..00000000 --- a/template/node16/Dockerfile +++ /dev/null @@ -1,62 +0,0 @@ -FROM --platform=${TARGETPLATFORM:-linux/amd64} ghcr.io/openfaas/of-watchdog:0.10.6 AS watchdog -FROM --platform=${TARGETPLATFORM:-linux/amd64} node:16-alpine AS ship - -ARG TARGETPLATFORM -ARG BUILDPLATFORM - -COPY --from=watchdog /fwatchdog /usr/bin/fwatchdog -RUN chmod +x /usr/bin/fwatchdog - -RUN apk --no-cache add curl ca-certificates \ - && addgroup -S app && adduser -S -g app app - -# Turn down the verbosity to default level. -ENV NPM_CONFIG_LOGLEVEL warn - -RUN chmod 777 /tmp - -USER app - -RUN mkdir -p /home/app/function - -# Wrapper/boot-strapper -WORKDIR /home/app -COPY package.json ./ - -# This ordering means the npm installation is cached for the outer function handler. -RUN npm i - -# Copy outer function handler -COPY index.js ./ - -# COPY function node packages and install, adding this as a separate -# entry allows caching of npm install - -WORKDIR /home/app/function -COPY function/*.json ./ - -RUN npm i - -# COPY function files and folders -COPY function/ ./ - -# Run any tests that may be available -RUN npm test - -# Set correct permissions to use non root user -WORKDIR /home/app/ - -ENV cgi_headers="true" -ENV fprocess="node index.js" -ENV mode="http" -ENV upstream_url="http://127.0.0.1:3000" - -ENV exec_timeout="10s" -ENV write_timeout="15s" -ENV read_timeout="15s" - -ENV prefix_logs="false" - -HEALTHCHECK --interval=3s CMD [ -e /tmp/.lock ] || exit 1 - -CMD ["fwatchdog"] diff --git a/template/node16/function/handler.js b/template/node16/function/handler.js deleted file mode 100644 index 18f543d4..00000000 --- a/template/node16/function/handler.js +++ /dev/null @@ -1,12 +0,0 @@ -'use strict' - -module.exports = async (event, context) => { - const result = { - 'body': JSON.stringify(event.body), - 'content-type': event.headers["content-type"] - } - - return context - .status(200) - .succeed(result) -} diff --git a/template/node16/function/package.json b/template/node16/function/package.json deleted file mode 100644 index a3c013b0..00000000 --- a/template/node16/function/package.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "name": "openfaas-function", - "version": "1.0.0", - "description": "OpenFaaS Function", - "main": "handler.js", - "scripts": { - "test": "echo \"Error: no test specified\" && exit 0" - }, - "keywords": [], - "author": "OpenFaaS Ltd", - "license": "MIT" -} diff --git a/template/node16/index.js b/template/node16/index.js deleted file mode 100644 index e573248e..00000000 --- a/template/node16/index.js +++ /dev/null @@ -1,144 +0,0 @@ -// Copyright (c) Alex Ellis 2021. All rights reserved. -// Copyright (c) OpenFaaS Author(s) 2021. All rights reserved. -// Licensed under the MIT license. See LICENSE file in the project root for full license information. - -"use strict" - -const express = require('express') -const app = express() -const handler = require('./function/handler'); -const bodyParser = require('body-parser') - -const defaultMaxSize = '100kb' // body-parser default - -app.disable('x-powered-by'); - -const rawLimit = process.env.MAX_RAW_SIZE || defaultMaxSize -const jsonLimit = process.env.MAX_JSON_SIZE || defaultMaxSize - -app.use(function addDefaultContentType(req, res, next) { - // When no content-type is given, the body element is set to - // nil, and has been a source of contention for new users. - - if(!req.headers['content-type']) { - req.headers['content-type'] = "text/plain" - } - next() -}) - -if (process.env.RAW_BODY === 'true') { - app.use(bodyParser.raw({ type: '*/*' , limit: rawLimit })) -} else { - app.use(bodyParser.text({ type : "text/*" })); - app.use(bodyParser.json({ limit: jsonLimit})); - app.use(bodyParser.urlencoded({ extended: true })); -} - -const isArray = (a) => { - return (!!a) && (a.constructor === Array); -}; - -const isObject = (a) => { - return (!!a) && (a.constructor === Object); -}; - -class FunctionEvent { - constructor(req) { - this.body = req.body; - this.headers = req.headers; - this.method = req.method; - this.query = req.query; - this.path = req.path; - } -} - -class FunctionContext { - constructor(cb) { - this.statusCode = 200; - this.cb = cb; - this.headerValues = {}; - this.cbCalled = 0; - } - - status(statusCode) { - if(!statusCode) { - return this.statusCode; - } - - this.statusCode = statusCode; - return this; - } - - headers(value) { - if(!value) { - return this.headerValues; - } - - this.headerValues = value; - return this; - } - - succeed(value) { - let err; - this.cbCalled++; - this.cb(err, value); - } - - fail(value) { - let message; - if(this.status() == "200") { - this.status(500) - } - - this.cbCalled++; - this.cb(value, message); - } -} - -const middleware = async (req, res) => { - const cb = (err, functionResult) => { - if (err) { - console.error(err); - - return res.status(fnContext.status()) - .send(err.toString ? err.toString() : err); - } - - if(isArray(functionResult) || isObject(functionResult)) { - res.set(fnContext.headers()) - .status(fnContext.status()).send(JSON.stringify(functionResult)); - } else { - res.set(fnContext.headers()) - .status(fnContext.status()) - .send(functionResult); - } - }; - - const fnEvent = new FunctionEvent(req); - const fnContext = new FunctionContext(cb); - - Promise.resolve(handler(fnEvent, fnContext, cb)) - .then(res => { - if(!fnContext.cbCalled) { - fnContext.succeed(res); - } - }) - .catch(e => { - cb(e); - }); -}; - -app.post('/*', middleware); -app.get('/*', middleware); -app.patch('/*', middleware); -app.put('/*', middleware); -app.delete('/*', middleware); -app.options('/*', middleware); - -const port = process.env.http_port || 3000; - -app.listen(port, () => { - console.log(`node16 listening on port: ${port}`) -}); - - diff --git a/template/node16/package.json b/template/node16/package.json deleted file mode 100644 index b6a45c5e..00000000 --- a/template/node16/package.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "name": "openfaas-node12", - "version": "1.0.0", - "description": "", - "main": "index.js", - "scripts": { - "test": "echo \"Error: no tests specified\" && exit 0" - }, - "keywords": [], - "author": "OpenFaaS Ltd", - "license": "MIT", - "dependencies": { - "body-parser": "^1.18.2", - "express": "^4.16.2" - } -} diff --git a/template/node16/template.yml b/template/node16/template.yml deleted file mode 100644 index 953dd8b2..00000000 --- a/template/node16/template.yml +++ /dev/null @@ -1,12 +0,0 @@ -language: node16 -fprocess: node index.js -welcome_message: | - You have created a new function which uses Node.js 16 (LTS) and the OpenFaaS - of-watchdog which gives greater control over HTTP responses. - - npm i --save can be used to add third-party packages like request or cheerio - npm documentation: https://docs.npmjs.com/ - - Unit tests are run at build time via "npm run", edit package.json to specify - how you want to execute them. - diff --git a/template/node17/.dockerignore b/template/node17/.dockerignore deleted file mode 100644 index e84c3fba..00000000 --- a/template/node17/.dockerignore +++ /dev/null @@ -1 +0,0 @@ -*/node_modules diff --git a/template/node17/Dockerfile b/template/node17/Dockerfile deleted file mode 100644 index c21a853d..00000000 --- a/template/node17/Dockerfile +++ /dev/null @@ -1,62 +0,0 @@ -FROM --platform=${TARGETPLATFORM:-linux/amd64} ghcr.io/openfaas/of-watchdog:0.10.6 AS watchdog -FROM --platform=${TARGETPLATFORM:-linux/amd64} node:17-alpine AS ship - -ARG TARGETPLATFORM -ARG BUILDPLATFORM - -COPY --from=watchdog /fwatchdog /usr/bin/fwatchdog -RUN chmod +x /usr/bin/fwatchdog - -RUN apk --no-cache add curl ca-certificates \ - && addgroup -S app && adduser -S -g app app - -# Turn down the verbosity to default level. -ENV NPM_CONFIG_LOGLEVEL warn - -RUN chmod 777 /tmp - -USER app - -RUN mkdir -p /home/app/function - -# Entrypoint -WORKDIR /home/app -COPY --chown=app:app package.json ./ - -# This ordering means the npm installation is cached for the outer function handler. -RUN npm i - -# Copy outer function handler -COPY --chown=app:app index.js ./ - -# COPY function node packages and install, adding this as a separate -# entry allows caching of npm install - -WORKDIR /home/app/function -COPY --chown=app:app function/*.json ./ - -RUN npm i - -# COPY function files and folders -COPY --chown=app:app function/ ./ - -# Run any tests that may be available -RUN npm test - -# Set correct permissions to use non root user -WORKDIR /home/app/ - -ENV cgi_headers="true" -ENV fprocess="node index.js" -ENV mode="http" -ENV upstream_url="http://127.0.0.1:3000" - -ENV exec_timeout="10s" -ENV write_timeout="15s" -ENV read_timeout="15s" - -ENV prefix_logs="false" - -HEALTHCHECK --interval=3s CMD [ -e /tmp/.lock ] || exit 1 - -CMD ["fwatchdog"] diff --git a/template/node17/function/handler.js b/template/node17/function/handler.js deleted file mode 100644 index 18f543d4..00000000 --- a/template/node17/function/handler.js +++ /dev/null @@ -1,12 +0,0 @@ -'use strict' - -module.exports = async (event, context) => { - const result = { - 'body': JSON.stringify(event.body), - 'content-type': event.headers["content-type"] - } - - return context - .status(200) - .succeed(result) -} diff --git a/template/node17/function/package.json b/template/node17/function/package.json deleted file mode 100644 index a3c013b0..00000000 --- a/template/node17/function/package.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "name": "openfaas-function", - "version": "1.0.0", - "description": "OpenFaaS Function", - "main": "handler.js", - "scripts": { - "test": "echo \"Error: no test specified\" && exit 0" - }, - "keywords": [], - "author": "OpenFaaS Ltd", - "license": "MIT" -} diff --git a/template/node17/index.js b/template/node17/index.js deleted file mode 100644 index 13595293..00000000 --- a/template/node17/index.js +++ /dev/null @@ -1,144 +0,0 @@ -// Copyright (c) Alex Ellis 2021. All rights reserved. -// Copyright (c) OpenFaaS Author(s) 2021. All rights reserved. -// Licensed under the MIT license. See LICENSE file in the project root for full license information. - -"use strict" - -const express = require('express') -const app = express() -const handler = require('./function/handler'); -const bodyParser = require('body-parser') - -const defaultMaxSize = '100kb' // body-parser default - -app.disable('x-powered-by'); - -const rawLimit = process.env.MAX_RAW_SIZE || defaultMaxSize -const jsonLimit = process.env.MAX_JSON_SIZE || defaultMaxSize - -app.use(function addDefaultContentType(req, res, next) { - // When no content-type is given, the body element is set to - // nil, and has been a source of contention for new users. - - if(!req.headers['content-type']) { - req.headers['content-type'] = "text/plain" - } - next() -}) - -if (process.env.RAW_BODY === 'true') { - app.use(bodyParser.raw({ type: '*/*' , limit: rawLimit })) -} else { - app.use(bodyParser.text({ type : "text/*" })); - app.use(bodyParser.json({ limit: jsonLimit})); - app.use(bodyParser.urlencoded({ extended: true })); -} - -const isArray = (a) => { - return (!!a) && (a.constructor === Array); -}; - -const isObject = (a) => { - return (!!a) && (a.constructor === Object); -}; - -class FunctionEvent { - constructor(req) { - this.body = req.body; - this.headers = req.headers; - this.method = req.method; - this.query = req.query; - this.path = req.path; - } -} - -class FunctionContext { - constructor(cb) { - this.statusCode = 200; - this.cb = cb; - this.headerValues = {}; - this.cbCalled = 0; - } - - status(statusCode) { - if(!statusCode) { - return this.statusCode; - } - - this.statusCode = statusCode; - return this; - } - - headers(value) { - if(!value) { - return this.headerValues; - } - - this.headerValues = value; - return this; - } - - succeed(value) { - let err; - this.cbCalled++; - this.cb(err, value); - } - - fail(value) { - let message; - if(this.status() == "200") { - this.status(500) - } - - this.cbCalled++; - this.cb(value, message); - } -} - -const middleware = async (req, res) => { - const cb = (err, functionResult) => { - if (err) { - console.error(err); - - return res.status(fnContext.status()) - .send(err.toString ? err.toString() : err); - } - - if(isArray(functionResult) || isObject(functionResult)) { - res.set(fnContext.headers()) - .status(fnContext.status()).send(JSON.stringify(functionResult)); - } else { - res.set(fnContext.headers()) - .status(fnContext.status()) - .send(functionResult); - } - }; - - const fnEvent = new FunctionEvent(req); - const fnContext = new FunctionContext(cb); - - Promise.resolve(handler(fnEvent, fnContext, cb)) - .then(res => { - if(!fnContext.cbCalled) { - fnContext.succeed(res); - } - }) - .catch(e => { - cb(e); - }); -}; - -app.post('/*', middleware); -app.get('/*', middleware); -app.patch('/*', middleware); -app.put('/*', middleware); -app.delete('/*', middleware); -app.options('/*', middleware); - -const port = process.env.http_port || 3000; - -app.listen(port, () => { - console.log(`node17 listening on port: ${port}`) -}); - - diff --git a/template/node17/package.json b/template/node17/package.json deleted file mode 100644 index b6a45c5e..00000000 --- a/template/node17/package.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "name": "openfaas-node12", - "version": "1.0.0", - "description": "", - "main": "index.js", - "scripts": { - "test": "echo \"Error: no tests specified\" && exit 0" - }, - "keywords": [], - "author": "OpenFaaS Ltd", - "license": "MIT", - "dependencies": { - "body-parser": "^1.18.2", - "express": "^4.16.2" - } -} diff --git a/template/node17/template.yml b/template/node17/template.yml deleted file mode 100644 index fdd71264..00000000 --- a/template/node17/template.yml +++ /dev/null @@ -1,12 +0,0 @@ -language: node17 -fprocess: node index.js -welcome_message: | - You have created a new function which uses Node.js 17 and the OpenFaaS - of-watchdog which gives greater control over HTTP responses. - - npm i --save can be used to add third-party packages like request or cheerio - npm documentation: https://docs.npmjs.com/ - - Unit tests are run at build time via "npm run", edit package.json to specify - how you want to execute them. -