From b368beb622853bc7ae15c6c6bd57385c3a823295 Mon Sep 17 00:00:00 2001 From: aashikam Date: Wed, 6 Mar 2024 11:08:14 +0530 Subject: [PATCH] Add initial implementation --- .gitignore | 31 +- README.md | 184 +- ballerina/Ballerina.toml | 13 + ballerina/Dependencies.toml | 281 + ballerina/Module.md | 113 + ballerina/Package.md | 113 + ballerina/build.gradle | 80 + ballerina/icon.png | Bin 0 -> 8244 bytes ballerina/types.bal | 31317 + build-config/resources/Ballerina.toml | 13 + build.gradle | 76 + docs/spec/oas.json | 644687 ++++++++++++++++++++ gradle.properties | 10 + gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 63375 bytes gradle/wrapper/gradle-wrapper.properties | 7 + gradlew | 248 + gradlew.bat | 92 + pull_request_template.md | 54 +- settings.gradle | 49 + 19 files changed, 677317 insertions(+), 51 deletions(-) create mode 100644 ballerina/Ballerina.toml create mode 100644 ballerina/Dependencies.toml create mode 100644 ballerina/Module.md create mode 100644 ballerina/Package.md create mode 100644 ballerina/build.gradle create mode 100644 ballerina/icon.png create mode 100644 ballerina/types.bal create mode 100644 build-config/resources/Ballerina.toml create mode 100644 build.gradle create mode 100644 docs/spec/oas.json create mode 100644 gradle.properties create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100755 gradlew create mode 100644 gradlew.bat create mode 100644 settings.gradle diff --git a/.gitignore b/.gitignore index 524f096..b97ad98 100644 --- a/.gitignore +++ b/.gitignore @@ -12,13 +12,42 @@ # Package Files # *.jar +!gradle-wrapper/*.jar *.war *.nar *.ear *.zip *.tar.gz *.rar +*.deb # virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml hs_err_pid* -replay_pid* + +# .DS_Store files +*.DS_Store + +# Ballerina configuartion file +ballerina.conf +Config.toml + +# Target folder of ballerina project +target + +# json files created inside resources folder +/resources/*.json + +# idea files +*.idea +*.iml +*.ipr +*.iws + +# Ignore Gradle project-specific cache directory +.gradle + +# Ignore Gradle build output directory +build + +# Ignore lib +lib diff --git a/README.md b/README.md index 4501c9d..0645dce 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,182 @@ -# module-ballerinax-salesforce.types -The Ballerina types corresponding to the base types of Salesforce SObjects, without any custom SObjects. +Salesforce SObject Types for Ballerina Salesforce Connector +=================== + +[![Build](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/ci.yml/badge.svg)](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/ci.yml) +[![Trivy](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/trivy-scan.yml/badge.svg)](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/trivy-scan.yml) +[![GitHub Last Commit](https://img.shields.io/github/last-commit/ballerina-platform/module-ballerinax-salesforce.types.svg)](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/commits/main) +[![GraalVM Check](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/build-with-bal-test-graalvm.yml/badge.svg)](https://github.com/ballerina-platform/module-ballerinax-salesforce.types/actions/workflows/build-with-bal-test-graalvm.yml) +[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) + +Salesforce is a leading customer relationship management (CRM) platform that helps businesses manage and streamline their sales, service, and marketing operations. The [Ballerina Salesforce Connector](https://central.ballerina.io/ballerinax/salesforce/latest) is a project designed to enhance integration capabilities with Salesforce by providing a seamless connection for Ballerina. Notably, this Ballerina project incorporates record type definitions for the base types of Salesforce objects, offering a comprehensive and adaptable solution for developers working on Salesforce integration projects. + +## Setup Guide + +To customize this project for your Salesforce account and include your custom SObjects, follow the steps below: + +### Step 1: Login to Your Salesforce Developer Account + +Begin by logging into your [Salesforce Developer Account](https://developer.salesforce.com/). + +### Step 2: Generate Open API Specification for Your SObjects + +#### Step 2.1: Initiate OpenAPI Document Generation + +Use the following command to send a POST request to start the OpenAPI document generation process. + +```bash +curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3 \ +-d '{"resources": ["*"]}' +``` +Replace YOUR_ACCESS_TOKEN and MyDomainName with your actual access token and Salesforce domain. If successful, you'll receive a response with a URI. Extract the locator ID from the URI. + +#### Step 2.2: Retrieve the OpenAPI Document + +Send a GET request to fetch the generated OpenAPI document using the following command. + +```bash +curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3/LOCATOR_ID -o oas.json +``` +Replace YOUR_ACCESS_TOKEN, MyDomainName, and LOCATOR_ID with your actual values. + +### Step 3: Configure Cluster Settings + +To prevent Out-of-Memory (OOM) issues, execute the following command: + +```bash +export JAVA_OPTS="$JAVA_OPTS -DmaxYamlCodePoints=99999999" +``` + +Generate the Ballerina project for the OpenAPI spec using the Ballerina Open API tool with the following commands. + +```bash +bal openapi -i oas.json --mode client --client-methods resource +``` + +### Step 4: Edit the Generated Client and Push it to Local Repository + +#### Step 4.1 Delete the utils.bal and clients.bal files. + +#### Step 4.2 Use the following commands to build, pack, and push the package: + +````bash +bal pack + +bal push --repository=local +```` + +By following these steps, you can set up and customize the Ballerina Salesforce Connector for your Salesforce account with ease. + +## Quickstart + +To use the `salesforce.types` module in your Ballerina application, modify the `.bal` file as follows: + +### Step 1: Import the package + +Import `ballerinax/salesforce.types` module. + +```ballerina +import ballerinax/salesforce; +import ballerinax/salesforce.types; +``` + +### Step 2: Instantiate a new client + +Obtain the tokens using the following the [`ballerinax/salesforce` connector set up guide](https://central.ballerina.io/ballerinax/salesforce/latest). Create a salesforce:ConnectionConfig with the obtained OAuth2 tokens and initialize the connector with it. + +```ballerina +salesforce:ConnectionConfig config = { + baseUrl: baseUrl, + auth: { + clientId: clientId, + clientSecret: clientSecret, + refreshToken: refreshToken, + refreshUrl: refreshUrl + } +}; + +salesforce:Client salesforce = new(config); +``` + +### Step 3: Invoke the connector operation + +Now you can utilize the available operations. Note that they are in the form of remote operations. Following is an example on how to create a record using the connector. + +```ballerina +salesforce:Client salesforce = check new (config); +stypes:AccountSObject response = { + Name: "IT World", + BillingCity: "New York" +}; + +salesforce:CreationResponse response = check salesforce->create("Account", response); +``` + +Use following command to compile and run the Ballerina program. + +```bash +bal run +``` + +## Issues and projects + +The **Issues** and **Projects** tabs are disabled for this repository as this is part of the Ballerina library. To report bugs, request new features, start new discussions, view project boards, etc., visit the Ballerina library [parent repository](https://github.com/ballerina-platform/ballerina-library). + +This repository only contains the source code for the package. + +## Build from the source + +### Prerequisites + +1. Download and install Java SE Development Kit (JDK) version 17. You can download it from either of the following sources: + + * [Oracle JDK](https://www.oracle.com/java/technologies/downloads/) + * [OpenJDK](https://adoptium.net/) + + > **Note:** After installation, remember to set the `JAVA_HOME` environment variable to the directory where JDK was installed. + +2. Download and install [Ballerina Swan Lake](https://ballerina.io/). + +3. Download and install [Docker](https://www.docker.com/get-started). + + > **Note**: Ensure that the Docker daemon is running before executing any tests. + +### Build options + +Execute the commands below to build from the source. + +1. To build the package: + + ```bash + ./gradlew clean build + ``` + +2. Publish the generated artifacts to the local Ballerina Central repository: + + ```bash + ./gradlew clean build -PpublishToLocalCentral=true + ``` + +3. Publish the generated artifacts to the Ballerina Central repository: + + ```bash + ./gradlew clean build -PpublishToCentral=true + ``` + +## Contribute to Ballerina + +As an open-source project, Ballerina welcomes contributions from the community. + +For more information, go to the [contribution guidelines](https://github.com/ballerina-platform/ballerina-lang/blob/master/CONTRIBUTING.md). + +## Code of conduct + +All the contributors are encouraged to read the [Ballerina Code of Conduct](https://ballerina.io/code-of-conduct). + +## Useful links + +* For more information go to the [`salesforce.types` package](https://lib.ballerina.io/ballerinax/salesforce.types/latest). +* For example demonstrations of the usage, go to [Ballerina By Examples](https://ballerina.io/learn/by-example/). +* Chat live with us via our [Discord server](https://discord.gg/ballerinalang). +* Post all technical questions on Stack Overflow with the [#ballerina](https://stackoverflow.com/questions/tagged/ballerina) tag. diff --git a/ballerina/Ballerina.toml b/ballerina/Ballerina.toml new file mode 100644 index 0000000..841bab7 --- /dev/null +++ b/ballerina/Ballerina.toml @@ -0,0 +1,13 @@ +[package] +distribution = "2201.8.0" +org = "ballerinax" +name = "salesforce.types" +version = "1.0.0" +license= ["Apache-2.0"] +authors = ["Ballerina"] +keywords = ["Sales & CRM/Customer Relationship Management", "Cost/Freemium"] +icon = "icon.png" +repository = "https://github.com/ballerina-platform/module-ballerinax-salesforce.types" + +[platform.java17] +graalvmCompatible = true diff --git a/ballerina/Dependencies.toml b/ballerina/Dependencies.toml new file mode 100644 index 0000000..35cf375 --- /dev/null +++ b/ballerina/Dependencies.toml @@ -0,0 +1,281 @@ +# AUTO-GENERATED FILE. DO NOT MODIFY. + +# This file is auto-generated by Ballerina for managing dependency versions. +# It should not be modified by hand. + +[ballerina] +dependencies-toml-version = "2" +distribution-version = "2201.8.0" + +[[package]] +org = "ballerina" +name = "auth" +version = "2.10.0" +dependencies = [ + {org = "ballerina", name = "crypto"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.array"}, + {org = "ballerina", name = "lang.string"}, + {org = "ballerina", name = "log"} +] + +[[package]] +org = "ballerina" +name = "cache" +version = "3.7.1" +dependencies = [ + {org = "ballerina", name = "constraint"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "task"}, + {org = "ballerina", name = "time"} +] + +[[package]] +org = "ballerina" +name = "constraint" +version = "1.5.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "crypto" +version = "2.6.2" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "time"} +] + +[[package]] +org = "ballerina" +name = "file" +version = "1.9.0" +dependencies = [ + {org = "ballerina", name = "io"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "os"}, + {org = "ballerina", name = "time"} +] + +[[package]] +org = "ballerina" +name = "http" +version = "2.10.8" +dependencies = [ + {org = "ballerina", name = "auth"}, + {org = "ballerina", name = "cache"}, + {org = "ballerina", name = "constraint"}, + {org = "ballerina", name = "crypto"}, + {org = "ballerina", name = "file"}, + {org = "ballerina", name = "io"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "jwt"}, + {org = "ballerina", name = "lang.array"}, + {org = "ballerina", name = "lang.decimal"}, + {org = "ballerina", name = "lang.int"}, + {org = "ballerina", name = "lang.regexp"}, + {org = "ballerina", name = "lang.runtime"}, + {org = "ballerina", name = "lang.string"}, + {org = "ballerina", name = "lang.value"}, + {org = "ballerina", name = "log"}, + {org = "ballerina", name = "mime"}, + {org = "ballerina", name = "oauth2"}, + {org = "ballerina", name = "observe"}, + {org = "ballerina", name = "time"}, + {org = "ballerina", name = "url"} +] +modules = [ + {org = "ballerina", packageName = "http", moduleName = "http"}, + {org = "ballerina", packageName = "http", moduleName = "http.httpscerr"} +] + +[[package]] +org = "ballerina" +name = "io" +version = "1.6.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.value"} +] + +[[package]] +org = "ballerina" +name = "jballerina.java" +version = "0.0.0" + +[[package]] +org = "ballerina" +name = "jwt" +version = "2.10.0" +dependencies = [ + {org = "ballerina", name = "cache"}, + {org = "ballerina", name = "crypto"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.int"}, + {org = "ballerina", name = "lang.string"}, + {org = "ballerina", name = "log"}, + {org = "ballerina", name = "time"} +] + +[[package]] +org = "ballerina" +name = "lang.__internal" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.object"} +] + +[[package]] +org = "ballerina" +name = "lang.array" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.__internal"} +] + +[[package]] +org = "ballerina" +name = "lang.decimal" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "lang.int" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.__internal"}, + {org = "ballerina", name = "lang.object"} +] + +[[package]] +org = "ballerina" +name = "lang.object" +version = "0.0.0" + +[[package]] +org = "ballerina" +name = "lang.regexp" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "lang.runtime" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "lang.string" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.regexp"} +] + +[[package]] +org = "ballerina" +name = "lang.value" +version = "0.0.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "log" +version = "2.9.0" +dependencies = [ + {org = "ballerina", name = "io"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.value"}, + {org = "ballerina", name = "observe"} +] + +[[package]] +org = "ballerina" +name = "mime" +version = "2.9.0" +dependencies = [ + {org = "ballerina", name = "io"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "lang.int"} +] + +[[package]] +org = "ballerina" +name = "oauth2" +version = "2.10.0" +dependencies = [ + {org = "ballerina", name = "cache"}, + {org = "ballerina", name = "crypto"}, + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "log"}, + {org = "ballerina", name = "time"}, + {org = "ballerina", name = "url"} +] + +[[package]] +org = "ballerina" +name = "observe" +version = "1.2.2" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "os" +version = "1.8.0" +dependencies = [ + {org = "ballerina", name = "io"}, + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "task" +version = "2.5.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"}, + {org = "ballerina", name = "time"} +] + +[[package]] +org = "ballerina" +name = "time" +version = "2.4.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerina" +name = "url" +version = "2.4.0" +dependencies = [ + {org = "ballerina", name = "jballerina.java"} +] + +[[package]] +org = "ballerinax" +name = "salesforce.types" +version = "1.0.0" +dependencies = [ + {org = "ballerina", name = "http"} +] +modules = [ + {org = "ballerinax", packageName = "salesforce.types", moduleName = "salesforce.types"} +] + diff --git a/ballerina/Module.md b/ballerina/Module.md new file mode 100644 index 0000000..3389c56 --- /dev/null +++ b/ballerina/Module.md @@ -0,0 +1,113 @@ +## Overview + +Salesforce is a leading customer relationship management (CRM) platform that helps businesses manage and streamline their sales, service, and marketing operations. The [Ballerina Salesforce Connector](https://central.ballerina.io/ballerinax/salesforce/latest) is a project designed to enhance integration capabilities with Salesforce by providing a seamless connection for Ballerina. Notably, this Ballerina project incorporates record type definitions for the base types of Salesforce objects, offering a comprehensive and adaptable solution for developers working on Salesforce integration projects. + +## Setup Guide + +To customize this project for your Salesforce account and include your custom SObjects, follow the steps below: + +### Step 1: Login to Your Salesforce Developer Account + +Begin by logging into your [Salesforce Developer Account](https://developer.salesforce.com/). + +### Step 2: Generate Open API Specification for Your SObjects + +#### Step 2.1: Initiate OpenAPI Document Generation + +Use the following command to send a POST request to start the OpenAPI document generation process. + +```bash +curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3 \ +-d '{"resources": ["*"]}' +``` +Replace YOUR_ACCESS_TOKEN and MyDomainName with your actual access token and Salesforce domain. If successful, you'll receive a response with a URI. Extract the locator ID from the URI. + +#### Step 2.2: Retrieve the OpenAPI Document + +Send a GET request to fetch the generated OpenAPI document using the following command. + +```bash +curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3/LOCATOR_ID -o oas.json +``` +Replace YOUR_ACCESS_TOKEN, MyDomainName, and LOCATOR_ID with your actual values. + +### Step 3: Configure Cluster Settings + +To prevent Out-of-Memory (OOM) issues, execute the following command: + +```bash +export JAVA_OPTS="$JAVA_OPTS -DmaxYamlCodePoints=99999999" +``` + +Generate the Ballerina project for the OpenAPI spec using the Ballerina Open API tool with the following commands. + +```bash +bal openapi -i oas.json --mode client --client-methods resource +``` + +### Step 4: Edit the Generated Client and Push it to Local Repository + +#### Step 4.1 Delete the utils.bal and clients.bal files. + +#### Step 4.2 Use the following commands to build, pack, and push the package: + +````bash +bal pack + +bal push --repository=local +```` + +By following these steps, you can set up and customize the Ballerina Salesforce Connector for your Salesforce account with ease. + +## Quickstart + +To use the `salesforce.types` module in your Ballerina application, modify the `.bal` file as follows: + +### Step 1: Import the package + +Import `ballerinax/salesforce.types` module. + +```ballerina +import ballerinax/salesforce; +import ballerinax/salesforce.types; +``` + +### Step 2: Instantiate a new client + +Obtain the tokens using the following the [`ballerinax/salesforce` connector set up guide](https://central.ballerina.io/ballerinax/salesforce/latest). Create a salesforce:ConnectionConfig with the obtained OAuth2 tokens and initialize the connector with it. + +```ballerina +salesforce:ConnectionConfig config = { + baseUrl: baseUrl, + auth: { + clientId: clientId, + clientSecret: clientSecret, + refreshToken: refreshToken, + refreshUrl: refreshUrl + } +}; + +salesforce:Client salesforce = new(config); +``` + +### Step 3: Invoke the connector operation + +Now you can utilize the available operations. Note that they are in the form of remote operations. Following is an example on how to create a record using the connector. + +```ballerina +salesforce:Client salesforce = check new (config); +stypes:AccountSObject response = { + Name: "IT World", + BillingCity: "New York" +}; + +salesforce:CreationResponse response = check salesforce->create("Account", response); +``` + +Use following command to compile and run the Ballerina program. + +```bash +bal run +``` diff --git a/ballerina/Package.md b/ballerina/Package.md new file mode 100644 index 0000000..3389c56 --- /dev/null +++ b/ballerina/Package.md @@ -0,0 +1,113 @@ +## Overview + +Salesforce is a leading customer relationship management (CRM) platform that helps businesses manage and streamline their sales, service, and marketing operations. The [Ballerina Salesforce Connector](https://central.ballerina.io/ballerinax/salesforce/latest) is a project designed to enhance integration capabilities with Salesforce by providing a seamless connection for Ballerina. Notably, this Ballerina project incorporates record type definitions for the base types of Salesforce objects, offering a comprehensive and adaptable solution for developers working on Salesforce integration projects. + +## Setup Guide + +To customize this project for your Salesforce account and include your custom SObjects, follow the steps below: + +### Step 1: Login to Your Salesforce Developer Account + +Begin by logging into your [Salesforce Developer Account](https://developer.salesforce.com/). + +### Step 2: Generate Open API Specification for Your SObjects + +#### Step 2.1: Initiate OpenAPI Document Generation + +Use the following command to send a POST request to start the OpenAPI document generation process. + +```bash +curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3 \ +-d '{"resources": ["*"]}' +``` +Replace YOUR_ACCESS_TOKEN and MyDomainName with your actual access token and Salesforce domain. If successful, you'll receive a response with a URI. Extract the locator ID from the URI. + +#### Step 2.2: Retrieve the OpenAPI Document + +Send a GET request to fetch the generated OpenAPI document using the following command. + +```bash +curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer YOUR_ACCESS_TOKEN" \ +https://MyDomainName.my.salesforce.com/services/data/vXX.X/async/specifications/oas3/LOCATOR_ID -o oas.json +``` +Replace YOUR_ACCESS_TOKEN, MyDomainName, and LOCATOR_ID with your actual values. + +### Step 3: Configure Cluster Settings + +To prevent Out-of-Memory (OOM) issues, execute the following command: + +```bash +export JAVA_OPTS="$JAVA_OPTS -DmaxYamlCodePoints=99999999" +``` + +Generate the Ballerina project for the OpenAPI spec using the Ballerina Open API tool with the following commands. + +```bash +bal openapi -i oas.json --mode client --client-methods resource +``` + +### Step 4: Edit the Generated Client and Push it to Local Repository + +#### Step 4.1 Delete the utils.bal and clients.bal files. + +#### Step 4.2 Use the following commands to build, pack, and push the package: + +````bash +bal pack + +bal push --repository=local +```` + +By following these steps, you can set up and customize the Ballerina Salesforce Connector for your Salesforce account with ease. + +## Quickstart + +To use the `salesforce.types` module in your Ballerina application, modify the `.bal` file as follows: + +### Step 1: Import the package + +Import `ballerinax/salesforce.types` module. + +```ballerina +import ballerinax/salesforce; +import ballerinax/salesforce.types; +``` + +### Step 2: Instantiate a new client + +Obtain the tokens using the following the [`ballerinax/salesforce` connector set up guide](https://central.ballerina.io/ballerinax/salesforce/latest). Create a salesforce:ConnectionConfig with the obtained OAuth2 tokens and initialize the connector with it. + +```ballerina +salesforce:ConnectionConfig config = { + baseUrl: baseUrl, + auth: { + clientId: clientId, + clientSecret: clientSecret, + refreshToken: refreshToken, + refreshUrl: refreshUrl + } +}; + +salesforce:Client salesforce = new(config); +``` + +### Step 3: Invoke the connector operation + +Now you can utilize the available operations. Note that they are in the form of remote operations. Following is an example on how to create a record using the connector. + +```ballerina +salesforce:Client salesforce = check new (config); +stypes:AccountSObject response = { + Name: "IT World", + BillingCity: "New York" +}; + +salesforce:CreationResponse response = check salesforce->create("Account", response); +``` + +Use following command to compile and run the Ballerina program. + +```bash +bal run +``` diff --git a/ballerina/build.gradle b/ballerina/build.gradle new file mode 100644 index 0000000..339bfed --- /dev/null +++ b/ballerina/build.gradle @@ -0,0 +1,80 @@ +/* + * Copyright (c) 2024 WSO2 LLC. (https://www.wso2.com) All Rights Reserved. + * + * WSO2 LLC. licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import org.apache.tools.ant.taskdefs.condition.Os + +plugins { + id 'io.ballerina.plugin' +} + +description = 'Ballerina - Salesforce Base Types' + +def packageName = "salesforce.types" +def packageOrg = "ballerinax" +def tomlVersion = stripBallerinaExtensionVersion("${project.version}") +def ballerinaTomlFilePlaceHolder = new File("${project.rootDir}/build-config/resources/Ballerina.toml") +def ballerinaTomlFile = new File("$project.projectDir/Ballerina.toml") + +def stripBallerinaExtensionVersion(String extVersion) { + if (extVersion.matches(project.ext.timestampedVersionRegex)) { + def splitVersion = extVersion.split('-') + if (splitVersion.length > 3) { + def strippedValues = splitVersion[0..-4] + return strippedValues.join('-') + } else { + return extVersion + } + } else { + return extVersion.replace("${project.ext.snapshotVersion}", "") + } +} + +ballerina { + packageOrganization = packageOrg + module = packageName + isConnector = true + platform = "java17" +} + +task updateTomlFiles { + doLast { + def newConfig = ballerinaTomlFilePlaceHolder.text.replace('@project.version@', project.version.toString()) + newConfig = newConfig.replace('@toml.version@', tomlVersion) + ballerinaTomlFile.text = newConfig + } +} + +task commitTomlFiles { + doLast { + project.exec { + ignoreExitValue true + if (Os.isFamily(Os.FAMILY_WINDOWS)) { + commandLine 'cmd', '/c', "git commit -m \"[Automated] Update the toml files\" Ballerina.toml Dependencies.toml" + } else { + commandLine 'sh', '-c', "git commit -m '[Automated] Update the toml files' Ballerina.toml Dependencies.toml" + } + } + } +} + +clean { + delete 'build' +} + +build.dependsOn copyToLib +publish.dependsOn build diff --git a/ballerina/icon.png b/ballerina/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..9e38832a5fa0aae757ee824e823f68ca24059ee3 GIT binary patch literal 8244 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