From bbdc525999c8a74e355bc8a694ef7686f1daa028 Mon Sep 17 00:00:00 2001 From: Damjan Dimitrov Date: Tue, 22 Oct 2024 14:29:19 +0200 Subject: [PATCH 1/2] Update endpoint URLs --- build/11-cloud-functions-api.md | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/build/11-cloud-functions-api.md b/build/11-cloud-functions-api.md index 40486263..7c5360e8 100644 --- a/build/11-cloud-functions-api.md +++ b/build/11-cloud-functions-api.md @@ -6,7 +6,7 @@ The Cloud Function API provides an interface for developers to deploy, manage, a > Create a new cloud function to be executed on decentralized processors. -POST /acurast/cloud-functions +POST /cloud-functions
@@ -34,7 +34,7 @@ The Cloud Function API provides an interface for developers to deploy, manage, a ```sh -curl --location --request POST "https://api.apillon.io/acurast/cloud-functions" \ +curl --location --request POST "https://api.apillon.io/cloud-functions" \ --header "Authorization: Bearer :credentials" \ --header "Content-Type: application/json" \ --data-raw "{ @@ -73,7 +73,7 @@ curl --location --request POST "https://api.apillon.io/acurast/cloud-functions" > Retrieve a list of cloud functions associated with a project. -GET /acurast/cloud-functions +GET /cloud-functions
@@ -103,7 +103,7 @@ All query parameters from [listing request](1-apillon-api.md#listing-requests) ```sh -curl --location --request GET "https://api.apillon.io/acurast/cloud-functions?project_uuid=abc123-project" \ +curl --location --request GET "https://api.apillon.io/cloud-functions?project_uuid=abc123-project" \ --header "Authorization: Bearer :credentials" ``` @@ -144,7 +144,7 @@ curl --location --request GET "https://api.apillon.io/acurast/cloud-functions?pr > Get the details of a specific cloud function by its UUID. -GET /acurast/cloud-functions/:function_uuid +GET /cloud-functions/:function_uuid
@@ -187,7 +187,7 @@ curl --location --request GET "https://api.apillon.io/acurast/cloud-functions?pr ```sh -curl --location --request GET "https://api.apillon.io/acurast/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6" \ +curl --location --request GET "https://api.apillon.io/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6" \ --header "Authorization: Bearer :credentials" ``` @@ -237,7 +237,7 @@ curl --location --request GET "https://api.apillon.io/acurast/cloud-functions/d1 > Create a job/deployment for a specific cloud function. -POST /acurast/cloud-functions/:function_uuid/jobs +POST /cloud-functions/:function_uuid/jobs ::: warning The deployed code should be made on top of this Node.js template: [https://github.com/Apillon/cloud-function-template](https://github.com/Apillon/cloud-function-template) @@ -278,7 +278,7 @@ If it does not contain the boilerplate code, the deployment will not be accessib ```sh -curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6/jobs" \ +curl --location --request POST "https://api.apillon.io/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6/jobs" \ --header "Authorization: Bearer :credentials" \ --header "Content-Type: application/json" \ --data-raw "{ @@ -321,7 +321,7 @@ curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d > Set the environment variables for a specific cloud function. -POST /acurast/cloud-functions/:function_uuid/environment +POST /cloud-functions/:function_uuid/environment
@@ -352,7 +352,7 @@ curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d ```sh -curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6/environment" \ +curl --location --request POST "https://api.apillon.io/cloud-functions/d1e8b9f2-4d18-4ef7-9f59-87348590d5a6/environment" \ --header "Authorization: Bearer :credentials" \ --header "Content-Type: application/json" \ --data-raw "{ @@ -386,7 +386,7 @@ curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d > Delete a specific job using its unique identifier. -DELETE /acurast/jobs/:job_uuid +DELETE /cloud-functions/jobs/:job_uuid
@@ -412,7 +412,7 @@ curl --location --request POST "https://api.apillon.io/acurast/cloud-functions/d ```sh -curl --location --request DELETE "https://api.apillon.io/acurast/jobs/e3c86bb2-4190-4bda-9c8a-3852b6d04971" \ +curl --location --request DELETE "https://api.apillon.io/cloud-functions/jobs/e3c86bb2-4190-4bda-9c8a-3852b6d04971" \ --header "Authorization: Bearer :credentials" ``` From 63a9fae4ca213234864c1e734eb4838c628bbf43 Mon Sep 17 00:00:00 2001 From: Damjan Dimitrov Date: Thu, 24 Oct 2024 11:58:14 +0200 Subject: [PATCH 2/2] Write cloud functions SDK and CLI docs --- build/5-apillon-sdk.md | 43 +++++++++++++++++ build/6-apillon-cli.md | 102 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 145 insertions(+) diff --git a/build/5-apillon-sdk.md b/build/5-apillon-sdk.md index 50fc977f..738cfff2 100644 --- a/build/5-apillon-sdk.md +++ b/build/5-apillon-sdk.md @@ -439,6 +439,49 @@ console.log( ); ``` +## Cloud Functions + +The Cloud Functions module provides functionalities for managing cloud functions, including creating functions, listing functions, and interacting with specific functions for operations like job creation and environment variable management. + +### Usage example + +```ts +import { CloudFunctions } from '@apillon/sdk'; + +const cloudFunctions = new CloudFunctions({ key: 'yourApiKey', secret: 'yourApiSecret' }); + +// Create a new cloud function +const newCloudFunction = await cloudFunctions.createCloudFunction({ + name: 'My Cloud Function', + description: 'Description of my cloud function', +}); + +// List all cloud functions +const { items: cloudFunctionsList } = await cloudFunctions.listCloudFunctions(); + +// Get details of a specific cloud function +const cloudFunctionDetails = await cloudFunctions.cloudFunction(newCloudFunction.uuid).get(); + +// Create a job for the cloud function +const newJob = await cloudFunctions.cloudFunction(newCloudFunction.uuid).createJob({ + name: 'My Job', + scriptCid: 'QmYtHkLrtGEybxXg53swTHuKPYMXQCbHGeBqpYjYbaVyFV', +}); + +// Set environment variables for the cloud function +const environmentVariables = [ + { key: 'VAR1', value: 'value1' }, + { key: 'VAR2', value: 'value2' }, +]; +await cloudFunctions.cloudFunction(newCloudFunction.uuid).setEnvironment(environmentVariables); + +// List jobs for the cloud function +const { jobs: cloudFunctionJobs } = await cloudFunctions.cloudFunction(newCloudFunction.uuid).get(); + +// Delete a job for the cloud function +await cloudFunctionJobs[0].delete(); +``` + ## Social The Social module provides functionalities for managing social hubs and channels within the Apillon platform. This includes creating, listing, and interacting with hubs and channels. In the background it utilizes Grill.chat, a mobile-friendly, anonymous chat application powered by Subsocial. diff --git a/build/6-apillon-cli.md b/build/6-apillon-cli.md index d335c6a8..4a27aea4 100644 --- a/build/6-apillon-cli.md +++ b/build/6-apillon-cli.md @@ -756,6 +756,108 @@ apillon nfts list-transactions --uuid "123e4567-e89b-12d3-a456-426655440000" } ``` +## Cloud Function Commands + +The Apillon CLI provides a set of commands to manage cloud functions on the Apillon platform. These commands allow you to create, list, and manage cloud functions and their associated jobs. + +#### `cloud-functions list` + +Lists all cloud functions available in your project. + +**Example** + +```sh +apillon cloud-functions list --limit 10 --page 1 +``` + +#### `cloud-functions get` + +Retrieves details of a specific cloud function. + +**Options** + +- `--uuid `: UUID of the cloud function to retrieve. + +**Example** + +```sh +apillon cloud-functions get --uuid "123e4567-e89b-12d3-a456-426655440000" +``` + +#### `cloud-functions create` + +Creates a new cloud function. + +**Options** + +- `--name `: Name of the cloud function. +- `--description `: Description of the cloud function (optional). + +**Example** + +```sh +apillon cloud-functions create --name "MyFunction" --description "This is a test function" +``` + +#### `cloud-functions create-job` + +Creates a job for a cloud function from a script file. + +**Options** + +- `--uuid `: UUID of the cloud function. +- `--name `: Name of the job. +- `--script `: Path to the script file. + +**Example** + +```sh +apillon cloud-functions create-job --uuid "123e4567-e89b-12d3-a456-426655440000" --name "MyJob" --script "./path/to/script.js" +``` + +#### `cloud-functions set-environment` + +Sets environment variables for a cloud function. + +**Options** + +- `--uuid `: UUID of the cloud function. +- `--variables `: Environment variables in key=value format, separated by commas. + +**Example** + +```sh +apillon cloud-functions set-environment --uuid "123e4567-e89b-12d3-a456-426655440000" --variables "KEY1=value1,KEY2=value2" +``` + +#### `cloud-functions list-jobs` + +Lists all jobs for a specific cloud function. + +**Options** + +- `--uuid `: UUID of the cloud function. + +**Example** + +```sh +apillon cloud-functions list-jobs --uuid "123e4567-e89b-12d3-a456-426655440000" +``` + +#### `cloud-functions delete-job` + +Deletes a job from a cloud function. + +**Options** + +- `-j, --job-uuid `: UUID of the job to delete. + +**Example** + +```sh +apillon cloud-functions delete-job --job-uuid "987e6543-e21c-32f1-b123-426655441111" +``` + ## Using in CI/CD tools CLI is particularly useful for CI/CD builds and pipelines.