# npm-registry-client The code that npm uses to talk to the registry. It handles all the caching and HTTP calls. ## Usage ```javascript var RegClient = require('npm-registry-client') var client = new RegClient(config) var uri = "npm://registry.npmjs.org/npm" var params = {timeout: 1000} client.get(uri, params, function (error, data, raw, res) { // error is an error if there was a problem. // data is the parsed data object // raw is the json string // res is the response from couch }) ``` # Registry URLs The registry calls take either a full URL pointing to a resource in the registry, or a base URL for the registry as a whole (including the registry path – but be sure to terminate the path with `/`). `http` and `https` URLs are the only ones supported. ## Using the client Every call to the client follows the same pattern: * `uri` {String} The *fully-qualified* URI of the registry API method being invoked. * `params` {Object} Per-request parameters. * `callback` {Function} Callback to be invoked when the call is complete. ### Credentials Many requests to the registry can by authenticated, and require credentials for authorization. These credentials always look the same: * `username` {String} * `password` {String} * `email` {String} * `alwaysAuth` {Boolean} Whether calls to the target registry are always authed. **or** * `token` {String} * `alwaysAuth` {Boolean} Whether calls to the target registry are always authed. ## API ### client.access(uri, params, cb) * `uri` {String} Registry URL for the package's access API endpoint. Looks like `/-/package//access`. * `params` {Object} Object containing per-request properties. * `access` {String} New access level for the package. Can be either `public` or `restricted`. Registry will raise an error if trying to change the access level of an unscoped package. * `auth` {Credentials} Set the access level for scoped packages. For now, there are only two access levels: "public" and "restricted". ### client.adduser(uri, params, cb) * `uri` {String} Base registry URL. * `params` {Object} Object containing per-request properties. * `auth` {Credentials} * `cb` {Function} * `error` {Error | null} * `data` {Object} the parsed data object * `raw` {String} the json * `res` {Response Object} response from couch Add a user account to the registry, or verify the credentials. ### client.deprecate(uri, params, cb) * `uri` {String} Full registry URI for the deprecated package. * `params` {Object} Object containing per-request properties. * `version` {String} Semver version range. * `message` {String} The message to use as a deprecation warning. * `auth` {Credentials} * `cb` {Function} Deprecate a version of a package in the registry. ### client.distTags.fetch(uri, params, cb) * `uri` {String} Base URL for the registry. * `params` {Object} Object containing per-request properties. * `package` {String} Name of the package. * `auth` {Credentials} * `cb` {Function} Fetch all of the `dist-tags` for the named package. ### client.distTags.add(uri, params, cb) * `uri` {String} Base URL for the registry. * `params` {Object} Object containing per-request properties. * `package` {String} Name of the package. * `distTag` {String} Name of the new `dist-tag`. * `version` {String} Exact version to be mapped to the `dist-tag`. * `auth` {Credentials} * `cb` {Function} Add (or replace) a single dist-tag onto the named package. ### client.distTags.set(uri, params, cb) * `uri` {String} Base URL for the registry. * `params` {Object} Object containing per-request properties. * `package` {String} Name of the package. * `distTags` {Object} Object containing a map from tag names to package versions. * `auth` {Credentials} * `cb` {Function} Set all of the `dist-tags` for the named package at once, creating any `dist-tags` that do not already exit. Any `dist-tags` not included in the `distTags` map will be removed. ### client.distTags.update(uri, params, cb) * `uri` {String} Base URL for the registry. * `params` {Object} Object containing per-request properties. * `package` {String} Name of the package. * `distTags` {Object} Object containing a map from tag names to package versions. * `auth` {Credentials} * `cb` {Function} Update the values of multiple `dist-tags`, creating any `dist-tags` that do not already exist. Any pre-existing `dist-tags` not included in the `distTags` map will be left alone. ### client.distTags.rm(uri, params, cb) * `uri` {String} Base URL for the registry. * `params` {Object} Object containing per-request properties. * `package` {String} Name of the package. * `distTag` {String} Name of the new `dist-tag`. * `auth` {Credentials} * `cb` {Function} Remove a single `dist-tag` from the named package. ### client.get(uri, params, cb) * `uri` {String} The complete registry URI to fetch * `params` {Object} Object containing per-request properties. * `timeout` {Number} Duration before the request times out. Optional (default: never). * `follow` {Boolean} Follow 302/301 responses. Optional (default: true). * `staleOk` {Boolean} If there's cached data available, then return that to the callback quickly, and update the cache the background. Optional (default: false). * `auth` {Credentials} Optional. * `cb` {Function} Fetches data from the registry via a GET request, saving it in the cache folder with the ETag or the "Last Modified" timestamp. ### client.publish(uri, params, cb) * `uri` {String} The registry URI for the package to publish. * `params` {Object} Object containing per-request properties. * `metadata` {Object} Package metadata. * `access` {String} Access for the package. Can be `public` or `restricted` (no default). * `body` {Stream} Stream of the package body / tarball. * `auth` {Credentials} * `cb` {Function} Publish a package to the registry. Note that this does not create the tarball from a folder. ### client.star(uri, params, cb) * `uri` {String} The complete registry URI for the package to star. * `params` {Object} Object containing per-request properties. * `starred` {Boolean} True to star the package, false to unstar it. Optional (default: false). * `auth` {Credentials} * `cb` {Function} Star or unstar a package. Note that the user does not have to be the package owner to star or unstar a package, though other writes do require that the user be the package owner. ### client.stars(uri, params, cb) * `uri` {String} The base URL for the registry. * `params` {Object} Object containing per-request properties. * `username` {String} Name of user to fetch starred packages for. Optional (default: user in `auth`). * `auth` {Credentials} Optional (required if `username` is omitted). * `cb` {Function} View your own or another user's starred packages. ### client.tag(uri, params, cb) * `uri` {String} The complete registry URI to tag * `params` {Object} Object containing per-request properties. * `version` {String} Version to tag. * `tag` {String} Tag name to apply. * `auth` {Credentials} * `cb` {Function} Mark a version in the `dist-tags` hash, so that `pkg@tag` will fetch the specified version. ### client.unpublish(uri, params, cb) * `uri` {String} The complete registry URI of the package to unpublish. * `params` {Object} Object containing per-request properties. * `version` {String} version to unpublish. Optional – omit to unpublish all versions. * `auth` {Credentials} * `cb` {Function} Remove a version of a package (or all versions) from the registry. When the last version us unpublished, the entire document is removed from the database. ### client.whoami(uri, params, cb) * `uri` {String} The base registry for the URI. * `params` {Object} Object containing per-request properties. * `auth` {Credentials} * `cb` {Function} Simple call to see who the registry thinks you are. Especially useful with token-based auth. ## PLUMBING The below are primarily intended for use by the rest of the API, or by the npm caching logic directly. ### client.request(uri, params, cb) * `uri` {String} URI pointing to the resource to request. * `params` {Object} Object containing per-request properties. * `method` {String} HTTP method. Optional (default: "GET"). * `body` {Stream | Buffer | String | Object} The request body. Objects that are not Buffers or Streams are encoded as JSON. Optional – body only used for write operations. * `etag` {String} The cached ETag. Optional. * `lastModified` {String} The cached Last-Modified timestamp. Optional. * `follow` {Boolean} Follow 302/301 responses. Optional (default: true). * `auth` {Credentials} Optional. * `cb` {Function} * `error` {Error | null} * `data` {Object} the parsed data object * `raw` {String} the json * `res` {Response Object} response from couch Make a generic request to the registry. All the other methods are wrappers around `client.request`. ### client.fetch(uri, params, cb) * `uri` {String} The complete registry URI to upload to * `params` {Object} Object containing per-request properties. * `headers` {Stream} HTTP headers to be included with the request. Optional. * `auth` {Credentials} Optional. * `cb` {Function} Fetch a package from a URL, with auth set appropriately if included. Used to cache remote tarballs as well as request package tarballs from the registry. # Configuration The client uses its own configuration, which is just passed in as a simple nested object. The following are the supported values (with their defaults, if any): * `proxy.http` {URL} The URL to proxy HTTP requests through. * `proxy.https` {URL} The URL to proxy HTTPS requests through. Defaults to be the same as `proxy.http` if unset. * `proxy.localAddress` {IP} The local address to use on multi-homed systems. * `ssl.ca` {String} Certificate signing authority certificates to trust. * `ssl.certificate` {String} Client certificate (PEM encoded). Enable access to servers that require client certificates. * `ssl.key` {String} Private key (PEM encoded) for client certificate. * `ssl.strict` {Boolean} Whether or not to be strict with SSL certificates. Default = `true` * `retry.count` {Number} Number of times to retry on GET failures. Default = 2. * `retry.factor` {Number} `factor` setting for `node-retry`. Default = 10. * `retry.minTimeout` {Number} `minTimeout` setting for `node-retry`. Default = 10000 (10 seconds) * `retry.maxTimeout` {Number} `maxTimeout` setting for `node-retry`. Default = 60000 (60 seconds) * `userAgent` {String} User agent header to send. Default = `"node/{process.version}"` * `log` {Object} The logger to use. Defaults to `require("npmlog")` if that works, otherwise logs are disabled. * `defaultTag` {String} The default tag to use when publishing new packages. Default = `"latest"` * `couchToken` {Object} A token for use with [couch-login](https://npmjs.org/package/couch-login). * `sessionToken` {string} A random identifier for this set of client requests. Default = 8 random hexadecimal bytes.