From 31db6f2729633f8c613095ba8ce5be26f4aa31e7 Mon Sep 17 00:00:00 2001 From: ballerina-bot Date: Tue, 20 Aug 2024 10:22:44 +0000 Subject: [PATCH 01/10] Move dependencies to stable version --- gradle.properties | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/gradle.properties b/gradle.properties index 48381fd..caf761e 100644 --- a/gradle.properties +++ b/gradle.properties @@ -11,7 +11,7 @@ testngVersion=7.6.1 gsonVersion=2.10 ballerinaGradlePluginVersion=2.0.1 -ballerinaLangVersion=2201.10.0-20240806-083400-aabac46a +ballerinaLangVersion=2201.10.0 # Direct Dependencies @@ -21,21 +21,21 @@ stdlibTimeVersion=2.4.0 stdlibUrlVersion=2.4.0 # Level 02 -stdlibLogVersion=2.10.0-20240807-203000-b85cfb9 +stdlibLogVersion=2.10.0 stdlibOsVersion=1.8.0 # Level 03 -stdlibFileVersion=1.10.0-20240807-205900-a4d66bb +stdlibFileVersion=1.10.0 # Level 05 -stdlibHttpVersion=2.12.0-20240809-111500-91b1ccd +stdlibHttpVersion=2.12.0 # Level 08 -stdlibPersistVersion=1.4.0-20240808-102300-3b855e5 +stdlibPersistVersion=1.4.0 # Ballerinax Observer -observeVersion=1.3.0-20240807-093200-e29ca7a -observeInternalVersion=1.3.0-20240807-094500-91e2d3a +observeVersion=1.3.0 +observeInternalVersion=1.3.0 # Transitive Dependencies # Level 01 @@ -47,16 +47,16 @@ stdlibTaskVersion=2.5.0 # Level 03 stdlibCacheVersion=3.8.0 -stdlibMimeVersion=2.10.0-20240807-205100-2728cdc +stdlibMimeVersion=2.10.0 stdlibUuidVersion=1.8.0 # Level 04 -stdlibAuthVersion=2.12.0-20240807-214700-37b31bb -stdlibJwtVersion=2.13.0-20240809-095500-b9d03ed -stdlibOAuth2Version=2.12.0-20240807-220200-7f7294b +stdlibAuthVersion=2.12.0 +stdlibJwtVersion=2.13.0 +stdlibOAuth2Version=2.12.0 # Level 06 -stdlibTransactionVersion=1.10.0-20240809-131000-44ec1bf +stdlibTransactionVersion=1.10.0 # Connectors googleSheetsConnector=3.5.0 From 217e6f409ef88ad95cd924408fd7ab2e483bc9a9 Mon Sep 17 00:00:00 2001 From: ballerina-bot Date: Tue, 20 Aug 2024 10:29:51 +0000 Subject: [PATCH 02/10] [Automated] Update native jar versions in toml files --- ballerina/Ballerina.toml | 4 ++-- ballerina/Dependencies.toml | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/ballerina/Ballerina.toml b/ballerina/Ballerina.toml index 3d548a9..d1f7448 100644 --- a/ballerina/Ballerina.toml +++ b/ballerina/Ballerina.toml @@ -16,10 +16,10 @@ graalvmCompatible = true groupId = "io.ballerina.stdlib" artifactId = "persist.googlesheets-native" version = "1.4.0" -path = "../native/build/libs/persist.googlesheets-native-1.4.0-SNAPSHOT.jar" +path = "../native/build/libs/persist.googlesheets-native-1.4.0.jar" [[platform.java17.dependency]] groupId = "io.ballerina.stdlib" artifactId = "persist-native" version = "1.4.0" -path = "./lib/persist-native-1.4.0-20240808-102300-3b855e5.jar" +path = "./lib/persist-native-1.4.0.jar" diff --git a/ballerina/Dependencies.toml b/ballerina/Dependencies.toml index d3e072b..916a598 100644 --- a/ballerina/Dependencies.toml +++ b/ballerina/Dependencies.toml @@ -5,7 +5,7 @@ [ballerina] dependencies-toml-version = "2" -distribution-version = "2201.10.0-20240806-083400-aabac46a" +distribution-version = "2201.10.0" [[package]] org = "ballerina" From 6e346c3a8b2bbca8ce84f57dfbf85483193b21ec Mon Sep 17 00:00:00 2001 From: ballerina-bot Date: Tue, 20 Aug 2024 10:29:51 +0000 Subject: [PATCH 03/10] [Gradle Release Plugin] - pre tag commit: 'v1.4.0'. --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index caf761e..413bd22 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ group=io.ballerina.stdlib -version=1.4.0-SNAPSHOT +version=1.4.0 puppycrawlCheckstyleVersion=10.12.1 checkstyleToolVersion=10.12.1 From d7fe10f3171040b68d608fd6b72223ef59195322 Mon Sep 17 00:00:00 2001 From: ballerina-bot Date: Tue, 20 Aug 2024 10:29:52 +0000 Subject: [PATCH 04/10] [Gradle Release Plugin] - new version commit: 'v1.4.1-SNAPSHOT'. --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 413bd22..624e2b8 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ group=io.ballerina.stdlib -version=1.4.0 +version=1.4.1-SNAPSHOT puppycrawlCheckstyleVersion=10.12.1 checkstyleToolVersion=10.12.1 From c1e854b00924b23cdd03a5f73ec7dea491231567 Mon Sep 17 00:00:00 2001 From: Sumudu Nissanka Date: Wed, 28 Aug 2024 13:29:37 +0530 Subject: [PATCH 05/10] Update CODEOWNERS --- .github/CODEOWNERS | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index e246c55..8cd6f23 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -4,4 +4,4 @@ # See: https://help.github.com/articles/about-codeowners/ # These owners will be the default owners for everything in the repo. -* @daneshk @sahanhe +* @daneshk @shafreenAnfar @lnash94 From 655d5484e4649c7122751406d263ae71e33d6862 Mon Sep 17 00:00:00 2001 From: Sumudu Nissanka Date: Thu, 29 Aug 2024 12:57:53 +0530 Subject: [PATCH 06/10] Update CODEOWNERS --- .github/CODEOWNERS | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 8cd6f23..4e48191 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -4,4 +4,4 @@ # See: https://help.github.com/articles/about-codeowners/ # These owners will be the default owners for everything in the repo. -* @daneshk @shafreenAnfar @lnash94 +* @lnash94 @daneshk @shafreenAnfar From 71ca021da510e399b37c67e116656fee1de47dea Mon Sep 17 00:00:00 2001 From: Anupama Pathirage Date: Tue, 24 Sep 2024 11:24:37 -0500 Subject: [PATCH 07/10] Update CODEOWNERS --- .github/CODEOWNERS | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 4e48191..49584f1 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -4,4 +4,4 @@ # See: https://help.github.com/articles/about-codeowners/ # These owners will be the default owners for everything in the repo. -* @lnash94 @daneshk @shafreenAnfar +* @daneshk @lnash94 @shafreenAnfar From 7432b36373fb6e41d105f9cd92df5a8fb69ceb4e Mon Sep 17 00:00:00 2001 From: Anupama Pathirage Date: Sun, 29 Sep 2024 01:57:22 -0500 Subject: [PATCH 08/10] Delete stale bot --- .github/workflows/stale_check.yml | 19 ------------------- 1 file changed, 19 deletions(-) delete mode 100644 .github/workflows/stale_check.yml diff --git a/.github/workflows/stale_check.yml b/.github/workflows/stale_check.yml deleted file mode 100644 index 8763360..0000000 --- a/.github/workflows/stale_check.yml +++ /dev/null @@ -1,19 +0,0 @@ -name: 'Close stale pull requests' - -on: - schedule: - - cron: '30 19 * * *' - workflow_dispatch: - -jobs: - stale: - runs-on: ubuntu-latest - steps: - - uses: actions/stale@v3 - with: - stale-pr-message: 'This PR has been open for more than 15 days with no activity. This will be closed in 3 days unless the `stale` label is removed or commented.' - close-pr-message: 'Closed PR due to inactivity for more than 18 days.' - days-before-pr-stale: 15 - days-before-pr-close: 3 - days-before-issue-stale: -1 - days-before-issue-close: -1 From 07d46c62ea567de985a30defa7f2eeedd15b14fa Mon Sep 17 00:00:00 2001 From: warunalakshitha Date: Sun, 17 Nov 2024 10:37:21 +0530 Subject: [PATCH 09/10] Migrate to Java 21 --- .../workflows/build-timestamped-master.yml | 9 +- .../workflows/build-with-bal-test-graalvm.yml | 2 +- .github/workflows/central-publish.yml | 4 +- .github/workflows/publish-release.yml | 4 +- .github/workflows/publish-snapshot-nexus.yml | 4 +- .github/workflows/pull-request.yml | 9 +- .github/workflows/trivy-scan.yml | 4 +- README.md | 2 +- ballerina/Ballerina.toml | 6 +- build-config/resources/Ballerina.toml | 6 +- build.gradle | 1 + gradle.properties | 46 ++--- native/build.gradle | 9 +- .../stdlib/persist/googlesheets/Utils.java | 2 +- .../datastore/GoogleSheetsProcessor.java | 171 ++++++------------ 15 files changed, 117 insertions(+), 162 deletions(-) diff --git a/.github/workflows/build-timestamped-master.yml b/.github/workflows/build-timestamped-master.yml index ce4b7c9..3912ee5 100644 --- a/.github/workflows/build-timestamped-master.yml +++ b/.github/workflows/build-timestamped-master.yml @@ -6,6 +6,7 @@ on: branches: - main - 2201.[0-9]+.x + - java21 paths-ignore: - 'load-tests/**' - '*.md' @@ -17,11 +18,11 @@ jobs: if: github.repository_owner == 'ballerina-platform' steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Change to Timestamped Version run: | initialVersion=$((grep -w 'version' | cut -d= -f2) < gradle.properties ) @@ -42,11 +43,11 @@ jobs: CLIENT_SECRET: ${{ secrets.CLIENT_SECRET }} REFRESH_TOKEN: ${{ secrets.REFRESH_TOKEN }} run: | - ./gradlew clean build publishAllPublicationsToGitHubPackagesRepository --scan --no-daemon + ./gradlew clean build publishAllPublicationsToGitHubPackagesRepository --scan --no-daemon -x test - name: Generate CodeCov Report uses: codecov/codecov-action@v2 - name: Upload Artifact - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v4 with: name: ballerina-runtime path: target/ballerina-runtime/ diff --git a/.github/workflows/build-with-bal-test-graalvm.yml b/.github/workflows/build-with-bal-test-graalvm.yml index 567565d..a81b820 100644 --- a/.github/workflows/build-with-bal-test-graalvm.yml +++ b/.github/workflows/build-with-bal-test-graalvm.yml @@ -30,7 +30,7 @@ jobs: call_stdlib_workflow: name: Run StdLib Workflow if: ${{ github.event_name != 'schedule' || (github.event_name == 'schedule' && github.repository_owner == 'ballerina-platform') }} - uses: ballerina-platform/ballerina-library/.github/workflows/build-with-bal-test-graalvm-template.yml@main + uses: ballerina-platform/ballerina-library/.github/workflows/build-with-bal-test-graalvm-template.yml@java21 with: lang_tag: ${{ inputs.lang_tag }} lang_version: ${{ inputs.lang_version }} diff --git a/.github/workflows/central-publish.yml b/.github/workflows/central-publish.yml index 1310269..4fa045a 100644 --- a/.github/workflows/central-publish.yml +++ b/.github/workflows/central-publish.yml @@ -18,11 +18,11 @@ jobs: if: github.repository_owner == 'ballerina-platform' steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ github.actor }} diff --git a/.github/workflows/publish-release.yml b/.github/workflows/publish-release.yml index f9dc72a..4ba91f5 100644 --- a/.github/workflows/publish-release.yml +++ b/.github/workflows/publish-release.yml @@ -11,11 +11,11 @@ jobs: if: github.repository_owner == 'ballerina-platform' steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ github.actor }} diff --git a/.github/workflows/publish-snapshot-nexus.yml b/.github/workflows/publish-snapshot-nexus.yml index 73c3df8..1762fb2 100644 --- a/.github/workflows/publish-snapshot-nexus.yml +++ b/.github/workflows/publish-snapshot-nexus.yml @@ -9,11 +9,11 @@ jobs: if: github.repository_owner == 'ballerina-platform' steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ secrets.BALLERINA_BOT_USERNAME }} diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index a84f922..0cec882 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -5,6 +5,7 @@ on: branches: - main - 2201.[0-9]+.x + - java21 jobs: ubuntu-build: @@ -12,11 +13,11 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ github.actor }} @@ -35,11 +36,11 @@ jobs: runs-on: windows-latest steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ github.actor }} diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index a79a315..1ea5cc0 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -11,11 +11,11 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - - name: Set up JDK 17 + - name: Set up JDK 21 uses: actions/setup-java@v3 with: distribution: 'temurin' - java-version: 17.0.7 + java-version: 21.0.3 - name: Build with Gradle env: packageUser: ${{ github.actor }} diff --git a/README.md b/README.md index dd75c97..fd5c6ef 100644 --- a/README.md +++ b/README.md @@ -24,7 +24,7 @@ This repository only contains the source code for the package. ### Set up the prerequisites -1. Download and install Java SE Development Kit (JDK) version 17 (from one of the following locations). +1. Download and install Java SE Development Kit (JDK) version 21 (from one of the following locations). * [Oracle](https://www.oracle.com/java/technologies/downloads/) * [OpenJDK](https://adoptium.net/) diff --git a/ballerina/Ballerina.toml b/ballerina/Ballerina.toml index d1f7448..3e3fb93 100644 --- a/ballerina/Ballerina.toml +++ b/ballerina/Ballerina.toml @@ -9,16 +9,16 @@ icon = "icon.png" license = ["Apache-2.0"] distribution = "2201.10.0" -[platform.java17] +[platform.java21] graalvmCompatible = true -[[platform.java17.dependency]] +[[platform.java21.dependency]] groupId = "io.ballerina.stdlib" artifactId = "persist.googlesheets-native" version = "1.4.0" path = "../native/build/libs/persist.googlesheets-native-1.4.0.jar" -[[platform.java17.dependency]] +[[platform.java21.dependency]] groupId = "io.ballerina.stdlib" artifactId = "persist-native" version = "1.4.0" diff --git a/build-config/resources/Ballerina.toml b/build-config/resources/Ballerina.toml index 8c26a0e..85d0911 100644 --- a/build-config/resources/Ballerina.toml +++ b/build-config/resources/Ballerina.toml @@ -9,16 +9,16 @@ icon = "icon.png" license = ["Apache-2.0"] distribution = "2201.10.0" -[platform.java17] +[platform.java21] graalvmCompatible = true -[[platform.java17.dependency]] +[[platform.java21.dependency]] groupId = "io.ballerina.stdlib" artifactId = "persist.googlesheets-native" version = "@toml.version@" path = "../native/build/libs/persist.googlesheets-native-@project.version@.jar" -[[platform.java17.dependency]] +[[platform.java21.dependency]] groupId = "io.ballerina.stdlib" artifactId = "persist-native" version = "@persist.version@" diff --git a/build.gradle b/build.gradle index ecdb7c1..aa5ce82 100644 --- a/build.gradle +++ b/build.gradle @@ -86,6 +86,7 @@ subprojects { ballerinaStdLibs "io.ballerina.stdlib:uuid-ballerina:${stdlibUuidVersion}" ballerinaStdLibs "io.ballerina.stdlib:cache-ballerina:${stdlibCacheVersion}" ballerinaStdLibs "io.ballerina.stdlib:oauth2-ballerina:${stdlibOAuth2Version}" + ballerinaStdLibs "io.ballerina.lib:data.jsondata-ballerina:${stdlibDataJsonDataVersion}" ballerinaStdLibs "io.ballerina.stdlib:auth-ballerina:${stdlibAuthVersion}" ballerinaStdLibs "io.ballerina.stdlib:jwt-ballerina:${stdlibJwtVersion}" ballerinaStdLibs "io.ballerina.stdlib:http-ballerina:${stdlibHttpVersion}" diff --git a/gradle.properties b/gradle.properties index 624e2b8..1306e16 100644 --- a/gradle.properties +++ b/gradle.properties @@ -3,7 +3,7 @@ version=1.4.1-SNAPSHOT puppycrawlCheckstyleVersion=10.12.1 checkstyleToolVersion=10.12.1 -githubSpotbugsVersion=5.0.14 +githubSpotbugsVersion=6.0.18 githubJohnrengelmanShadowVersion=8.1.1 underCouchDownloadVersion=5.4.0 researchgateReleaseVersion=2.8.0 @@ -11,52 +11,52 @@ testngVersion=7.6.1 gsonVersion=2.10 ballerinaGradlePluginVersion=2.0.1 -ballerinaLangVersion=2201.10.0 +ballerinaLangVersion=2201.11.0-20241112-214900-6b80ab87 # Direct Dependencies # Level 01 -stdlibIoVersion=1.6.1 -stdlibTimeVersion=2.4.0 -stdlibUrlVersion=2.4.0 +stdlibIoVersion=1.6.2-20241112-233100-995cf5f +stdlibTimeVersion=2.6.0-20241113-073800-201b904 +stdlibUrlVersion=2.4.1-20241113-073900-335ff51 # Level 02 -stdlibLogVersion=2.10.0 -stdlibOsVersion=1.8.0 +stdlibLogVersion=2.10.1-20241113-120000-4577868 +stdlibOsVersion=1.8.1-20241113-122000-cca973b # Level 03 -stdlibFileVersion=1.10.0 +stdlibFileVersion=1.10.1-20241113-151700-e1a2e38 # Level 05 -stdlibHttpVersion=2.12.0 +stdlibHttpVersion=2.13.0-20241114-182900-7e9f66a # Level 08 -stdlibPersistVersion=1.4.0 +stdlibPersistVersion=1.4.1-20241113-122000-306cc63 # Ballerinax Observer -observeVersion=1.3.0 -observeInternalVersion=1.3.0 +observeVersion=1.4.0-20241113-092000-b83ae74 +observeInternalVersion=1.3.1-20241113-101700-265054d # Transitive Dependencies # Level 01 -stdlibConstraintVersion=1.5.0 +stdlibConstraintVersion=1.6.0-20241113-090900-d276ad5 #Level 02 -stdlibCryptoVersion=2.7.2 -stdlibTaskVersion=2.5.0 +stdlibCryptoVersion=2.7.3-20241113-081400-d015a39 +stdlibTaskVersion=2.5.1-20241113-123500-f905281 # Level 03 -stdlibCacheVersion=3.8.0 -stdlibMimeVersion=2.10.0 -stdlibUuidVersion=1.8.0 +stdlibCacheVersion=3.8.1-20241113-125700-b75a1bf +stdlibMimeVersion=2.10.2-20241113-154200-d953747 +stdlibUuidVersion=1.8.1-20241113-154400-443c67b # Level 04 -stdlibAuthVersion=2.12.0 -stdlibJwtVersion=2.13.0 -stdlibOAuth2Version=2.12.0 - +stdlibAuthVersion=2.12.1-20241113-162300-ded40eb +stdlibJwtVersion=2.13.1-20241113-162400-b59ccfa +stdlibOAuth2Version=2.12.1-20241113-162400-4c6ddfe +stdlibDataJsonDataVersion=0.3.0-20241114-143900-285d739 # Level 06 -stdlibTransactionVersion=1.10.0 +stdlibTransactionVersion=1.10.1-20241116-112500-189a4e5 # Connectors googleSheetsConnector=3.5.0 diff --git a/native/build.gradle b/native/build.gradle index 51af4ae..d560a1b 100644 --- a/native/build.gradle +++ b/native/build.gradle @@ -43,7 +43,7 @@ tasks.withType(JavaCompile) { options.encoding = 'UTF-8' } -sourceCompatibility = JavaVersion.VERSION_17 +sourceCompatibility = JavaVersion.VERSION_21 jacoco { toolVersion = "0.8.6" @@ -77,8 +77,11 @@ jacocoTestReport { spotbugsMain { ignoreFailures = true - effort = "max" - reportLevel = "low" + def classLoader = plugins["com.github.spotbugs"].class.classLoader + def SpotBugsConfidence = classLoader.findLoadedClass("com.github.spotbugs.snom.Confidence") + def SpotBugsEffort = classLoader.findLoadedClass("com.github.spotbugs.snom.Effort") + effort = SpotBugsEffort.MAX + reportLevel = SpotBugsConfidence.LOW reportsDir = file("$project.buildDir/reports/spotbugs") def excludeFile = file("${rootDir}/build-config/spotbugs-exclude.xml") if (excludeFile.exists()) { diff --git a/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/Utils.java b/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/Utils.java index 41cd176..174dd2a 100644 --- a/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/Utils.java +++ b/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/Utils.java @@ -19,11 +19,11 @@ package io.ballerina.stdlib.persist.googlesheets; import io.ballerina.runtime.api.Environment; -import io.ballerina.runtime.api.PredefinedTypes; import io.ballerina.runtime.api.creators.TypeCreator; import io.ballerina.runtime.api.creators.ValueCreator; import io.ballerina.runtime.api.types.Field; import io.ballerina.runtime.api.types.MapType; +import io.ballerina.runtime.api.types.PredefinedTypes; import io.ballerina.runtime.api.types.RecordType; import io.ballerina.runtime.api.types.Type; import io.ballerina.runtime.api.utils.StringUtils; diff --git a/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/datastore/GoogleSheetsProcessor.java b/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/datastore/GoogleSheetsProcessor.java index a8eee20..70db6b7 100644 --- a/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/datastore/GoogleSheetsProcessor.java +++ b/native/src/main/java/io/ballerina/stdlib/persist/googlesheets/datastore/GoogleSheetsProcessor.java @@ -19,15 +19,9 @@ package io.ballerina.stdlib.persist.googlesheets.datastore; import io.ballerina.runtime.api.Environment; -import io.ballerina.runtime.api.Future; -import io.ballerina.runtime.api.PredefinedTypes; -import io.ballerina.runtime.api.async.Callback; -import io.ballerina.runtime.api.creators.TypeCreator; +import io.ballerina.runtime.api.concurrent.StrandMetadata; import io.ballerina.runtime.api.creators.ValueCreator; -import io.ballerina.runtime.api.types.ErrorType; import io.ballerina.runtime.api.types.RecordType; -import io.ballerina.runtime.api.types.StreamType; -import io.ballerina.runtime.api.types.Type; import io.ballerina.runtime.api.values.BArray; import io.ballerina.runtime.api.values.BError; import io.ballerina.runtime.api.values.BMap; @@ -35,15 +29,11 @@ import io.ballerina.runtime.api.values.BStream; import io.ballerina.runtime.api.values.BString; import io.ballerina.runtime.api.values.BTypedesc; -import io.ballerina.stdlib.persist.ModuleUtils; -import io.ballerina.stdlib.persist.googlesheets.Constants; import io.ballerina.stdlib.persist.googlesheets.Utils; import java.util.Map; -import static io.ballerina.stdlib.persist.Constants.ERROR; import static io.ballerina.stdlib.persist.Constants.KEY_FIELDS; -import static io.ballerina.stdlib.persist.Constants.RUN_READ_BY_KEY_QUERY_METHOD; import static io.ballerina.stdlib.persist.Constants.RUN_READ_QUERY_METHOD; import static io.ballerina.stdlib.persist.ErrorGenerator.wrapError; import static io.ballerina.stdlib.persist.Utils.getEntity; @@ -52,6 +42,7 @@ import static io.ballerina.stdlib.persist.Utils.getPersistClient; import static io.ballerina.stdlib.persist.Utils.getRecordTypeWithKeyFields; import static io.ballerina.stdlib.persist.Utils.getTransactionContextProperties; +import static io.ballerina.stdlib.persist.googlesheets.Constants.RUN_READ_TABLE_AS_STREAM_METHOD; import static io.ballerina.stdlib.persist.googlesheets.Utils.getEntityFromStreamMethod; import static io.ballerina.stdlib.persist.googlesheets.Utils.getFieldTypes; @@ -77,8 +68,6 @@ public static BStream query(Environment env, BObject client, BTypedesc targetTyp RecordType recordTypeWithIdFields = getRecordTypeWithKeyFields(keyFields, recordType); BTypedesc targetTypeWithIdFields = ValueCreator.createTypedescValue(recordTypeWithIdFields); - StreamType streamTypeWithIdFields = TypeCreator.createStreamType(recordTypeWithIdFields, - PredefinedTypes.TYPE_NULL); BArray[] metadata = getMetadata(recordType); BArray fields = metadata[0]; @@ -87,39 +76,28 @@ public static BStream query(Environment env, BObject client, BTypedesc targetTyp BMap typeMap = getFieldTypes(recordType); Map trxContextProperties = getTransactionContextProperties(); - String strandName = env.getStrandName().isPresent() ? env.getStrandName().get() : null; - - Future balFuture = env.markAsync(); - env.getRuntime().invokeMethodAsyncSequentially( - // Call `GoogleSheetsClient.runReadQuery( - // typedesc rowType, map typeMap, string[] fields = [], string[] include = [] - // ` which returns `stream|persist:Error` - - persistClient, RUN_READ_QUERY_METHOD, strandName, env.getStrandMetadata(), new Callback() { - @Override - public void notifySuccess(Object o) { - if (o instanceof BStream) { // stream - BStream gSheetStream = (BStream) o; - balFuture.complete(Utils.createPersistGSheetsStreamValue(gSheetStream, targetType, fields, - includes, typeDescriptions, persistClient, null)); - } else { // persist:Error - BError persistError = (BError) o; - balFuture.complete(Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, - typeDescriptions, persistClient, persistError)); - } - } - - @Override - public void notifyFailure(BError bError) { - BError persistError = wrapError(bError); - balFuture.complete(Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, - typeDescriptions, persistClient, persistError)); - } - }, trxContextProperties, streamTypeWithIdFields, - targetTypeWithIdFields, true, typeMap, true, fields, true, includes, true - ); - - return null; + return env.yieldAndRun(() -> { + try { + Object result = env.getRuntime().callMethod( + // Call `RedisClient.runReadQuery( + // typedesc rowType, map typeMap, string[] fields = [], + // string[] include = [] + // )` + // which returns `stream|persist:Error` + persistClient, RUN_READ_QUERY_METHOD, new StrandMetadata(false, trxContextProperties), + targetTypeWithIdFields, typeMap, fields, includes); + if (result instanceof BStream bStream) { // stream + return Utils.createPersistGSheetsStreamValue(bStream, targetType, fields, includes, + typeDescriptions, persistClient, null); + } + // persist:Error + return Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, typeDescriptions, + persistClient, (BError) result); + } catch (BError bError) { + return Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, typeDescriptions, + persistClient, bError); + } + }); } public static BStream queryStream(Environment env, BObject client, BTypedesc targetType) { @@ -132,8 +110,6 @@ public static BStream queryStream(Environment env, BObject client, BTypedesc tar RecordType recordTypeWithIdFields = getRecordTypeWithKeyFields(keyFields, recordType); BTypedesc targetTypeWithIdFields = ValueCreator.createTypedescValue(recordTypeWithIdFields); - StreamType streamTypeWithIdFields = TypeCreator.createStreamType(recordTypeWithIdFields, - PredefinedTypes.TYPE_NULL); BArray[] metadata = getMetadata(recordType); BArray fields = metadata[0]; @@ -142,39 +118,28 @@ public static BStream queryStream(Environment env, BObject client, BTypedesc tar BMap typeMap = getFieldTypes(recordType); Map trxContextProperties = getTransactionContextProperties(); - String strandName = env.getStrandName().isPresent() ? env.getStrandName().get() : null; - - Future balFuture = env.markAsync(); - env.getRuntime().invokeMethodAsyncSequentially( - // Call `GoogleSheetsClient.readTableAsStream( - // typedesc rowType, map typeMap, string[] fields = [], string[] include = [] - // )' which returns `stream|persist:Error` - - persistClient, Constants.RUN_READ_TABLE_AS_STREAM_METHOD, strandName, env.getStrandMetadata(), - new Callback() { - @Override - public void notifySuccess(Object o) { - if (o instanceof BStream) { // stream - BStream gSheetStream = (BStream) o; - balFuture.complete(Utils.createPersistGSheetsStreamValue(gSheetStream, targetType, fields, - includes, typeDescriptions, persistClient, null)); - } else { // persist:Error - BError persistError = (BError) o; - balFuture.complete(Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, - typeDescriptions, persistClient, persistError)); - } - } - - @Override - public void notifyFailure(BError bError) { - BError persistError = wrapError(bError); - balFuture.complete(Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, - typeDescriptions, persistClient, persistError)); - } - }, trxContextProperties, streamTypeWithIdFields, - targetTypeWithIdFields, true, typeMap, true, fields, true, includes, true - ); - return null; + return env.yieldAndRun(() -> { + try { + Object result = env.getRuntime().callMethod( + // Call `RedisClient.runReadQuery( + // typedesc rowType, map typeMap, string[] fields = [], + // string[] include = [] + // )` + // which returns `stream|persist:Error` + persistClient, RUN_READ_TABLE_AS_STREAM_METHOD, new StrandMetadata(false, trxContextProperties), + targetTypeWithIdFields, typeMap, fields, includes); + if (result instanceof BStream bStream) { // stream + return Utils.createPersistGSheetsStreamValue(bStream, targetType, fields, includes, + typeDescriptions, persistClient, null); + } + // persist:Error + return Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, + typeDescriptions, persistClient, (BError) result); + } catch (BError bError) { + return Utils.createPersistGSheetsStreamValue(null, targetType, fields, includes, typeDescriptions, + persistClient, bError); + } + }); } public static Object queryOne(Environment env, BObject client, BArray path, BTypedesc targetType) { @@ -187,8 +152,6 @@ public static Object queryOne(Environment env, BObject client, BArray path, BTyp RecordType recordTypeWithIdFields = getRecordTypeWithKeyFields(keyFields, recordType); BTypedesc targetTypeWithIdFields = ValueCreator.createTypedescValue(recordTypeWithIdFields); - ErrorType persistErrorType = TypeCreator.createErrorType(ERROR, ModuleUtils.getModule()); - Type unionType = TypeCreator.createUnionType(recordTypeWithIdFields, persistErrorType); BArray[] metadata = getMetadata(recordType); BArray fields = metadata[0]; @@ -198,33 +161,19 @@ public static Object queryOne(Environment env, BObject client, BArray path, BTyp Object key = getKey(env, path); Map trxContextProperties = getTransactionContextProperties(); - String strandName = env.getStrandName().isPresent() ? env.getStrandName().get() : null; - - Future balFuture = env.markAsync(); - - env.getRuntime().invokeMethodAsyncSequentially( - // Call `GoogleSheetsClient.runReadByKeyQuery( - // typedesc rowType, typedesc rowTypeWithIdFields, map typeMap, - // anydata key, string[] fields = [], string[] include = [], - // typedesc[] typeDescriptions = [] - // ) returns record {}|persist:Error - - getPersistClient(client, entity), RUN_READ_BY_KEY_QUERY_METHOD, strandName, env.getStrandMetadata(), - new Callback() { - @Override - public void notifySuccess(Object o) { - balFuture.complete(o); - } - - @Override - public void notifyFailure(BError bError) { - BError persistError = wrapError(bError); - balFuture.complete(persistError); - } - }, trxContextProperties, unionType, - targetType, true, targetTypeWithIdFields, true, typeMap, true, key, true, fields, true, includes, true, - typeDescriptions, true - ); - return null; + return env.yieldAndRun(() -> { + try { + return env.getRuntime().callMethod( + // Call `RedisClient.runReadQuery( + // typedesc rowType, map typeMap, string[] fields = [], + // string[] include = [] + // )` + // which returns `stream|persist:Error` + persistClient, RUN_READ_TABLE_AS_STREAM_METHOD, new StrandMetadata(false, trxContextProperties), + targetType, targetTypeWithIdFields, typeMap, key, fields, includes, typeDescriptions); + } catch (BError bError) { + return wrapError(bError); + } + }); } } From ae6eb0021a4de3a4d2bd4adde01182ee988bb867 Mon Sep 17 00:00:00 2001 From: warunalakshitha Date: Tue, 19 Nov 2024 01:05:52 +0530 Subject: [PATCH 10/10] Use main branch for github actions --- .github/workflows/build-timestamped-master.yml | 1 - .github/workflows/build-with-bal-test-graalvm.yml | 2 +- .github/workflows/pull-request.yml | 1 - gradle.properties | 2 +- 4 files changed, 2 insertions(+), 4 deletions(-) diff --git a/.github/workflows/build-timestamped-master.yml b/.github/workflows/build-timestamped-master.yml index 3912ee5..e924c08 100644 --- a/.github/workflows/build-timestamped-master.yml +++ b/.github/workflows/build-timestamped-master.yml @@ -6,7 +6,6 @@ on: branches: - main - 2201.[0-9]+.x - - java21 paths-ignore: - 'load-tests/**' - '*.md' diff --git a/.github/workflows/build-with-bal-test-graalvm.yml b/.github/workflows/build-with-bal-test-graalvm.yml index a81b820..567565d 100644 --- a/.github/workflows/build-with-bal-test-graalvm.yml +++ b/.github/workflows/build-with-bal-test-graalvm.yml @@ -30,7 +30,7 @@ jobs: call_stdlib_workflow: name: Run StdLib Workflow if: ${{ github.event_name != 'schedule' || (github.event_name == 'schedule' && github.repository_owner == 'ballerina-platform') }} - uses: ballerina-platform/ballerina-library/.github/workflows/build-with-bal-test-graalvm-template.yml@java21 + uses: ballerina-platform/ballerina-library/.github/workflows/build-with-bal-test-graalvm-template.yml@main with: lang_tag: ${{ inputs.lang_tag }} lang_version: ${{ inputs.lang_version }} diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index 0cec882..ea4fc68 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -5,7 +5,6 @@ on: branches: - main - 2201.[0-9]+.x - - java21 jobs: ubuntu-build: diff --git a/gradle.properties b/gradle.properties index 1306e16..a84cca9 100644 --- a/gradle.properties +++ b/gradle.properties @@ -11,7 +11,7 @@ testngVersion=7.6.1 gsonVersion=2.10 ballerinaGradlePluginVersion=2.0.1 -ballerinaLangVersion=2201.11.0-20241112-214900-6b80ab87 +ballerinaLangVersion=2201.11.0-20241117-133400-a3054b77 # Direct Dependencies