Unity PackageManager is an awesome tool and it’s a shame not to use it!
This guide contains step by step instructions on how to create and publish a very own unity package using npmjs as the scope registry for your package. If you are looking for a sample rather then step by step instruction, check out how we did with few of our public packages:
Why bother?
Splitting up large codebases into separate independently versioned packages is extremely useful. Especially for the large project.
- You can work on the isolation and test your package in the clean project rather then working in the main project all the time (could be a lifesaver if you have a very large Unity project).
- Very clean dependencies.
- Easy to share across your company projects or even share with the rest of the world
Why NPMJS?
- It can be consumed by the UPM(Unity Package Manager) system with no issue.
- Even tho npm Registry is a public collection of packages of open-source code for Node.js it can be still used for the Unity package, it looks like more and more companies are choosing npm.
- This is a well-known platform that already has lots of tools built for it.
Another option to consider
I would also recommend considering other options as the public registry for your package, like for example:
-
OpenUPM - Comunity based Open Source Unity Package Registry.
-
GitHub Packages - If you are using GitHub than it may appear like the best option. But there are some known issues with it:
-
The main limitation is discoverability. Even if your Github Packages registry-based scoped registry is correctly configured, packages won’t show up in the Package Manager UI’s All section. GitHub doesn’t support any of the NPM search API endpoints (/-/all or /-/v1/search). You will have to resort to GitHub UI to search packages and manually add them to your project manifest.
-
Even if the GitHub Registry package is public, your users will need to provide authentication.
-
See the Using GitHub Packages Registry with Unity Package Manager forum post for more details.
Let’s assume you already have your package create, and you just want to make it available on npmjs. If you haven’t made one, check your Creating custom packages Unity guide. Now let’s get back to the publishing steps.
- Make an nmpjs account if you do not have one yet.
- Install NodeJS and npm, see the instructions here. If you are using brew as I am, it will be as easy as: brew install node
- Open console or terminal and type npm login.
- Change directory to your package location (this flexibility allows you to not keep your package in the repository root, or even have 1 repository for the multiple packages.)
- Type npm publish --access public
- All set your package is now available on npm.
It’s also recommended to add keys specific to npm into your package.json such as:
- homepage
- bugs
- repository
- license
See the Foundation library package.json sample below:
{
"name": "com.stansassets.foundation",
"displayName": "Stans Assets - Foundation Lib",
"version": "1.0.1",
"unity": "2019.3",
"description": "Foundation package is a collection of utility methods, design patterns, and extensions for Unity.",
"keywords": [
"pattern",
"utility",
"unity",
"stansassets"
],
"homepage": "https://api.stansassets.com/",
"bugs": {
"url": "https://github.com/StansAssets/com.stansassets.foundation/issues"
},
"repository": {
"type": "git",
"url": "ssh://git@github.com:StansAssets/com.stansassets.foundation.git"
},
"license": "MIT",
"author": {
"name": "Stan's Assets",
"email": "stan@stansassets.com",
"url": "https://stansassets.com/"
}
}
Automatically Publish to npm using GitHub Actions
I am as lazy as you are So if something can be automated it had to be done! If you are hosting your repository on GitHub you can automatically Publish to npm using GitHub Actions.
Got to the Actions tab in your repository
Pick set up a workflow yourself option.
I was able to set up new publish action fairly quick thx to Sergio Xalambrí Guide. Check out his awesome guide for a more detailed description.
The workflow script I used
name: Publish to npm
# Controls when the action will run.
# In this case, I'm saying on each release event when it's specifically a new release publish, the types: [published] is required here,
# since releases could also be updated or deleted, we only want to publish to npm when a new release is created (published).
on:
release:
types: [published]
jobs:
build:
runs-on: ubuntu-latest
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
#Install Node.js, with the version 12 and using the registry URL of npm, this could be changed to a custom registry or the GitHub registry.
- uses: actions/setup-node@v1
with:
node-version: 12
registry-url: https://registry.npmjs.org/
# Command to install the package dependencies
- run: yarn install
# Publish to npm
- run: npm publish --access public
env:
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}
Configure the NPM_TOKEN secret
To configure the npm token secret
- Go to https://github.com/$username/$repository/settings/secrets and click on Add a new secret.
- Once you click that button GitHub will show you a form to write the name and the value of the secret.
- In our case, we used NPM_TOKEN as name, for the value.
- Now go to your npmjs.com account.
- Go to https://www.npmjs.com/settings/$username/tokens to get a new token.
- Click the Create New Token button, the token creation form will appear.
- In this form check the first option, read and publish and click on Create Token, this way your token will have access to publish as you.
- Now you will get back to the list of tokens with your new token created and displayed to you, copy it, and go back to GitHub and add it as value.
Once you have done that you will be able to add the secret and use it in your GitHub Actions.
Final Words
I hope that was a helpful small article and we will be able to see a lot more awesome public open-source package for Unity!