Skip to content

Installing Internal packages

To install internal/private packages, you will need to setup Azure Artifact Credentials. These credentials ensure that only authorized users can use these packages, which helps teams work together more effectively. By having the right access, engineers can easily integrate these private packages into their development processes.

Setting Up Azure Artifacts Credentials

Step 1 - Creating .npmrc file

Create a .npmrc file at the root of your home directory

bash
/home/your-username/
├── .npmrc          <-- Global .npmrc configuration here
├── other-files-and-directories

Next, paste in the following snippet in the .npmrc file:

bash
@hubtel:registry=https://pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/registry/
always-auth=true

; begin auth token
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/registry/:username=hubtel
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/registry/:_password=[BASE64_ENCODED_PERSONAL_ACCESS_TOKEN]
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/registry/:email=npm requires email to be set but doesn't use the value
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/:username=hubtel
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/:_password=[BASE64_ENCODED_PERSONAL_ACCESS_TOKEN]
//pkgs.dev.azure.com/hubtel/_packaging/hubtel/npm/:email=npm requires email to be set but doesn't use the value
; end auth token

Step 2 - Creating a personal access token

  1. Next, you have to generate a Personal Access Token

  2. Click on New Token, this should open up a modal.

  3. Define a name for the personal access token. Under Scopes, scroll to Packaging and tick the Read checkbox (the read checkbox under the Packaging section). PAT creation

  4. Click Create to generate the token, and make sure to copy it, as you won't be able to see it again. PAT creation

Step 3 - Base64 encode the personal access token from Step 2.

  1. From a command/shell prompt run:
bash
node -e "require('readline') .createInterface({input:process.stdin,output:process.stdout,historySize:0}) .question('PAT> ',p => { b64=Buffer.from(p.trim()).toString('base64');console.log(b64);process.exit(); })"
  1. Paste your personal access token value and press Enter/Return
  2. Copy the Base64 encoded value

Step 4

Replace both [BASE64_ENCODED_PERSONAL_ACCESS_TOKEN] values in your .npmrc file with the Base64 encoded value from Step 3.

You can now install internal npm packages from Hubtel's private registry, ensuring secure access and streamlining your development process.