This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 6. Functions
6.1. Setting up OpenShift Serverless Functions
To improve the process of deployment of your application code, you can use OpenShift Serverless to deploy stateless, event-driven functions as a Knative service on OpenShift Container Platform. If you want to develop functions, you must complete the set up steps.
6.1.1. Prerequisites
To enable the use of OpenShift Serverless Functions on your cluster, you must complete the following steps:
- The OpenShift Serverless Operator and Knative Serving are installed on your cluster. Note- Functions are deployed as a Knative service. If you want to use event-driven architecture with your functions, you must also install Knative Eventing. 
- 
							You have the ocCLI installed.
- 
							You have the Knative (kn) CLI installed. Installing the Knative CLI enables the use ofkn funccommands which you can use to create and manage functions.
- You have installed Docker Container Engine or Podman version 3.4.7 or higher.
- You have access to an available image registry, such as the OpenShift Container Registry.
- If you are using Quay.io as the image registry, you must ensure that either the repository is not private, or that you have followed the OpenShift Container Platform documentation on Allowing pods to reference images from other secured registries.
- If you are using the OpenShift Container Registry, a cluster administrator must expose the registry.
6.1.2. Setting up Podman
					To use advanced container management features, you might want to use Podman with OpenShift Serverless Functions. To do so, you need to start the Podman service and configure the Knative (kn) CLI to connect to it.
				
Procedure
- Start the Podman service that serves the Docker API on a UNIX socket at - ${XDG_RUNTIME_DIR}/podman/podman.sock:- systemctl start --user podman.socket - $ systemctl start --user podman.socket- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- On most systems, this socket is located at - /run/user/$(id -u)/podman/podman.sock.
- Establish the environment variable that is used to build a function: - export DOCKER_HOST="unix://${XDG_RUNTIME_DIR}/podman/podman.sock"- $ export DOCKER_HOST="unix://${XDG_RUNTIME_DIR}/podman/podman.sock"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the build command inside your function project directory with the - -vflag to see verbose output. You should see a connection to your local UNIX socket:- kn func build -v - $ kn func build -v- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.1.3. Setting up Podman on macOS
					To use advanced container management features, you might want to use Podman with OpenShift Serverless Functions. To do so on macOS, you need to start the Podman machine and configure the Knative (kn) CLI to connect to it.
				
Procedure
- Create the Podman machine: - podman machine init --memory=8192 --cpus=2 --disk-size=20 - $ podman machine init --memory=8192 --cpus=2 --disk-size=20- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Start the Podman machine, which serves the Docker API on a UNIX socket: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- On most macOS systems, this socket is located at - /Users/myuser/.local/share/containers/podman/machine/podman-machine-default/podman.sock.
- Establish the environment variable that is used to build a function: - export DOCKER_HOST='unix:///Users/myuser/.local/share/containers/podman/machine/podman-machine-default/podman.sock' - $ export DOCKER_HOST='unix:///Users/myuser/.local/share/containers/podman/machine/podman-machine-default/podman.sock'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the build command inside your function project directory with the - -vflag to see verbose output. You should see a connection to your local UNIX socket:- kn func build -v - $ kn func build -v- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.1.4. Next steps
- For more information about Docker Container Engine or Podman, see Container build tool options.
- See Getting started with functions.
6.2. Getting started with functions
				Function lifecycle management includes creating, building, and deploying a function. Optionally, you can also test a deployed function by invoking it. You can do all of these operations on OpenShift Serverless using the kn func tool.
			
6.2.1. Prerequisites
Before you can complete the following procedures, you must ensure that you have completed all of the prerequisite tasks in Setting up OpenShift Serverless Functions.
6.2.2. Creating functions
					Before you can build and deploy a function, you must create it by using the Knative (kn) CLI. You can specify the path, runtime, template, and image registry as flags on the command line, or use the -c flag to start the interactive experience in the terminal.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
Procedure
- Create a function project: - kn func create -r <repository> -l <runtime> -t <template> <path> - $ kn func create -r <repository> -l <runtime> -t <template> <path>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
									Accepted runtime values include quarkus,node,typescript,go,python,springboot, andrust.
- Accepted template values include - httpand- cloudevents.- Example command - kn func create -l typescript -t cloudevents examplefunc - $ kn func create -l typescript -t cloudevents examplefunc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Created typescript function in /home/user/demo/examplefunc - Created typescript function in /home/user/demo/examplefunc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Alternatively, you can specify a repository that contains a custom template. - Example command - kn func create -r https://github.com/boson-project/templates/ -l node -t hello-world examplefunc - $ kn func create -r https://github.com/boson-project/templates/ -l node -t hello-world examplefunc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Created node function in /home/user/demo/examplefunc - Created node function in /home/user/demo/examplefunc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
									Accepted runtime values include 
6.2.3. Running a function locally
					You can use the kn func run command to run a function locally in the current directory or in the directory specified by the --path flag. If the function that you are running has never previously been built, or if the project files have been modified since the last time it was built, the kn func run command builds the function before running it by default.
				
Example command to run a function in the current directory
kn func run
$ kn func runExample command to run a function in a directory specified as a path
kn func run --path=<directory_path>
$ kn func run --path=<directory_path>
					You can also force a rebuild of an existing image before running the function, even if there have been no changes to the project files, by using the --build flag:
				
Example run command using the build flag
kn func run --build
$ kn func run --build
					If you set the build flag as false, this disables building of the image, and runs the function using the previously built image:
				
Example run command using the build flag
kn func run --build=false
$ kn func run --build=false
					You can use the help command to learn more about kn func run command options:
				
Build help command
kn func help run
$ kn func help run6.2.4. Building functions
					Before you can run a function, you must build the function project. If you are using the kn func run command, the function is built automatically. However, you can use the kn func build command to build a function without running it, which can be useful for advanced users or debugging scenarios.
				
					The kn func build command creates an OCI container image that can be run locally on your computer or on an OpenShift Container Platform cluster. This command uses the function project name and the image registry name to construct a fully qualified image name for your function.
				
6.2.4.1. Image container types
						By default, kn func build creates a container image by using Red Hat Source-to-Image (S2I) technology.
					
