From 06e925fccd3334decde73893777ee52c2ee1e8f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fede=20Fern=C3=A1ndez?= <720923+fedefernandez@users.noreply.github.com> Date: Fri, 10 Nov 2023 22:24:13 +0100 Subject: [PATCH 1/2] Adds a custom task for downloading the API --- openai-client/generator/build.gradle.kts | 6 +++ .../generator/config/openai-api-commit | 1 + .../openai/generator/DownloadOpenAIAPI.java | 38 +++++++++++++++++++ 3 files changed, 45 insertions(+) create mode 100644 openai-client/generator/config/openai-api-commit create mode 100644 openai-client/generator/src/main/java/ai/xef/openai/generator/DownloadOpenAIAPI.java diff --git a/openai-client/generator/build.gradle.kts b/openai-client/generator/build.gradle.kts index 40aa5ffae..e5b07caa1 100644 --- a/openai-client/generator/build.gradle.kts +++ b/openai-client/generator/build.gradle.kts @@ -13,6 +13,12 @@ tasks.test { useJUnitPlatform() } +task("downloadOpenAIAPI", JavaExec::class) { + group = "GenerateTasks" + mainClass = "ai.xef.openai.generator.DownloadOpenAIAPI" + classpath = sourceSets["main"].runtimeClasspath +} + task("openaiClientGenerate", JavaExec::class) { group = "GenerateTasks" mainClass = "org.openapitools.codegen.OpenAPIGenerator" diff --git a/openai-client/generator/config/openai-api-commit b/openai-client/generator/config/openai-api-commit new file mode 100644 index 000000000..1360b8ffa --- /dev/null +++ b/openai-client/generator/config/openai-api-commit @@ -0,0 +1 @@ +5c1857ea865e74e45e3b12064e0cc2396ef64be1 \ No newline at end of file diff --git a/openai-client/generator/src/main/java/ai/xef/openai/generator/DownloadOpenAIAPI.java b/openai-client/generator/src/main/java/ai/xef/openai/generator/DownloadOpenAIAPI.java new file mode 100644 index 000000000..ef8cdb5b2 --- /dev/null +++ b/openai-client/generator/src/main/java/ai/xef/openai/generator/DownloadOpenAIAPI.java @@ -0,0 +1,38 @@ +package ai.xef.openai.generator; + +import java.io.*; +import java.net.URL; +import java.nio.channels.Channels; +import java.nio.channels.FileChannel; +import java.nio.channels.ReadableByteChannel; + +public class DownloadOpenAIAPI { + public static void main(String[] args) { + try { + String commit = readCommit(); + downloadAPI(commit); + } catch (IOException e) { + throw new RuntimeException(e); + } + } + + private static String readCommit() throws IOException { + StringBuilder resultStringBuilder = new StringBuilder(); + try (BufferedReader br = new BufferedReader(new FileReader("config/openai-api-commit"))) { + String line; + while ((line = br.readLine()) != null) { + resultStringBuilder.append(line).append("\n"); + } + } + return resultStringBuilder.toString().trim(); + } + + private static void downloadAPI(String commit) throws IOException { + URL url = new URL("https://raw.githubusercontent.com/openai/openai-openapi/%s/openapi.yaml".formatted(commit)); + ReadableByteChannel readableByteChannel = Channels.newChannel(url.openStream()); + try (FileOutputStream fileOutputStream = new FileOutputStream("config/openai-api.yaml")) { + FileChannel fileChannel = fileOutputStream.getChannel(); + fileChannel.transferFrom(readableByteChannel, 0, Long.MAX_VALUE); + } + } +} From 53627688a5109a9625600eee805aa5e86a4729b0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fede=20Fern=C3=A1ndez?= <720923+fedefernandez@users.noreply.github.com> Date: Mon, 13 Nov 2023 11:59:02 +0100 Subject: [PATCH 2/2] GitHub action for checking the OpenAI API --- .github/workflows/openai-api-check.yml | 150 +++++++++++++++++++++++++ 1 file changed, 150 insertions(+) create mode 100644 .github/workflows/openai-api-check.yml diff --git a/.github/workflows/openai-api-check.yml b/.github/workflows/openai-api-check.yml new file mode 100644 index 000000000..2cfd4107f --- /dev/null +++ b/.github/workflows/openai-api-check.yml @@ -0,0 +1,150 @@ +name: Check OpenAI API + +on: + workflow_dispatch: + +jobs: + checkAPIVersion: + runs-on: ubuntu-latest + steps: + - name: Install Octokit Action + run: npm install @octokit/action + - name: Get latest API commit + id: get-latest-commit + uses: actions/github-script@v6 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + result-encoding: string + script: ' + const { Octokit } = require("@octokit/action"); + const octokit = new Octokit(); + const owner = ''openai''; + const repo = ''openai-openapi''; + const filePath = ''openapi.yaml''; + const branch = ''master''; + const commits = await octokit.repos.listCommits({ + owner, + repo, + path: filePath, + ref: branch + }); + return commits.data[0].sha.trim(); + ' + - name: Get result latest API commit + run: | + LATEST_API_COMMIT="${{steps.get-latest-commit.outputs.result}}" + echo "LATEST_API_COMMIT=$LATEST_API_COMMIT" >> $GITHUB_ENV + - name: Get current API commit + id: get-current-commit + uses: actions/github-script@v6 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + result-encoding: string + script: ' + const { Octokit } = require("@octokit/action"); + const octokit = new Octokit(); + const owner = ''xebia-functional''; + const repo = ''xef''; + const filePath = ''openai-client/generator/config/openai-api-commit''; + const branch = ''main''; + const response = await octokit.repos.getContent({ + owner, + repo, + path: filePath, + ref: branch, + }); + const content = Buffer.from(response.data.content, ''base64'').toString(''utf-8''); + return content.trim(); + ' + - name: Get result current API commit + run: | + CURRENT_API_COMMIT="${{steps.get-current-commit.outputs.result}}" + echo "CURRENT_API_COMMIT=$CURRENT_API_COMMIT" >> $GITHUB_ENV + - name: Check existing PR + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + id: get-pr-commit + uses: actions/github-script@v6 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + result-encoding: string + script: ' + const { Octokit } = require("@octokit/action"); + const octokit = new Octokit(); + const owner = ''xebia-functional''; + const repo = ''xef''; + const filePath = ''openai-client/generator/config/openai-api-commit''; + const existing = await octokit.pulls.list({ + owner, + repo, + head: ''xebia-functional:update/openai-client'' + }); + + if (existing.data.length > 0) { + const prCommit = existing.data[0].head.sha; + const response = await octokit.repos.getContent({ + owner, + repo, + path: filePath, + ref: prCommit + }); + const prApiCommit = Buffer.from(response.data.content, ''base64'').toString(''utf-8'').trim(); + + if (prApiCommit === ''${{ env.LATEST_API_COMMIT }}'') { + return prApiCommit; + } else { + return ''''; + } + + } else { + return ''''; + } + ' + - name: Update current commit with PR + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + run: | + PR_API_COMMIT="${{steps.get-pr-commit.outputs.result}}" + if [[ ! -z "$PR_API_COMMIT" ]] + then + echo "CURRENT_API_COMMIT=$PR_API_COMMIT" >> $GITHUB_ENV + else + echo "Previous PR outdated or nonexistent" + fi + - name: Checkout + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: actions/checkout@v4 + - name: Update commit + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + run: | + echo $LATEST_API_COMMIT > $GITHUB_WORKSPACE/generator/config/openai-api-commit + - name: Set up Java + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: actions/setup-java@v3 + with: + distribution: 'zulu' + java-version: 20 + - name: Download new API spec + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: gradle/gradle-build-action@v2 + with: + arguments: downloadOpenAIAPI + - name: Generate new OpenAI client + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: gradle/gradle-build-action@v2 + with: + arguments: openaiClientGenerate + - name: Spotless Apply + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: gradle/gradle-build-action@v2 + with: + arguments: spotlessApply + - name: Create PR + if: env.CURRENT_API_COMMIT != env.LATEST_API_COMMIT + uses: peter-evans/create-pull-request@v5 + with: + commit-message: 'Update OpenAI Client' + branch: update/openai-client + title: 'Update OpenAI client' + body: 'Updates the OpenAI client based on the latest changes.'