SDK Generation workflow
The SDK Generation workflow is powered by the Speakeasy CLI (opens in a new tab) and the Speakeasy SDK Generation GitHub Action (opens in a new tab). The workflow automates the process of:
- Downloading or loading the OpenAPI document from a URL or repository.
- Validating the OpenAPI document.
- Generating SDKs for multiple languages.
- Committing the generated SDKs to the repository or opening a pull request (PR).
Example workflow file
name: SDK Generationpermissions:checks: writecontents: writepull-requests: writestatuses: writeon:workflow_dispatch:inputs:force:description: Force SDK generation, even if no changes are detected.type: booleandefault: falsejobs:generate:uses: speakeasy-api/sdk-generation-action/.github/workflows/workflow-executor.yaml@v15with:speakeasy_version: latestforce: ${{ github.event.inputs.force }}mode: prsecrets:github_access_token: ${{ secrets.GITHUB_TOKEN }}speakeasy_api_key: ${{ secrets.SPEAKEASY_API_KEY }}
Step-by-step guide
1. Initialize SDK Repository
Create a new GitHub repository to host the autogenerated SDKs. It is recommended to use a separate repository for each SDK, but a monorepo is also supported.
2. Generate SDK Workflow Configuration
Run the Speakeasy CLI to configure the SDK generation workflow. This command creates the necessary workflow files.
speakeasy configure github
After running the command, .speakeasy/workflow.yaml
and .github/workflows/sdk_generation.yaml
will be created. These files define the SDK generation workflow and the associated GitHub Action.
If further customization is needed, manual configuration of the workflow files is available.
3. Set up GitHub secrets
Configure GitHub secrets for authentication:
- Navigate to Settings > Secrets & Variables > Actions in your GitHub repository.
- Add a new secret named
SPEAKEASY_API_KEY
which can be obtained from the Speakeasy dashboard.
4. Push to GitHub
Commit and push the generated workflow files to the repository. To test your GitHub Action without modifying any GitHub branches, put the action into mode: test
.
Navigate to Actions in the GitHub repository to trigger the SDK generation workflow manually or wait for it to run automatically. A green checkmark indicates successful workflow completion. If the publishing step has not been configured, it will be skipped.
For details on package publishing, refer to the Publishing SDKs guide.
5. GitHub Actions workflow permissions
If the error 403 GitHub Actions is not permitted to create or approve pull requests
occurs, the repository’s GitHub Actions permissions must be updated.
Navigate to Settings > Actions > Workflow permissions and adjust the permissions accordingly.
Configure remote URLs for schemas
Warning
Remote URLs for OpenAPI schemas must remain stable. Dynamically constructed URLs in workflow files are not supported.
If the OpenAPI schema is hosted in another repository or at a remote URL, set the source
as the remote URL in .speakeasy/workflow.yaml
. Use the following command to add the remote URL:
To authenticate the remote URL, provide a token or key stored as an environment variable (e.g., $OPENAPI_DOC_AUTH_TOKEN
).
Important: When fetching OpenAPI specs from private repositories, ensure that you prefix the token value with “Bearer ” when setting the value. For example:
OPENAPI_DOC_AUTH_TOKEN="Bearer <YOUR_TOKEN_VALUE>"
Add a GitHub Secret (opens in a new tab) with the same name and value as the token or key (including the “Bearer ” prefix for private repositories).