Using a Code Repository to Create a Function with Code Editor

Find out how to use Code Editor to create a new function in OCI Functions based on existing function code in a remote Git repository.

You can use Code Editor to create a function in OCI Functions based on existing function code in a remote Git repository. Having cloned the remote Git repository into a local Git repository, you can then use Code Editor to edit the code in the local Git repository. When you've finished making changes, you can use Code Editor to commit and push the code back to the remote Git repository. With the updates in the remote Git repository, you can then use Code Editor to deploy the function to OCI Functions, and then to invoke the function.

When using Code Editor to create and update functions, note the following:

  • The remote Git repository must contain a valid func.yaml file at the top level.
  • The name of a function you create using Code Editor must match the function name specified in the func.yaml file in the remote code repository. If the names are different, you will be unable to invoke the function.
  • When you deploy a function to OCI Functions, you are fetching the latest commit from the remote Git repository. Uncommitted changes, and commits in the local repository, are ignored. Therefore, before you can deploy a new or updated function to OCI Functions, you must always commit new and modified files to the local Git repository, and then push the changes to the remote Git repository.

This topic explains how to use Code Editor to:

  • create a new function from code in an existing remote Git repository
  • deploy the function to OCI Functions
  • invoke the function
  • optionally, update the function, re-deploy it, and invoke it again

Before you start:

  • You must have completed the steps in the Functions QuickStart on Cloud Shell.
  • To follow the steps in this topic, you must have access to a remote Git repository (for example, in GitHub) containing both the function code and a func.yaml file at the top level in the repository.
  • For convenience and simplicity, the examples in this topic assume you have used the fn init --runtime python helloworld-func-python command to create a simple python helloworld function that you have then pushed to a remote Git repository. If you have created such a python helloworld function and pushed it to a remote Git repository, you can specify that remote Git repository as the code repository when following the instructions. If you're not sure how to create the python helloworld function and push it to a remote Git repository, see Optional Preliminary Steps to Upload A Simple Python helloworld Function Code to a Remote Code Repository.

For more information about Code Editor features and functionality, see Code Editor.

Optional Preliminary Steps to Upload A Simple Python helloworld Function Code to a Remote Code Repository

To populate a remote Git repository with valid func.yaml and source code files for a simple python helloworld function, for use in the Creating a Function From a Code Repository Using Code Editor section later in this topic:

  1. Create a new remote Git repository. For example, in GitHub as https://github.com/jdoe/simple-python-helloworld-repo.
  2. In Cloud Shell, create a temporary directory to contain the python helloworld function. For example, /home/jdoe/temp/python/simple-helloworld
  3. Switch to the directory you just created.
  4. Run fn init --runtime python helloworld-func-python to create a python helloworld function named helloworld-func-python.
  5. Switch to the newly-created helloworld-func-python directory.
  6. Convert the unversioned helloworld-func-python directory into a local Git repository by entering:
    git init
  7. Add the files in the helloworld-func-python directory to the staging area by entering:
    git add .
  8. Store the contents of the staging area in the local Git repository by entering:
    git commit
  9. When prompted, enter a commit message:
    1. Press the i key on your keyboard to insert text.
    2. Enter a commit message. For example:
      Adds simple python hello-world files.
    3. Press the Esc key, then type : w q and then press Enter.
  10. In Cloud Shell, connect the local Git repository to the remote Git repository you created earlier by entering:
    git remote add origin <remote-repository-url>

    For example:

    git remote add origin https://github.com/jdoe/simple-python-helloworld-repo.git
  11. Create a new branch named main in the local Git repository by entering:
    git branch -M main
  12. Push files to the main branch in the remote Git repository by entering:
    git push -u origin main
  13. If prompted, enter the Git username and password for the remote Git repository.

    In the case of GitHub, note that your password is your GitHub Personal Access Token.

You have now uploaded valid func.yaml and source code files for a simple python helloworld function to a remote Git repository, for use in the Creating a Function From a Code Repository Using Code Editor section.

Creating a Function From a Code Repository Using Code Editor

