Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
package

GitHub Action

Publish VS Code Extension

v0

Publish VS Code Extension

package

Publish VS Code Extension

Publish your VSCode extension to the VS Marketplace (using vsce) or the Open VSX Registry (using ovsx) with ease

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Publish VS Code Extension

uses: HaaLeo/publish-vscode-extension@v0

Learn more about this action in HaaLeo/publish-vscode-extension

Choose a version

Publish VS Code Extension — GitHub Action

Build, Lint, Test and Deploy Coverage Status
License Stars
David David
Donate

GitHub action to publish your VS Code Extension to the Open VSX Registry or the Visual Studio Marketplace.

Usage

To use the GitHub Action, just reference the action in your workflow file.

Example

The following example shows a workflow that publishes an extension to the Open VSX Registry as well as to the Visual Studio Marketplace when a new tag was created:

on:
  push:
    tags:
      - "*"

name: Deploy Extension
jobs:
  deploy:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      - uses: actions/setup-node@v1
        with:
          node-version: 12
      - run: npm ci
      - name: Publish to Open VSX Registry
        uses: HaaLeo/publish-vscode-extension@v0
        with:
          pat: ${{ secrets.OPEN_VSX_TOKEN }}
      - name: Publish to Visual Studio Marketplace
        uses: HaaLeo/publish-vscode-extension@v0
        with:
          pat: ${{ secrets.VS_MARKETPLACE_TOKEN }}
          registryUrl: https://marketplace.visualstudio.com

To package the extension only once and publish the identical .vsix file to both registries one can use the following two steps instead:

- name: Publish to Open VSX Registry
  uses: HaaLeo/publish-vscode-extension@v0
  id: publishToOpenVSX
  with:
    pat: ${{ secrets.OPEN_VSX_TOKEN }}
- name: Publish to Visual Studio Marketplace
  uses: HaaLeo/publish-vscode-extension@v0
  with:
    pat: ${{ secrets.VS_MARKETPLACE_TOKEN }}
    registryUrl: https://marketplace.visualstudio.com
    extensionFile: ${{ steps.publishToOpenVSX.outputs.vsixPath }}
    packagePath: ''

Open VSX Registry

To publish to the Open VSX Registry ensure that your extension's namespace was created beforehand. You need to set the pat parameter to your Open VSX access token. Further, you should ensure that you only publish an extension which is licensed. For more information regarding Open VSX' timeline and its extensions' licensing check out Brian King's blog (section "Licensing" and "Timeline").

Currently, this GitHub action allows you to publish extensions which do not state their license terms. However, this behavior is deprecated and a future release of this action will reject unlicensed extensions. Therefore, I heavily encourage you to publish an extension with a (permissive) license such as the MIT license.

Visual Studio Marketplace

In order to upload your extension to the VS Marketplace you need to set the pat option to the corresponding access token. Further, the registryUrl must be set to https://marketplace.visualstudio.com.

Input Parameters

You can set any or all of the following input parameters:

Name Type Required? Default Description
pat string yes - The personal access token to the corresponding registry.
extensionFile string no - Path to the vsix file to be published. Cannot be used together with packagePath.
registryUrl string no https://open-vsx.org Use the registry API at this base URL
packagePath string no ./ Path to the extension to be packaged and published. Cannot be used together with extensionFile.
baseContentUrl string no - Prepend all relative links in README.md with this URL.
baseImagesUrl string no - Prepend all relative image links in README.md with this URL.
yarn boolean no false Use yarn instead of npm while packing extension files.
dryRun boolean no false Set this option to true to package your extension but do not publish it. When using this option set the pat option to a stub value.
noVerify boolean no false Allow publishing extensions to the visual studio marketplace which use a proposed API (enableProposedApi: true). Similar to vsce's --noVerify command line argument.

Outputs

The action exposes the following outputs:

Name Type Description
vsixPath string The path to the packaged and published VSIX file.

Contribution

If you found a bug or are missing a feature do not hesitate to file an issue.
Pull Requests are welcome!

Support

When you like this extension make sure to star the repo. I am always looking for new ideas and feedback.
In addition, it is possible to donate via paypal.