|
5 | 5 | branches: [ main ] |
6 | 6 |
|
7 | 7 | jobs: |
8 | | - release-package: |
| 8 | + release-please: |
9 | 9 | runs-on: ubuntu-latest |
10 | 10 | permissions: |
11 | | - id-token: write # Needed if using OIDC to get release secrets. |
12 | | - contents: write # Contents and pull-requests are for release-please to make releases. |
| 11 | + contents: write |
13 | 12 | pull-requests: write |
14 | 13 | outputs: |
15 | | - release-created: ${{ steps.release.outputs.release_created }} |
16 | | - upload-tag-name: ${{ steps.release.outputs.tag_name }} |
17 | | - package-hashes: ${{ steps.build.outputs.package-hashes}} |
| 14 | + releases_created: ${{ steps.release.outputs.releases_created }} |
| 15 | + core_release_created: ${{ steps.release.outputs['packages/core--release_created'] }} |
| 16 | + langchain_release_created: ${{ steps.release.outputs['packages/langchain--release_created'] }} |
18 | 17 | steps: |
19 | 18 | - uses: googleapis/release-please-action@v4 |
20 | 19 | id: release |
| 20 | + with: |
| 21 | + config-file: release-please-config.json |
| 22 | + manifest-file: .release-please-manifest.json |
21 | 23 |
|
| 24 | + release-core: |
| 25 | + needs: release-please |
| 26 | + if: ${{ needs.release-please.outputs.core_release_created == 'true' }} |
| 27 | + runs-on: ubuntu-latest |
| 28 | + permissions: |
| 29 | + id-token: write |
| 30 | + contents: write |
| 31 | + steps: |
22 | 32 | - uses: actions/checkout@v4 |
23 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
24 | | - with: |
25 | | - fetch-depth: 0 # If you only need the current version keep this. |
26 | 33 |
|
27 | 34 | - uses: actions/setup-python@v5 |
28 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
29 | 35 | with: |
30 | 36 | python-version: 3.9 |
31 | 37 |
|
32 | 38 | - name: Install poetry |
33 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
34 | 39 | uses: abatilo/actions-poetry@7b6d33e44b4f08d7021a1dee3c044e9c253d6439 |
35 | 40 |
|
36 | 41 | - uses: launchdarkly/gh-actions/actions/release-secrets@release-secrets-v1.2.0 |
37 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
38 | 42 | name: 'Get PyPI token' |
39 | 43 | with: |
40 | 44 | aws_assume_role: ${{ vars.AWS_ROLE_ARN }} |
41 | 45 | ssm_parameter_pairs: '/production/common/releasing/pypi/token = PYPI_AUTH_TOKEN' |
42 | 46 |
|
43 | 47 | - uses: ./.github/actions/build |
44 | 48 | id: build |
45 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
| 49 | + with: |
| 50 | + package-path: packages/core |
46 | 51 |
|
47 | 52 | - uses: ./.github/actions/build-docs |
48 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
49 | 53 |
|
50 | | - - name: Publish package distributions to PyPI |
51 | | - if: ${{ steps.release.outputs.releases_created == 'true' }} |
| 54 | + - name: Publish core package to PyPI |
52 | 55 | uses: pypa/gh-action-pypi-publish@release/v1 |
53 | 56 | with: |
54 | | - password: ${{env.PYPI_AUTH_TOKEN}} |
| 57 | + password: ${{ env.PYPI_AUTH_TOKEN }} |
| 58 | + packages-dir: packages/core/dist/ |
55 | 59 |
|
56 | | - release-provenance: |
57 | | - needs: [ 'release-package' ] |
58 | | - if: ${{ needs.release-package.outputs.release-created == 'true' }} |
| 60 | + release-langchain: |
| 61 | + needs: release-please |
| 62 | + if: ${{ needs.release-please.outputs.langchain_release_created == 'true' }} |
| 63 | + runs-on: ubuntu-latest |
59 | 64 | permissions: |
60 | | - actions: read |
61 | 65 | id-token: write |
62 | 66 | contents: write |
63 | | - uses: slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@v2.0.0 |
64 | | - with: |
65 | | - base64-subjects: "${{ needs.release-package.outputs.package-hashes }}" |
66 | | - upload-assets: true |
67 | | - upload-tag-name: ${{ needs.release-package.outputs.upload-tag-name }} |
| 67 | + steps: |
| 68 | + - uses: actions/checkout@v4 |
| 69 | + |
| 70 | + - uses: actions/setup-python@v5 |
| 71 | + with: |
| 72 | + python-version: 3.9 |
| 73 | + |
| 74 | + - name: Install poetry |
| 75 | + uses: abatilo/actions-poetry@7b6d33e44b4f08d7021a1dee3c044e9c253d6439 |
| 76 | + |
| 77 | + - uses: launchdarkly/gh-actions/actions/release-secrets@release-secrets-v1.2.0 |
| 78 | + name: 'Get PyPI token' |
| 79 | + with: |
| 80 | + aws_assume_role: ${{ vars.AWS_ROLE_ARN }} |
| 81 | + ssm_parameter_pairs: '/production/common/releasing/pypi/token = PYPI_AUTH_TOKEN' |
| 82 | + |
| 83 | + - uses: ./.github/actions/build |
| 84 | + id: build |
| 85 | + with: |
| 86 | + package-path: packages/langchain |
| 87 | + |
| 88 | + - name: Publish langchain package to PyPI |
| 89 | + uses: pypa/gh-action-pypi-publish@release/v1 |
| 90 | + with: |
| 91 | + password: ${{ env.PYPI_AUTH_TOKEN }} |
| 92 | + packages-dir: packages/langchain/dist/ |
0 commit comments