Example build command using Red Hat Source-to-Image (S2I)
kn func build
$ kn func build6.2.4.2. Image registry types
The OpenShift Container Registry is used by default as the image registry for storing function images.
Example build command using OpenShift Container Registry
kn func build
$ kn func buildExample output
Building function image Function image has been built, image: registry.redhat.io/example/example-function:latest
Building function image
Function image has been built, image: registry.redhat.io/example/example-function:latest
						You can override using OpenShift Container Registry as the default image registry by using the --registry flag:
					
Example build command overriding OpenShift Container Registry to use quay.io
kn func build --registry quay.io/username
$ kn func build --registry quay.io/usernameExample output
Building function image Function image has been built, image: quay.io/username/example-function:latest
Building function image
Function image has been built, image: quay.io/username/example-function:latest6.2.4.3. Push flag
						You can add the --push flag to a kn func build command to automatically push the function image after it is successfully built:
					
Example build command using OpenShift Container Registry
kn func build --push
$ kn func build --push6.2.4.4. Help command
						You can use the help command to learn more about kn func build command options:
					
Build help command
kn func help build
$ kn func help build6.2.5. Deploying functions
					You can deploy a function to your cluster as a Knative service by using the kn func deploy command. If the targeted function is already deployed, it is updated with a new container image that is pushed to a container image registry, and the Knative service is updated.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