To use Code Editor to create a new function in OCI Functions based on existing function code in a remote Git repository:

  1. Confirm that you have completed the steps in the Functions QuickStart on Cloud Shell to:
    • Set up your tenancy with groups and users, create a compartment in which to create OCI Functions resources, create a VCN and subnets, and create an IAM policy.
    • Set up your Cloud Shell dev environment with the Fn Project CLI context, obtain an auth token, and log in to the Docker registry specified for the Fn Project CLI context.
  2. Sign in to the Console as a functions developer.
  3. Use the Console to create a new application in OCI Functions:

    1. Open the navigation menu  and select Developer Services. Under Functions, select Applications.
    2. Select the region you intend to use for OCI Functions.

      We recommend that you use the same region as the Docker registry specified in the Fn Project CLI context (see Creating an Fn Project CLI Context to Connect to Oracle Cloud Infrastructure).

    3. Select the compartment specified in the Fn Project CLI context (see Creating an Fn Project CLI Context to Connect to Oracle Cloud Infrastructure).

      The Applications page shows the applications already defined in the compartment.

    4. Click Create Application and specify:

    5. Click Create to create the application.
  4. Start Code Editor in either of the following ways:

    • On the Application Details page, under Resources, click Functions. On the Functions page, click the Create Function button, and select Create in Code Editor. This method opens Code Editor at the application you just created.
    • Click the Code Editor button in the Console's toolbar.
  5. Create a new function from a code repository:
    1. In the Code Editor Oracle Cloud Infrastructure panel, navigate to the application you just created in the compartment specified in the Fn Project CLI context. For example, helloworld-python-app.
    2. With the application name highlighted, select Create Function... from the right mouse button menu.
    3. Select the Create from a code repository creation method in the entry field in the Code Editor menu bar.
    4. Enter the function name that is specified in the function's func.yaml file in the remote repository (for example, helloworld-func-python), and press Enter.

      Note that the name of the function you create using Code Editor must match the function name specified in the func.yaml file in the remote code repository. If the names are different, you will be unable to invoke the function later.

    5. Enter the url of the remote repository containing the function code. For example, https://github.com/jdoe/simple-python-helloworld-repo
    6. If prompted, enter the Git username and password for the remote Git repository.

      In the case of GitHub, note that the password is the GitHub Personal Access Token.

      When the remote Git repository has been successfully cloned, a dialog is displayed with the message "Would you like to open the cloned repository, or add it to the current workspace".

    7. Click the X button in the top right-hand corner of the dialog to close the dialog without selecting an option.

      Important: Do not click either the Open button or the Add to Workspace button in the dialog.

    8. Click OK to acknowledge the dialog informing you that changes have to be committed and pushed to a remote branch before the function can be deployed.

      The remote Git repository is cloned into a local Git repository at /home/<username>/oci-ide-plugins/faas-artifacts/<app-ocid>/<function-name>/<repository-name>. For example, /home/jdoe/oci-ide-plugins/faas-artifacts/ocid1.fnapp.oc1.iad.aaaaaa______76nf/helloworld-func-python/simple-python-helloworld-repo.

      If you have based the new function on the python helloworld function in the remote Git repository, the local Git repository directory contains:

      • func.yaml
      • func.py
      • requirments.txt
  6. Deploy the function to OCI Functions:
    1. Open a Code Editor terminal window by selecting New Terminal from the Terminal window in the Code Editor menu bar.
    2. In the Code Editor terminal window, change directory to the newly created directory containing the func.yaml file and the function source files by entering:
      cd /home/<oci-username>/oci-ide-plugins/faas-artifacts/<application-OCID>/<function-name>/<repos-name>

      For example:

      cd /home/jdoe/oci-ide-plugins/faas-artifacts/ocid1.fnapp.oc1.iad.aaaaaa______76nf/helloworld-func-python/simple-python-helloworld-repo
    3. In the Code Editor terminal window, in the directory containing the func.yaml file and the function source files, log in to the Docker registry specified in the Fn Project CLI context. Assuming the Docker registry is Oracle Cloud Infrastructure Registry, use the following command:

      docker login -u '<tenancy-namespace>/<user-name>' <region-key>.ocir.io

      For example:

      docker login -u 'ansh81vru1zp/jdoe@acme.com' phx.ocir.io
    4. When prompted for a password, enter your OCI auth token.
    5. In the Code Editor terminal window, deploy the function to OCI Functions by running:
      fn -v deploy --app <application-name>

      For example:

      fn -v deploy --app helloworld-python-app
  7. Invoke the function you've just deployed:
    1. In the Code Editor terminal window, in the directory containing the func.yaml file and the function source files, invoke the function by running:
      fn invoke <application-name> <function-name>

      For example:

      fn invoke helloworld-python-app helloworld-func-python

      If a message is returned showing the function is not found, one likely cause is a mismatch between the name of the function you created in Code Editor, and the name of the function specified in the func.yaml. Repeat the previous steps to create a function in Code Editor that has the same name as specified in the func.yaml file in the remote Git repository.

      If you have based the new function on the python helloworld function, the following message is displayed:

      {"message": "Hello World"}
  8. (Optional) If you have based the new function on the python helloworld function named helloworld-func-python in the previous steps, this optional step describes how to change the text of the message that is displayed when the function is invoked. You update the message text in the local Git repository, push the update to the remote Git repository, and then deploy and invoke the function.

    1. In the Code Editor's Oracle Cloud Infrastructure panel, under the helloworld-func-python function that you just created, click on the file func.py and change the line:
      {"message": "Hello {0}".format(name)}),
      to read:
      {"message": "Greetings {0}".format(name)}),
    2. In the Code Editor navigator, select the Source Control panel, click the More Actions button, and select Commit from the Commit menu.
    3. When prompted to stage changes, click Yes.
    4. Enter a commit message (for example, Changes-Hello-to-Greetings) and press Enter.
    5. Click the More Actions button, and select Push from the Pull, Push menu
    6. If prompted, enter the Git username and password for the remote Git repository.

      In the case of GitHub, note that the password is the GitHub Personal Access Token.

    7. If a dialog is displayed with the message "Would you like Code Editor to periodically run 'git fetch'?", click Ask Me Later.
    8. In the Code Editor terminal window, in the directory containing the func.yaml file and the function source files, deploy the function by entering:

      fn -v deploy --app <application-name>

      For example:

      fn -v deploy --app helloworld-python-app
    9. In the Code Editor terminal window, invoke the function by entering:
      fn invoke <application-name> <function-name>

      For example:

      fn invoke helloworld-python-app helloworld-func-python

      The following message is displayed:

      {"message": "Greetings World"}

    The updated message confirms you have successfully modified function source code in the local Git repository, pushed the update to the remote Git repository, and then deployed and invoked the function.