node/deps/npm/node_modules/npm-registry-client/README.md

188 lines
6.5 KiB
Markdown
Raw Normal View History

2012-06-12 00:30:44 +08:00
# 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')
2012-08-22 06:29:03 +08:00
var client = new RegClient(config)
2014-08-01 00:05:30 +08:00
var uri = "npm://registry.npmjs.org/npm"
var options = {timeout: 1000}
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
client.get(uri, options, function (error, data, raw, res) {
2012-06-12 00:30:44 +08:00
// 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
})
```
2014-08-01 00:05:30 +08:00
# 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 (for the base URL, any path
will be ignored). In addition to `http` and `https`, `npm` URLs are allowed.
`npm` URLs are `https` URLs with the additional restrictions that they will
always include authorization credentials, and the response is always registry
metadata (and not tarballs or other attachments).
2012-08-22 06:29:03 +08:00
# Configuration
This program is designed to work with
[npmconf](https://npmjs.org/package/npmconf), but you can also pass in
a plain-jane object with the appropriate configs, and it'll shim it
for you. Any configuration thingie that has get/set/del methods will
also be accepted.
2012-06-12 00:30:44 +08:00
* `cache` **Required** {String} Path to the cache folder
2012-08-22 06:29:03 +08:00
* `always-auth` {Boolean} Auth even for GET requests.
2012-06-12 00:30:44 +08:00
* `auth` {String} A base64-encoded `username:password`
* `email` {String} User's email address
* `tag` {String} The default tag to use when publishing new packages.
Default = `"latest"`
* `ca` {String} Cerficate signing authority certificates to trust.
2013-12-17 08:23:13 +08:00
* `cert` {String} Client certificate (PEM encoded). Enable access
to servers that require client certificates
* `key` {String} Private key (PEM encoded) for client certificate 'cert'
2012-08-22 06:29:03 +08:00
* `strict-ssl` {Boolean} Whether or not to be strict with SSL
2012-06-12 00:30:44 +08:00
certificates. Default = `true`
2012-08-22 06:29:03 +08:00
* `user-agent` {String} User agent header to send. Default =
2013-02-07 00:39:27 +08:00
`"node/{process.version} {process.platform} {process.arch}"`
2012-06-12 00:30:44 +08:00
* `log` {Object} The logger to use. Defaults to `require("npmlog")` if
that works, otherwise logs are disabled.
2012-08-22 06:29:03 +08:00
* `fetch-retries` {Number} Number of times to retry on GET failures.
Default=2
2012-08-22 06:29:03 +08:00
* `fetch-retry-factor` {Number} `factor` setting for `node-retry`. Default=10
* `fetch-retry-mintimeout` {Number} `minTimeout` setting for `node-retry`.
Default=10000 (10 seconds)
2012-08-22 06:29:03 +08:00
* `fetch-retry-maxtimeout` {Number} `maxTimeout` setting for `node-retry`.
Default=60000 (60 seconds)
2012-08-22 06:29:03 +08:00
* `proxy` {URL} The url to proxy requests through.
* `https-proxy` {URL} The url to proxy https requests through.
Defaults to be the same as `proxy` if unset.
* `_auth` {String} The base64-encoded authorization header.
* `username` `_password` {String} Username/password to use to generate
`_auth` if not supplied.
* `_token` {Object} A token for use with
[couch-login](https://npmjs.org/package/couch-login)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.request(method, uri, options, cb)
2012-06-12 00:30:44 +08:00
* `method` {String} HTTP method
2014-08-01 00:05:30 +08:00
* `uri` {String} URI pointing to the resource to request
* `options` {Object} Object containing optional per-request properties.
* `what` {Stream | Buffer | String | Object} The request body. Objects
that are not Buffers or Streams are encoded as JSON.
* `etag` {String} The cached ETag
* `follow` {Boolean} Follow 302/301 responses (defaults to true)
2012-06-12 00:30:44 +08:00
* `cb` {Function}
* `error` {Error | null}
* `data` {Object} the parsed data object
* `raw` {String} the json
* `res` {Response Object} response from couch
2014-08-01 00:05:30 +08:00
Make a request to the registry. All the other methods are wrappers around
`request`.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.adduser(base, username, password, email, cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `base` {String} Base registry URL
2012-06-12 00:30:44 +08:00
* `username` {String}
* `password` {String}
* `email` {String}
* `cb` {Function}
Add a user account to the registry, or verify the credentials.
2014-08-01 00:05:30 +08:00
# client.deprecate(uri, version, message, cb)
2013-12-17 08:23:13 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} Full registry URI for the deprecated package
2013-12-17 08:23:13 +08:00
* `version` {String} Semver version range
* `message` {String} The message to use as a deprecation warning
* `cb` {Function}
Deprecate a version of a package in the registry.
2014-08-01 00:05:30 +08:00
# client.bugs(uri, cb)
2013-12-17 08:23:13 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} Full registry URI for the package
2013-12-17 08:23:13 +08:00
* `cb` {Function}
Get the url for bugs of a package
2014-08-01 00:05:30 +08:00
# client.get(uri, options, cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The complete registry URI to fetch
* `options` {Object} Object containing optional per-request properties.
* `timeout` {Number} Duration before the request times out.
* `follow` {Boolean} Follow 302/301 responses (defaults to true)
* `staleOk` {Boolean} If there's cached data available, then return that
to the callback quickly, and update the cache the background.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
Fetches data from the registry via a GET request, saving it in the cache folder
with the ETag.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.publish(uri, data, tarball, cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The registry URI to publish to
2012-06-12 00:30:44 +08:00
* `data` {Object} Package data
* `tarball` {String | Stream} Filename or stream of the package tarball
* `cb` {Function}
Publish a package to the registry.
2014-08-01 00:05:30 +08:00
Note that this does not create the tarball from a folder. However, it can
accept a gzipped tar stream or a filename to a tarball.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.star(uri, starred, cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The complete registry URI to star
2012-06-12 00:30:44 +08:00
* `starred` {Boolean} True to star the package, false to unstar it.
* `cb` {Function}
Star or unstar a package.
2014-08-01 00:05:30 +08:00
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.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.stars(base, username, cb)
2013-02-16 02:49:16 +08:00
2014-08-01 00:05:30 +08:00
* `base` {String} The base URL for the registry
2013-02-16 02:49:16 +08:00
* `username` {String} Name of user to fetch starred packages for.
* `cb` {Function}
View your own or another user's starred packages.
2014-08-01 00:05:30 +08:00
# client.tag(uri, version, tag, cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The complete registry URI to tag
2012-06-12 00:30:44 +08:00
* `version` {String} Version to tag
* `tag` {String} Tag name to apply
* `cb` {Function}
2014-08-01 00:05:30 +08:00
Mark a version in the `dist-tags` hash, so that `pkg@tag` will fetch the
specified version.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.unpublish(uri, [ver], cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The complete registry URI to unpublish
2012-06-12 00:30:44 +08:00
* `ver` {String} version to unpublish. Leave blank to unpublish all
versions.
* `cb` {Function}
2014-08-01 00:05:30 +08:00
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.
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
# client.upload(uri, file, [etag], [nofollow], cb)
2012-06-12 00:30:44 +08:00
2014-08-01 00:05:30 +08:00
* `uri` {String} The complete registry URI to upload to
2012-06-12 00:30:44 +08:00
* `file` {String | Stream} Either the filename or a readable stream
* `etag` {String} Cache ETag
* `nofollow` {Boolean} Do not follow 301/302 responses
* `cb` {Function}
Upload an attachment. Mostly used by `client.publish()`.