- You must have already created and initialized the function that you want to deploy.
Procedure
- Deploy a function: - kn func deploy [-n <namespace> -p <path> -i <image>] - $ kn func deploy [-n <namespace> -p <path> -i <image>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Function deployed at: http://func.example.com - Function deployed at: http://func.example.com- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
									If no namespaceis specified, the function is deployed in the current namespace.
- 
									The function is deployed from the current directory, unless a pathis specified.
- The Knative service name is derived from the project name, and cannot be changed using this command.
 
- 
									If no 
6.2.6. Invoking a deployed function with a test event
					You can use the kn func invoke CLI command to send a test request to invoke a function either locally or on your OpenShift Container Platform cluster. You can use this command to test that a function is working and able to receive events correctly. Invoking a function locally is useful for a quick test during function development. Invoking a function on the cluster is useful for testing that is closer to the production environment.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
- You must have already deployed the function that you want to invoke.
Procedure
- Invoke a function: - kn func invoke - $ kn func invoke- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
									The kn func invokecommand only works when there is either a local container image currently running, or when there is a function deployed in the cluster.
- 
									The kn func invokecommand executes on the local directory by default, and assumes that this directory is a function project.
 
- 
									The 
6.2.7. Deleting a function
					You can delete a function by using the kn func delete command. This is useful when a function is no longer required, and can help to save resources on your cluster.
				
Procedure
- Delete a function: - kn func delete [<function_name> -n <namespace> -p <path>] - $ kn func delete [<function_name> -n <namespace> -p <path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
									If the name or path of the function to delete is not specified, the current directory is searched for a func.yamlfile that is used to determine the function to delete.
- 
									If the namespace is not specified, it defaults to the namespacevalue in thefunc.yamlfile.
 
- 
									If the name or path of the function to delete is not specified, the current directory is searched for a 
6.2.9. Next steps
6.3. On-cluster function building and deploying
Instead of building a function locally, you can build a function directly on the cluster. When using this workflow on a local development machine, you only need to work with the function source code. This is useful, for example, when you cannot install on-cluster function building tools, such as docker or podman.
6.3.1. Building and deploying functions on the cluster
					You can use the Knative (kn) CLI to initiate a function project build and then deploy the function directly on the cluster. To build a function project in this way, the source code for your function project must exist in a Git repository branch that is accessible to your cluster.
				
Prerequisites
- Red Hat OpenShift Pipelines must be installed on your cluster.
- 
							You have installed the OpenShift CLI (oc).
- 
							You have installed the Knative (kn) CLI.
Procedure
- In each namespace where you want to run Pipelines and deploy a function, you must create the following resources: - Create the - s2iTekton task to be able to use Source-to-Image in the pipeline:- oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-s2i/0.1/func-s2i.yaml - $ oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-s2i/0.1/func-s2i.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - kn funcdeploy Tekton task to be able to deploy the function in the pipeline:- oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-deploy/0.1/func-deploy.yaml - $ oc apply -f https://raw.githubusercontent.com/openshift-knative/kn-plugin-func/serverless-1.28.0/pipelines/resources/tekton/task/func-deploy/0.1/func-deploy.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a function: - kn func create <function_name> -l <runtime> - $ kn func create <function_name> -l <runtime>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							After you have created a new function project, you must add the project to a Git repository and ensure that the repository is available to the cluster. Information about this Git repository is used to update the func.yamlfile in the next step.
- Update the configuration in the - func.yamlfile for your function project to enable on-cluster builds for the Git repository:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Implement the business logic of your function. Then, use Git to commit and push the changes.
- Deploy your function: - kn func deploy --remote - $ kn func deploy --remote- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you are not logged into the container registry referenced in your function configuration, you are prompted to provide credentials for the remote container registry that hosts the function image: - Example output and prompts - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							To update your function, commit and push new changes by using Git, then run the kn func deploy --remotecommand again.
6.3.2. Specifying function revision
					When building and deploying a function on the cluster, you must specify the location of the function code by specifying the Git repository, branch, and subdirectory within the repository. You do not need to specify the branch if you use the main branch. Similarly, you do not need to specify the subdirectory if your function is at the root of the repository. You can specify these parameters in the func.yaml configuration file, or by using flags with the kn func deploy command.
				
Prerequisites
- Red Hat OpenShift Pipelines must be installed on your cluster.
- 
							You have installed the OpenShift (oc) CLI.
- 
							You have installed the Knative (kn) CLI.
Procedure
- Deploy your function: - kn func deploy --remote \ --git-url <repo-url> \ [--git-branch <branch>] \ [--git-dir <function-dir>]- $ kn func deploy --remote \- 1 - --git-url <repo-url> \- 2 - [--git-branch <branch>] \- 3 - [--git-dir <function-dir>]- 4 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- With the--remoteflag, the build runs remotely.
- 2
- Substitute<repo-url>with the URL of the Git repository.
- 3
- Substitute<branch>with the Git branch, tag, or commit. If using the latest commit on themainbranch, you can skip this flag.
- 4
- Substitute<function-dir>with the directory containing the function if it is different than the repository root directory.
 - For example: - kn func deploy --remote \ --git-url https://example.com/alice/myfunc.git \ --git-branch my-feature \ --git-dir functions/example-func/- $ kn func deploy --remote \ --git-url https://example.com/alice/myfunc.git \ --git-branch my-feature \ --git-dir functions/example-func/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.4. Developing Quarkus functions
After you have created a Quarkus function project, you can modify the template files provided to add business logic to your function. This includes configuring function invocation and the returned headers and status codes.
6.4.1. Prerequisites
- Before you can develop functions, you must complete the setup steps in Setting up OpenShift Serverless Functions.
6.4.2. Quarkus function template structure
					When you create a Quarkus function by using the Knative (kn) CLI, the project directory looks similar to a typical Maven project. Additionally, the project contains the func.yaml file, which is used for configuring the function.
				
					Both http and event trigger functions have the same template structure:
				
Template structure
- 1
- Used to determine the image name and registry.
- 2
- The Project Object Model (POM) file contains project configuration, such as information about dependencies. You can add additional dependencies by modifying this file.Example of additional dependencies Copy to Clipboard Copied! Toggle word wrap Toggle overflow Dependencies are downloaded during the first compilation. 
- 3
- The function project must contain a Java method annotated with@Funq. You can place this method in theFunction.javaclass.
- 4
- Contains simple test cases that can be used to test your function locally.
6.4.3. About invoking Quarkus functions
You can create a Quarkus project that responds to cloud events, or one that responds to simple HTTP requests. Cloud events in Knative are transported over HTTP as a POST request, so either function type can listen and respond to incoming HTTP requests.
When an incoming request is received, Quarkus functions are invoked with an instance of a permitted type.
| Invocation method | Data type contained in the instance | Example of data | 
|---|---|---|
| HTTP POST request | JSON object in the body of the request | 
									 | 
| HTTP GET request | Data in the query string | 
									 | 
| 
									 | 
									JSON object in the  | 
									 | 
					The following example shows a function that receives and processes the customerId and productId purchase data that is listed in the previous table:
				
Example Quarkus function
					The corresponding Purchase JavaBean class that contains the purchase data looks as follows:
				
Example class
public class Purchase {
    private long customerId;
    private long productId;
    // getters and setters
}
public class Purchase {
    private long customerId;
    private long productId;
    // getters and setters
}6.4.3.1. Invocation examples
						The following example code defines three functions named withBeans, withCloudEvent, and withBinary;
					
Example
						The withBeans function of the Functions class can be invoked by:
					
- An HTTP POST request with a JSON body: - curl "http://localhost:8080/withBeans" -X POST \ -H "Content-Type: application/json" \ -d '{"message": "Hello there."}'- $ curl "http://localhost:8080/withBeans" -X POST \ -H "Content-Type: application/json" \ -d '{"message": "Hello there."}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- An HTTP GET request with query parameters: - curl "http://localhost:8080/withBeans?message=Hello%20there." -X GET - $ curl "http://localhost:8080/withBeans?message=Hello%20there." -X GET- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- A - CloudEventobject in binary encoding:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- A - CloudEventobject in structured encoding:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
						The withCloudEvent function of the Functions class can be invoked by using a CloudEvent object, similarly to the withBeans function. However, unlike withBeans, withCloudEvent cannot be invoked with a plain HTTP request.
					
						The withBinary function of the Functions class can be invoked by:
					
- A - CloudEventobject in binary encoding:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- A - CloudEventobject in structured encoding:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.4.4. CloudEvent attributes
					If you need to read or write the attributes of a CloudEvent, such as type or subject, you can use the CloudEvent<T> generic interface and the CloudEventBuilder builder. The <T> type parameter must be one of the permitted types.
				
					In the following example, CloudEventBuilder is used to return success or failure of processing the purchase:
				
6.4.5. Quarkus function return values
					Functions can return an instance of any type from the list of permitted types. Alternatively, they can return the Uni<T> type, where the <T> type parameter can be of any type from the permitted types.
				
					The Uni<T> type is useful if a function calls asynchronous APIs, because the returned object is serialized in the same format as the received object. For example:
				
- If a function receives an HTTP request, then the returned object is sent in the body of an HTTP response.
- 
							If a function receives a CloudEventobject in binary encoding, then the returned object is sent in the data property of a binary-encodedCloudEventobject.
The following example shows a function that fetches a list of purchases:
Example command
- Invoking this function through an HTTP request produces an HTTP response that contains a list of purchases in the body of the response.
- 
							Invoking this function through an incoming CloudEventobject produces aCloudEventresponse with a list of purchases in thedataproperty.
6.4.5.1. Permitted types
						The input and output of a function can be any of the void, String, or byte[] types. Additionally, they can be primitive types and their wrappers, for example, int and Integer. They can also be the following complex objects: Javabeans, maps, lists, arrays, and the special CloudEvents<T> type.
					
						Maps, lists, arrays, the <T> type parameter of the CloudEvents<T> type, and attributes of Javabeans can only be of types listed here.
					
Example
6.4.6. Testing Quarkus functions
					Quarkus functions can be tested locally on your computer. In the default project that is created when you create a function using kn func create, there is the src/test/ directory, which contains basic Maven tests. These tests can be extended as needed.
				
Prerequisites
- You have created a Quarkus function.
- 
							You have installed the Knative (kn) CLI.
Procedure
- Navigate to the project folder for your function.
- Run the Maven tests: - ./mvnw test - $ ./mvnw test- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.4.7. Next steps
6.5. Developing Node.js functions
After you have created a Node.js function project, you can modify the template files provided to add business logic to your function. This includes configuring function invocation and the returned headers and status codes.
6.5.1. Prerequisites
- Before you can develop functions, you must complete the steps in Setting up OpenShift Serverless Functions.
6.5.2. Node.js function template structure
					When you create a Node.js function using the Knative (kn) CLI, the project directory looks like a typical Node.js project. The only exception is the additional func.yaml file, which is used to configure the function.
				
					Both http and event trigger functions have the same template structure:
				
Template structure
- 1
- Thefunc.yamlconfiguration file is used to determine the image name and registry.
- 2
- Your project must contain anindex.jsfile which exports a single function.
- 3
- You are not restricted to the dependencies provided in the templatepackage.jsonfile. You can add additional dependencies as you would in any other Node.js project.Example of adding npm dependencies npm install --save opossum npm install --save opossumCopy to Clipboard Copied! Toggle word wrap Toggle overflow When the project is built for deployment, these dependencies are included in the created runtime container image. 
- 4
- Integration and unit test scripts are provided as part of the function template.
6.5.3. About invoking Node.js functions
					When using the Knative (kn) CLI to create a function project, you can generate a project that responds to CloudEvents, or one that responds to simple HTTP requests. CloudEvents in Knative are transported over HTTP as a POST request, so both function types listen for and respond to incoming HTTP events.
				
					Node.js functions can be invoked with a simple HTTP request. When an incoming request is received, functions are invoked with a context object as the first parameter.
				
6.5.3.1. Node.js context objects
						Functions are invoked by providing a context object as the first parameter. This object provides access to the incoming HTTP request information.
					
Example context object
function handle(context, data)
function handle(context, data)
						This information includes the HTTP request method, any query strings or headers sent with the request, the HTTP version, and the request body. Incoming requests that contain a CloudEvent attach the incoming instance of the CloudEvent to the context object so that it can be accessed by using context.cloudevent.
					
6.5.3.1.1. Context object methods
							The context object has a single method, cloudEventResponse(), that accepts a data value and returns a CloudEvent.
						
In a Knative system, if a function deployed as a service is invoked by an event broker sending a CloudEvent, the broker examines the response. If the response is a CloudEvent, this event is handled by the broker.
Example context object method
6.5.3.1.2. CloudEvent data
If the incoming request is a CloudEvent, any data associated with the CloudEvent is extracted from the event and provided as a second parameter. For example, if a CloudEvent is received that contains a JSON string in its data property that is similar to the following:
{
  "customerId": "0123456",
  "productId": "6543210"
}
{
  "customerId": "0123456",
  "productId": "6543210"
}
							When invoked, the second parameter to the function, after the context object, will be a JavaScript object that has customerId and productId properties.
						
Example signature
function handle(context, data)
function handle(context, data)
							The data parameter in this example is a JavaScript object that contains the customerId and productId properties.
						
6.5.4. Node.js function return values
					Functions can return any valid JavaScript type or can have no return value. When a function has no return value specified, and no failure is indicated, the caller receives a 204 No Content response.
				
					Functions can also return a CloudEvent or a Message object in order to push events into the Knative Eventing system. In this case, the developer is not required to understand or implement the CloudEvent messaging specification. Headers and other relevant information from the returned values are extracted and sent with the response.
				
Example
6.5.4.1. Returning headers
						You can set a response header by adding a headers property to the return object. These headers are extracted and sent with the response to the caller.
					
Example response header
function handle(context, customer) {
  // process customer and return custom headers
  // the response will be '204 No content'
  return { headers: { customerid: customer.id } };
}
function handle(context, customer) {
  // process customer and return custom headers
  // the response will be '204 No content'
  return { headers: { customerid: customer.id } };
}6.5.4.2. Returning status codes
						You can set a status code that is returned to the caller by adding a statusCode property to the return object:
					
Example status code
Status codes can also be set for errors that are created and thrown by the function:
Example error status code
6.5.5. Testing Node.js functions
					Node.js functions can be tested locally on your computer. In the default project that is created when you create a function by using kn func create, there is a test folder that contains some simple unit and integration tests.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- 
							You have created a function by using kn func create.
Procedure
- Navigate to the test folder for your function.
- Run the tests: - npm test - $ npm test- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.5.6. Next steps
- See the Node.js context object reference documentation.
- Build and deploy a function.
6.6. Developing TypeScript functions
After you have created a TypeScript function project, you can modify the template files provided to add business logic to your function. This includes configuring function invocation and the returned headers and status codes.
6.6.1. Prerequisites
- Before you can develop functions, you must complete the steps in Setting up OpenShift Serverless Functions.
6.6.2. TypeScript function template structure
					When you create a TypeScript function using the Knative (kn) CLI, the project directory looks like a typical TypeScript project. The only exception is the additional func.yaml file, which is used for configuring the function.
				
					Both http and event trigger functions have the same template structure:
				
Template structure
- 1
- Thefunc.yamlconfiguration file is used to determine the image name and registry.
- 2
- You are not restricted to the dependencies provided in the templatepackage.jsonfile. You can add additional dependencies as you would in any other TypeScript project.Example of adding npm dependencies npm install --save opossum npm install --save opossumCopy to Clipboard Copied! Toggle word wrap Toggle overflow When the project is built for deployment, these dependencies are included in the created runtime container image. 
- 3
- Your project must contain ansrc/index.jsfile which exports a function namedhandle.
- 4
- Integration and unit test scripts are provided as part of the function template.
6.6.3. About invoking TypeScript functions
					When using the Knative (kn) CLI to create a function project, you can generate a project that responds to CloudEvents or one that responds to simple HTTP requests. CloudEvents in Knative are transported over HTTP as a POST request, so both function types listen for and respond to incoming HTTP events.
				
					TypeScript functions can be invoked with a simple HTTP request. When an incoming request is received, functions are invoked with a context object as the first parameter.
				
6.6.3.1. TypeScript context objects
						To invoke a function, you provide a context object as the first parameter. Accessing properties of the context object can provide information about the incoming HTTP request.
					
Example context object
function handle(context:Context): string
function handle(context:Context): string
						This information includes the HTTP request method, any query strings or headers sent with the request, the HTTP version, and the request body. Incoming requests that contain a CloudEvent attach the incoming instance of the CloudEvent to the context object so that it can be accessed by using context.cloudevent.
					
6.6.3.1.1. Context object methods
							The context object has a single method, cloudEventResponse(), that accepts a data value and returns a CloudEvent.
						
In a Knative system, if a function deployed as a service is invoked by an event broker sending a CloudEvent, the broker examines the response. If the response is a CloudEvent, this event is handled by the broker.
Example context object method
6.6.3.1.2. Context types
The TypeScript type definition files export the following types for use in your functions.
Exported type definitions
6.6.3.1.3. CloudEvent data
If the incoming request is a CloudEvent, any data associated with the CloudEvent is extracted from the event and provided as a second parameter. For example, if a CloudEvent is received that contains a JSON string in its data property that is similar to the following:
{
  "customerId": "0123456",
  "productId": "6543210"
}
{
  "customerId": "0123456",
  "productId": "6543210"
}
							When invoked, the second parameter to the function, after the context object, will be a JavaScript object that has customerId and productId properties.
						
Example signature
function handle(context: Context, cloudevent?: CloudEvent): CloudEvent
function handle(context: Context, cloudevent?: CloudEvent): CloudEvent
							The cloudevent parameter in this example is a JavaScript object that contains the customerId and productId properties.
						
6.6.4. TypeScript function return values
					Functions can return any valid JavaScript type or can have no return value. When a function has no return value specified, and no failure is indicated, the caller receives a 204 No Content response.
				
					Functions can also return a CloudEvent or a Message object in order to push events into the Knative Eventing system. In this case, the developer is not required to understand or implement the CloudEvent messaging specification. Headers and other relevant information from the returned values are extracted and sent with the response.
				
Example
6.6.4.1. Returning headers
						You can set a response header by adding a headers property to the return object. These headers are extracted and sent with the response to the caller.
					
Example response header
export function handle(context: Context, cloudevent?: CloudEvent): Record<string, any> {
  // process customer and return custom headers
  const customer = cloudevent.data as Record<string, any>;
  return { headers: { 'customer-id': customer.id } };
}
export function handle(context: Context, cloudevent?: CloudEvent): Record<string, any> {
  // process customer and return custom headers
  const customer = cloudevent.data as Record<string, any>;
  return { headers: { 'customer-id': customer.id } };
}6.6.4.2. Returning status codes
						You can set a status code that is returned to the caller by adding a statusCode property to the return object:
					
Example status code
Status codes can also be set for errors that are created and thrown by the function:
Example error status code
6.6.5. Testing TypeScript functions
					TypeScript functions can be tested locally on your computer. In the default project that is created when you create a function using kn func create, there is a test folder that contains some simple unit and integration tests.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- 
							You have created a function by using kn func create.
Procedure
- If you have not previously run tests, install the dependencies first: - npm install - $ npm install- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Navigate to the test folder for your function.
- Run the tests: - npm test - $ npm test- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.6.6. Next steps
- See the TypeScript context object reference documentation.
- Build and deploy a function.
- See the Pino API documentation for more information about logging with functions.
6.7. Developing Python functions
OpenShift Serverless Functions with Python is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
After you have created a Python function project, you can modify the template files provided to add business logic to your function. This includes configuring function invocation and the returned headers and status codes.
6.7.1. Prerequisites
- Before you can develop functions, you must complete the steps in Setting up OpenShift Serverless Functions.
6.7.2. Python function template structure
					When you create a Python function by using the Knative (kn) CLI, the project directory looks similar to a typical Python project. Python functions have very few restrictions. The only requirements are that your project contains a func.py file that contains a main() function, and a func.yaml configuration file.
				
					Developers are not restricted to the dependencies provided in the template requirements.txt file. Additional dependencies can be added as they would be in any other Python project. When the project is built for deployment, these dependencies will be included in the created runtime container image.
				
					Both http and event trigger functions have the same template structure:
				
Template structure
fn ├── func.py ├── func.yaml ├── requirements.txt └── test_func.py
fn
├── func.py 
├── func.yaml 
├── requirements.txt 
└── test_func.py 6.7.3. About invoking Python functions
					Python functions can be invoked with a simple HTTP request. When an incoming request is received, functions are invoked with a context object as the first parameter.
				
					The context object is a Python class with two attributes:
				
- 
							The requestattribute is always present, and contains the Flaskrequestobject.
- 
							The second attribute, cloud_event, is populated if the incoming request is aCloudEventobject.
					Developers can access any CloudEvent data from the context object.
				
Example context object
6.7.4. Python function return values
Functions can return any value supported by Flask. This is because the invocation framework proxies these values directly to the Flask server.
Example
def main(context: Context):
    body = { "message": "Howdy!" }
    headers = { "content-type": "application/json" }
    return body, 200, headers
def main(context: Context):
    body = { "message": "Howdy!" }
    headers = { "content-type": "application/json" }
    return body, 200, headersFunctions can set both headers and response codes as secondary and tertiary response values from function invocation.
6.7.4.1. Returning CloudEvents
						Developers can use the @event decorator to tell the invoker that the function return value must be converted to a CloudEvent before sending the response.
					
Example
						This example sends a CloudEvent as the response value, with a type of "my.type" and a source of "/my/function". The CloudEvent data property is set to the returned data variable. The event_source and event_type decorator attributes are both optional.
					
6.7.5. Testing Python functions
					You can test Python functions locally on your computer. The default project contains a test_func.py file, which provides a simple unit test for functions.
				
						The default test framework for Python functions is unittest. You can use a different test framework if you prefer.
					
Prerequisites
- To run Python functions tests locally, you must install the required dependencies: - pip install -r requirements.txt - $ pip install -r requirements.txt- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- 
							Navigate to the folder for your function that contains the test_func.pyfile.
- Run the tests: - python3 test_func.py - $ python3 test_func.py- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.7.6. Next steps
6.8. Using functions with Knative Eventing
Functions are deployed as Knative services on an OpenShift Container Platform cluster. You can connect functions to Knative Eventing components so that they can receive incoming events.
6.8.1. Connect an event source to a function using the Developer perspective
Functions are deployed as Knative services on an OpenShift Container Platform cluster. When you create an event source by using the OpenShift Container Platform web console, you can specify a deployed function that events are sent to from that source.
Prerequisites
- The OpenShift Serverless Operator, Knative Serving, and Knative Eventing are installed on your OpenShift Container Platform cluster.
- You have logged in to the web console and are in the Developer perspective.
- You have created a project or have access to a project with the appropriate roles and permissions to create applications and other workloads in OpenShift Container Platform.
- You have created and deployed a function.
Procedure
- 
							Create an event source of any type, by navigating to +Add Event Source and selecting the event source type that you want to create. 
- In the Sink section of the Create Event Source form view, select your function in the Resource list.
- Click Create.
Verification
You can verify that the event source was created and is connected to the function by viewing the Topology page.
- In the Developer perspective, navigate to Topology.
- View the event source and click the connected function to see the function details in the right panel.
6.9. Function project configuration in func.yaml
				The func.yaml file contains the configuration for your function project. Values specified in func.yaml are used when you execute a kn func command. For example, when you run the kn func build command, the value in the build field is used. In some cases, you can override these values with command line flags or environment variables.
			
6.9.1. Configurable fields in func.yaml
					Many of the fields in func.yaml are generated automatically when you create, build, and deploy your function. However, there are also fields that you modify manually to change things, such as the function name or the image name.
				
6.9.1.1. buildEnvs
						The buildEnvs field enables you to set environment variables to be available to the environment that builds your function. Unlike variables set using envs, a variable set using buildEnv is not available during function runtime.
					
						You can set a buildEnv variable directly from a value. In the following example, the buildEnv variable named EXAMPLE1 is directly assigned the one value:
					
buildEnvs: - name: EXAMPLE1 value: one
buildEnvs:
- name: EXAMPLE1
  value: one
						You can also set a buildEnv variable from a local environment variable. In the following example, the buildEnv variable named EXAMPLE2 is assigned the value of the LOCAL_ENV_VAR local environment variable:
					
buildEnvs:
- name: EXAMPLE1
  value: '{{ env:LOCAL_ENV_VAR }}'
buildEnvs:
- name: EXAMPLE1
  value: '{{ env:LOCAL_ENV_VAR }}'6.9.1.2. envs
						The envs field enables you to set environment variables to be available to your function at runtime. You can set an environment variable in several different ways:
					
- Directly from a value.
- From a value assigned to a local environment variable. See the section "Referencing local environment variables from func.yaml fields" for more information.
- From a key-value pair stored in a secret or config map.
- You can also import all key-value pairs stored in a secret or config map, with keys used as names of the created environment variables.
This examples demonstrates the different ways to set an environment variable:
- 1
- An environment variable set directly from a value.
- 2
- An environment variable set from a value assigned to a local environment variable.
- 3
- An environment variable assigned from a key-value pair stored in a secret.
- 4
- An environment variable assigned from a key-value pair stored in a config map.
- 5
- A set of environment variables imported from key-value pairs of a secret.
- 6
- A set of environment variables imported from key-value pairs of a config map.
6.9.1.3. builder
						The builder field specifies the strategy used by the function to build the image. It accepts values of pack or s2i.
					
6.9.1.4. build
						The build field indicates how the function should be built. The value local indicates that the function is built locally on your machine. The value git indicates that the function is built on a cluster by using the values specified in the git field.
					
6.9.1.5. volumes
						The volumes field enables you to mount secrets and config maps as a volume accessible to the function at the specified path, as shown in the following example:
					
6.9.1.6. options
						The options field enables you to modify Knative Service properties for the deployed function, such as autoscaling. If these options are not set, the default ones are used.
					
These options are available:
- scale- 
										min: The minimum number of replicas. Must be a non-negative integer. The default is 0.
- 
										max: The maximum number of replicas. Must be a non-negative integer. The default is 0, which means no limit.
- 
										metric: Defines which metric type is watched by the Autoscaler. It can be set toconcurrency, which is the default, orrps.
- 
										target: Recommendation for when to scale up based on the number of concurrently incoming requests. Thetargetoption can be a float value greater than 0.01. The default is 100, unless theoptions.resources.limits.concurrencyis set, in which casetargetdefaults to its value.
- 
										utilization: Percentage of concurrent requests utilization allowed before scaling up. It can be a float value between 1 and 100. The default is 70.
 
- 
										
- resources- requests- 
												cpu: A CPU resource request for the container with deployed function.
- 
												memory: A memory resource request for the container with deployed function.
 
- 
												
- limits- 
												cpu: A CPU resource limit for the container with deployed function.
- 
												memory: A memory resource limit for the container with deployed function.
- 
												concurrency: Hard Limit of concurrent requests to be processed by a single replica. It can be integer value greater than or equal to 0, default is 0 - meaning no limit.
 
- 
												
 
						This is an example configuration of the scale options:
					
6.9.1.7. image
						The image field sets the image name for your function after it has been built. You can modify this field. If you do, the next time you run kn func build or kn func deploy, the function image will be created with the new name.
					
6.9.1.8. imageDigest
						The imageDigest field contains the SHA256 hash of the image manifest when the function is deployed. Do not modify this value.
					
6.9.1.9. labels
						The labels field enables you to set labels on a deployed function.
					
						You can set a label directly from a value. In the following example, the label with the role key is directly assigned the value of backend:
					
labels: - key: role value: backend
labels:
- key: role
  value: backend
						You can also set a label from a local environment variable. In the following example, the label with the author key is assigned the value of the USER local environment variable:
					
labels:
- key: author
  value: '{{ env:USER }}'
labels:
- key: author
  value: '{{ env:USER }}'6.9.1.10. name
						The name field defines the name of your function. This value is used as the name of your Knative service when it is deployed. You can change this field to rename the function on subsequent deployments.
					
6.9.1.11. namespace
						The namespace field specifies the namespace in which your function is deployed.
					
6.9.1.12. runtime
						The runtime field specifies the language runtime for your function, for example, python.
					
6.9.2. Referencing local environment variables from func.yaml fields
					If you want to avoid storing sensitive information such as an API key in the function configuration, you can add a reference to an environment variable available in the local environment. You can do this by modifying the envs field in the func.yaml file.
				
Prerequisites
- You need to have the function project created.
- The local environment needs to contain the variable that you want to reference.
Procedure
- To refer to a local environment variable, use the following syntax: - {{ env:ENV_VAR }}- {{ env:ENV_VAR }}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Substitute - ENV_VARwith the name of the variable in the local environment that you want to use.- For example, you might have the - API_KEYvariable available in the local environment. You can assign its value to the- MY_API_KEYvariable, which you can then directly use within your function:- Example function - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.10. Accessing secrets and config maps from functions
After your functions have been deployed to the cluster, they can access data stored in secrets and config maps. This data can be mounted as volumes, or assigned to environment variables. You can configure this access interactively by using the Knative CLI, or by manually by editing the function configuration YAML file.
To access secrets and config maps, the function must be deployed on the cluster. This functionality is not available to a function running locally.
If a secret or config map value cannot be accessed, the deployment fails with an error message specifying the inaccessible values.
6.10.1. Modifying function access to secrets and config maps interactively
					You can manage the secrets and config maps accessed by your function by using the kn func config interactive utility. The available operations include listing, adding, and removing values stored in config maps and secrets as environment variables, as well as listing, adding, and removing volumes. This functionality enables you to manage what data stored on the cluster is accessible by your function.
				
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- Run the following command in the function project directory: - kn func config - $ kn func config- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Alternatively, you can specify the function project directory using the - --pathor- -poption.
- Use the interactive interface to perform the necessary operation. For example, using the utility to list configured volumes produces an output similar to this: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This scheme shows all operations available in the interactive utility and how to navigate to them: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional. Deploy the function to make the changes take effect: - kn func deploy -p test - $ kn func deploy -p test- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.10.2. Modifying function access to secrets and config maps interactively by using specialized commands
					Every time you run the kn func config utility, you need to navigate the entire dialogue to select the operation you need, as shown in the previous section. To save steps, you can directly execute a specific operation by running a more specific form of the kn func config command:
				
- To list configured environment variables: - kn func config envs [-p <function-project-path>] - $ kn func config envs [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To add environment variables to the function configuration: - kn func config envs add [-p <function-project-path>] - $ kn func config envs add [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To remove environment variables from the function configuration: - kn func config envs remove [-p <function-project-path>] - $ kn func config envs remove [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To list configured volumes: - kn func config volumes [-p <function-project-path>] - $ kn func config volumes [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To add a volume to the function configuration: - kn func config volumes add [-p <function-project-path>] - $ kn func config volumes add [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To remove a volume from the function configuration: - kn func config volumes remove [-p <function-project-path>] - $ kn func config volumes remove [-p <function-project-path>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
6.10.3. Adding function access to secrets and config maps manually
					You can manually add configuration for accessing secrets and config maps to your function. This might be preferable to using the kn func config interactive utility and commands, for example when you have an existing configuration snippet.
				
6.10.3.1. Mounting a secret as a volume
You can mount a secret as a volume. Once a secret is mounted, you can access it from the function as a regular file. This enables you to store on the cluster data needed by the function, for example, a list of URIs that need to be accessed by the function.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For each secret you want to mount as a volume, add the following YAML to the - volumessection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
										Substitute mysecretwith the name of the target secret.
- Substitute - /workspace/secretwith the path where you want to mount the secret.- For example, to mount the - addressessecret, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
										Substitute 
- Save the configuration.
6.10.3.2. Mounting a config map as a volume
You can mount a config map as a volume. Once a config map is mounted, you can access it from the function as a regular file. This enables you to store on the cluster data needed by the function, for example, a list of URIs that need to be accessed by the function.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For each config map you want to mount as a volume, add the following YAML to the - volumessection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
										Substitute myconfigmapwith the name of the target config map.
- Substitute - /workspace/configmapwith the path where you want to mount the config map.- For example, to mount the - addressesconfig map, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
										Substitute 
- Save the configuration.
6.10.3.3. Setting environment variable from a key value defined in a secret
You can set an environment variable from a key value defined as a secret. A value previously stored in a secret can then be accessed as an environment variable by the function at runtime. This can be useful for getting access to a value stored in a secret, such as the ID of a user.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For each value from a secret key-value pair that you want to assign to an environment variable, add the following YAML to the - envssection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
										Substitute EXAMPLEwith the name of the environment variable.
- 
										Substitute mysecretwith the name of the target secret.
- Substitute - keywith the key mapped to the target value.- For example, to access the user ID that is stored in - userdetailssecret, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
										Substitute 
- Save the configuration.
6.10.3.4. Setting environment variable from a key value defined in a config map
You can set an environment variable from a key value defined as a config map. A value previously stored in a config map can then be accessed as an environment variable by the function at runtime. This can be useful for getting access to a value stored in a config map, such as the ID of a user.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For each value from a config map key-value pair that you want to assign to an environment variable, add the following YAML to the - envssection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
										Substitute EXAMPLEwith the name of the environment variable.
- 
										Substitute myconfigmapwith the name of the target config map.
- Substitute - keywith the key mapped to the target value.- For example, to access the user ID that is stored in - userdetailsmap, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
										Substitute 
- Save the configuration.
6.10.3.5. Setting environment variables from all values defined in a secret
You can set an environment variable from all values defined in a secret. Values previously stored in a secret can then be accessed as environment variables by the function at runtime. This can be useful for simultaneously getting access to a collection of values stored in a secret, for example, a set of data pertaining to a user.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For every secret for which you want to import all key-value pairs as environment variables, add the following YAML to the - envssection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Substitutemysecretwith the name of the target secret.
 - For example, to access all user data that is stored in - userdetailssecret, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save the configuration.
6.10.3.6. Setting environment variables from all values defined in a config map
You can set an environment variable from all values defined in a config map. Values previously stored in a config map can then be accessed as environment variables by the function at runtime. This can be useful for simultaneously getting access to a collection of values stored in a config map, for example, a set of data pertaining to a user.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
								You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
								Open the func.yamlfile for your function.
- For every config map for which you want to import all key-value pairs as environment variables, add the following YAML to the - envssection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Substitutemyconfigmapwith the name of the target config map.
 - For example, to access all user data that is stored in - userdetailsmap, use the following YAML:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save the file.
6.11. Adding annotations to functions
				You can add Kubernetes annotations to a deployed Serverless function. Annotations enable you to attach arbitrary metadata to a function, for example, a note about the function’s purpose. Annotations are added to the annotations section of the func.yaml configuration file.
			
There are two limitations of the function annotation feature:
- 
						After a function annotation propagates to the corresponding Knative service on the cluster, it cannot be removed from the service by deleting it from the func.yamlfile. You must remove the annotation from the Knative service by modifying the YAML file of the service directly, or by using the OpenShift Container Platform web console.
- 
						You cannot set annotations that are set by Knative, for example, the autoscalingannotations.
6.11.1. Adding annotations to a function
You can add annotations to a function. Similar to a label, an annotation is defined as a key-value map. Annotations are useful, for example, for providing metadata about a function, such as the function’s author.
Prerequisites
- The OpenShift Serverless Operator and Knative Serving are installed on the cluster.
- 
							You have installed the Knative (kn) CLI.
- You have created a function.
Procedure
- 
							Open the func.yamlfile for your function.
- For every annotation that you want to add, add the following YAML to the - annotationssection:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Substitute<annotation_name>: "<annotation_value>"with your annotation.
 - For example, to indicate that a function was authored by Alice, you might include the following annotation: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save the configuration.
The next time you deploy your function to the cluster, the annotations are added to the corresponding Knative service.
6.12. Functions development reference guide
				OpenShift Serverless Functions provides templates that can be used to create basic functions. A template initiates the function project boilerplate and prepares it for use with the kn func tool. Each function template is tailored for a specific runtime and follows its conventions. With a template, you can initiate your function project automatically.
			
Templates for the following runtimes are available:
6.12.1. Node.js context object reference
					The context object has several properties that can be accessed by the function developer. Accessing these properties can provide information about HTTP requests and write output to the cluster logs.
				
6.12.1.1. log
Provides a logging object that can be used to write output to the cluster logs. The log adheres to the Pino logging API.
Example log
function handle(context) {
  context.log.info(“Processing customer”);
}
function handle(context) {
  context.log.info(“Processing customer”);
}
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.function.com'
$ kn func invoke --target 'http://example.function.com'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"Processing customer"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"Processing customer"}
						You can change the log level to one of fatal, error, warn, info, debug, trace, or silent. To do that, change the value of logLevel by assigning one of these values to the environment variable FUNC_LOG_LEVEL using the config command.
					
6.12.1.2. query
Returns the query string for the request, if any, as key-value pairs. These attributes are also found on the context object itself.
Example query
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.com?name=tiger'
$ kn func invoke --target 'http://example.com?name=tiger'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}6.12.1.3. body
Returns the request body if any. If the request body contains JSON code, this will be parsed so that the attributes are directly available.
Example body
function handle(context) {
  // log the incoming request body's 'hello' parameter
  context.log.info(context.body.hello);
}
function handle(context) {
  // log the incoming request body's 'hello' parameter
  context.log.info(context.body.hello);
}
						You can access the function by using the curl command to invoke it:
					
Example command
kn func invoke -d '{"Hello": "world"}'
$ kn func invoke -d '{"Hello": "world"}'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"world"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"world"}6.12.1.4. headers
Returns the HTTP request headers as an object.
Example header
function handle(context) {
  context.log.info(context.headers["custom-header"]);
}
function handle(context) {
  context.log.info(context.headers["custom-header"]);
}
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.function.com'
$ kn func invoke --target 'http://example.function.com'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"some-value"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"some-value"}6.12.1.5. HTTP requests
- method
- Returns the HTTP request method as a string.
- httpVersion
- Returns the HTTP version as a string.
- httpVersionMajor
- Returns the HTTP major version number as a string.
- httpVersionMinor
- Returns the HTTP minor version number as a string.
6.12.2. TypeScript context object reference
					The context object has several properties that can be accessed by the function developer. Accessing these properties can provide information about incoming HTTP requests and write output to the cluster logs.
				
6.12.2.1. log
Provides a logging object that can be used to write output to the cluster logs. The log adheres to the Pino logging API.
Example log
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.function.com'
$ kn func invoke --target 'http://example.function.com'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"Processing customer"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"Processing customer"}
						You can change the log level to one of fatal, error, warn, info, debug, trace, or silent. To do that, change the value of logLevel by assigning one of these values to the environment variable FUNC_LOG_LEVEL using the config command.
					
6.12.2.2. query
Returns the query string for the request, if any, as key-value pairs. These attributes are also found on the context object itself.
Example query
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.function.com' --data '{"name": "tiger"}'
$ kn func invoke --target 'http://example.function.com' --data '{"name": "tiger"}'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"tiger"}6.12.2.3. body
Returns the request body, if any. If the request body contains JSON code, this will be parsed so that the attributes are directly available.
Example body
						You can access the function by using the kn func invoke command:
					
Example command
kn func invoke --target 'http://example.function.com' --data '{"hello": "world"}'
$ kn func invoke --target 'http://example.function.com' --data '{"hello": "world"}'Example output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"world"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"world"}6.12.2.4. headers
Returns the HTTP request headers as an object.
Example header
						You can access the function by using the curl command to invoke it:
					
Example command
curl -H'x-custom-header: some-value’' http://example.function.com
$ curl -H'x-custom-header: some-value’' http://example.function.comExample output
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"some-value"}
{"level":30,"time":1604511655265,"pid":3430203,"hostname":"localhost.localdomain","reqId":1,"msg":"some-value"}6.12.2.5. HTTP requests
- method
- Returns the HTTP request method as a string.
- httpVersion
- Returns the HTTP version as a string.
- httpVersionMajor
- Returns the HTTP major version number as a string.
- httpVersionMinor
- Returns the HTTP minor version number as a string.