|
26 | 26 | options: |
27 | 27 | - packages/sdk/server-ai |
28 | 28 | - packages/ai-providers/server-ai-langchain |
| 29 | + - packages/ai-providers/server-ai-openai |
| 30 | + - packages/ai-providers/server-ai-vercel |
29 | 31 | dry_run: |
30 | 32 | description: 'Is this a dry run. If so no package will be published.' |
31 | 33 | type: boolean |
|
43 | 45 | package-server-ai-tag-name: ${{ steps.release.outputs['packages/sdk/server-ai--tag_name'] }} |
44 | 46 | package-server-ai-langchain-released: ${{ steps.release.outputs['packages/ai-providers/server-ai-langchain--release_created'] }} |
45 | 47 | package-server-ai-langchain-tag-name: ${{ steps.release.outputs['packages/ai-providers/server-ai-langchain--tag_name'] }} |
| 48 | + package-server-ai-openai-released: ${{ steps.release.outputs['packages/ai-providers/server-ai-openai--release_created'] }} |
| 49 | + package-server-ai-openai-tag-name: ${{ steps.release.outputs['packages/ai-providers/server-ai-openai--tag_name'] }} |
| 50 | + package-server-ai-vercel-released: ${{ steps.release.outputs['packages/ai-providers/server-ai-vercel--release_created'] }} |
| 51 | + package-server-ai-vercel-tag-name: ${{ steps.release.outputs['packages/ai-providers/server-ai-vercel--tag_name'] }} |
46 | 52 | steps: |
47 | 53 | - uses: googleapis/release-please-action@v4 |
48 | 54 | id: release |
@@ -193,3 +199,111 @@ jobs: |
193 | 199 | base64-subjects: "${{ needs.release-server-ai-langchain.outputs.package-hashes }}" |
194 | 200 | upload-assets: true |
195 | 201 | upload-tag-name: ${{ needs.release-please.outputs.package-server-ai-langchain-tag-name }} |
| 202 | + |
| 203 | + release-server-ai-openai: |
| 204 | + runs-on: ubuntu-latest |
| 205 | + needs: ['release-please'] |
| 206 | + permissions: |
| 207 | + id-token: write # Needed for OIDC to get release secrets from AWS. |
| 208 | + if: ${{ needs.release-please.outputs.package-server-ai-openai-released == 'true' }} |
| 209 | + outputs: |
| 210 | + package-hashes: ${{ steps.build.outputs.package-hashes }} |
| 211 | + steps: |
| 212 | + - uses: actions/checkout@v4 |
| 213 | + with: |
| 214 | + fetch-depth: 0 |
| 215 | + |
| 216 | + - uses: actions/setup-python@v5 |
| 217 | + with: |
| 218 | + python-version: '3.11' |
| 219 | + |
| 220 | + - name: Install poetry |
| 221 | + uses: abatilo/actions-poetry@7b6d33e44b4f08d7021a1dee3c044e9c253d6439 |
| 222 | + |
| 223 | + - uses: ./.github/actions/ci |
| 224 | + with: |
| 225 | + workspace_path: packages/ai-providers/server-ai-openai |
| 226 | + |
| 227 | + - uses: ./.github/actions/build |
| 228 | + id: build |
| 229 | + with: |
| 230 | + workspace_path: packages/ai-providers/server-ai-openai |
| 231 | + |
| 232 | + - uses: launchdarkly/gh-actions/actions/release-secrets@release-secrets-v1.2.0 |
| 233 | + name: 'Get PyPI token' |
| 234 | + with: |
| 235 | + aws_assume_role: ${{ vars.AWS_ROLE_ARN }} |
| 236 | + ssm_parameter_pairs: '/production/common/releasing/pypi/token = PYPI_AUTH_TOKEN' |
| 237 | + |
| 238 | + - name: Publish to PyPI |
| 239 | + uses: pypa/gh-action-pypi-publish@ed0c53931b1dc9bd32cbe73a98c7f6766f8a527e # v1.13.0 |
| 240 | + with: |
| 241 | + password: ${{ env.PYPI_AUTH_TOKEN }} |
| 242 | + packages-dir: packages/ai-providers/server-ai-openai/dist/ |
| 243 | + |
| 244 | + release-server-ai-openai-provenance: |
| 245 | + needs: ['release-please', 'release-server-ai-openai'] |
| 246 | + if: ${{ needs.release-please.outputs.package-server-ai-openai-released == 'true' }} |
| 247 | + permissions: |
| 248 | + actions: read # Needed for detecting the GitHub Actions environment. |
| 249 | + id-token: write # Needed for provenance signing. |
| 250 | + contents: write # Needed for uploading assets to the release. |
| 251 | + uses: slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@v2.0.0 |
| 252 | + with: |
| 253 | + base64-subjects: "${{ needs.release-server-ai-openai.outputs.package-hashes }}" |
| 254 | + upload-assets: true |
| 255 | + upload-tag-name: ${{ needs.release-please.outputs.package-server-ai-openai-tag-name }} |
| 256 | + |
| 257 | + release-server-ai-vercel: |
| 258 | + runs-on: ubuntu-latest |
| 259 | + needs: ['release-please'] |
| 260 | + permissions: |
| 261 | + id-token: write # Needed for OIDC to get release secrets from AWS. |
| 262 | + if: ${{ needs.release-please.outputs.package-server-ai-vercel-released == 'true' }} |
| 263 | + outputs: |
| 264 | + package-hashes: ${{ steps.build.outputs.package-hashes }} |
| 265 | + steps: |
| 266 | + - uses: actions/checkout@v4 |
| 267 | + with: |
| 268 | + fetch-depth: 0 |
| 269 | + |
| 270 | + - uses: actions/setup-python@v5 |
| 271 | + with: |
| 272 | + python-version: '3.11' |
| 273 | + |
| 274 | + - name: Install poetry |
| 275 | + uses: abatilo/actions-poetry@7b6d33e44b4f08d7021a1dee3c044e9c253d6439 |
| 276 | + |
| 277 | + - uses: ./.github/actions/ci |
| 278 | + with: |
| 279 | + workspace_path: packages/ai-providers/server-ai-vercel |
| 280 | + |
| 281 | + - uses: ./.github/actions/build |
| 282 | + id: build |
| 283 | + with: |
| 284 | + workspace_path: packages/ai-providers/server-ai-vercel |
| 285 | + |
| 286 | + - uses: launchdarkly/gh-actions/actions/release-secrets@release-secrets-v1.2.0 |
| 287 | + name: 'Get PyPI token' |
| 288 | + with: |
| 289 | + aws_assume_role: ${{ vars.AWS_ROLE_ARN }} |
| 290 | + ssm_parameter_pairs: '/production/common/releasing/pypi/token = PYPI_AUTH_TOKEN' |
| 291 | + |
| 292 | + - name: Publish to PyPI |
| 293 | + uses: pypa/gh-action-pypi-publish@ed0c53931b1dc9bd32cbe73a98c7f6766f8a527e # v1.13.0 |
| 294 | + with: |
| 295 | + password: ${{ env.PYPI_AUTH_TOKEN }} |
| 296 | + packages-dir: packages/ai-providers/server-ai-vercel/dist/ |
| 297 | + |
| 298 | + release-server-ai-vercel-provenance: |
| 299 | + needs: ['release-please', 'release-server-ai-vercel'] |
| 300 | + if: ${{ needs.release-please.outputs.package-server-ai-vercel-released == 'true' }} |
| 301 | + permissions: |
| 302 | + actions: read # Needed for detecting the GitHub Actions environment. |
| 303 | + id-token: write # Needed for provenance signing. |
| 304 | + contents: write # Needed for uploading assets to the release. |
| 305 | + uses: slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@v2.0.0 |
| 306 | + with: |
| 307 | + base64-subjects: "${{ needs.release-server-ai-vercel.outputs.package-hashes }}" |
| 308 | + upload-assets: true |
| 309 | + upload-tag-name: ${{ needs.release-please.outputs.package-server-ai-vercel-tag-name }} |
0 commit comments