@tkow/bun-google-artifactregistry-auth
v0.0.1
Published
google-artifactregistry-auth is an npm module that allows you to configure npm to interact with npm repositories stored in Artifact Registry with bunfig.
Downloads
502
Maintainers
Readme
Artifact Registry tools for npm packages using bun
This repository contains tools to simplify the process of working with npm packages using Artifact Registry and bun.
This library is inherited from https://github.com/GoogleCloudPlatform/artifact-registry-npm-tools.
Artifact Registry Module
The Artifact Registry google-artifactregistry-auth module is an npm package which allows you to configure npm to interact with npm private repositories in Artifact Registry.
For more details, see https://cloud.google.com/artifact-registry/docs/nodejs/authentication
The module automatically searches for credentials from the environment and authenticates to Artifact Registry. It looks for credentials in the following order:
- Google Application Default Credentials.
- The current active account logged in via
gcloud auth login
. - If neither of them exist, an error occurs.
NOTE: This module would update credentials for all Artifact Registry repositories. It would not be suitable if you use multiple account credentials in npmrc file.
To use the module:
Log in
Option 1: log in as a service account:
(1). Using a JSON file that contains a service account key:
`$ export GOOGLE_APPLICATION_CREDENTIALS=[path/to/key.json]`
(2). Or using gcloud:
`$ gcloud auth application-default login`
Option 2: log in as an end user via gcloud:
$ gcloud auth login
Add settings to connect to the repository to .npmrc. Use the output from the following command:
$ gcloud artifacts print-settings npm
registry=https://LOCATION-npm.pkg.dev/PROJECT_ID/REPOSITORY_ID/ //LOCATION-npm.pkg.dev/PROJECT_ID/REPOSITORY_ID/:always-auth=true
Where
PROJECT_ID is the ID of the project.
REPOSITORY_ID is the ID of the repository.
LOCATION is the location of the repository.
Use one of these below options to run the script
Run the module outside of the directory containing the target npmrc file
$ npx -y @tkow/bun-google-artifactregistry-auth --repo-config=[./.npmrc] --bunfig=[$HOME/.bunfig.toml]
Include the command in the scripts in package.json
"scripts": { "artifactregistry-login": "npx -y @tkow/bun-google-artifactregistry-auth(add if you change paths: --repo-config=[./.npmrc] --bunfig=[$HOME/.bunfig.toml] --bunfig=[$HOME/.bunfig.toml])", }
Where:
--repo-config
is the.npmrc
file with your repository settings. If you don't specify this flag, the default location is the current directory.--bunfig
is the path to thebunfig.toml
file where you want to write the access token. The default is your home$HOME/.bunfig.toml
file.--from
is the path to thebunfig.toml
file where you want to make it base bunfig file. The default is your user$HOME/.bunfig.toml
file.
And then run the script
$ npm run artifactregistry-login
npx
should come withnpm
5.2+. Ifnpx
is not available:Install the module from npmjs.com as a dev dependency and include the command in the script
$ npm install @tkow/bun-google-artifactregistry-auth --save-dev
"scripts": { "artifactregistry-login": "./node_modules/.bin/bun-artifactregistry-auth --repo-config=[./.npmrc] --bunfig=[./bunfig.toml]", }
Run the script
$ npm run artifactregistry-login