Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/netlify/js-client
A Open-API derived JS + Node.js API client for Netlify
https://github.com/netlify/js-client
api api-client api-rest javascript js-client netlify nodejs openapi rest swagger
Last synced: 2 months ago
JSON representation
A Open-API derived JS + Node.js API client for Netlify
- Host: GitHub
- URL: https://github.com/netlify/js-client
- Owner: netlify
- Archived: true
- Created: 2014-10-11T07:28:03.000Z (over 10 years ago)
- Default Branch: main
- Last Pushed: 2022-10-10T13:03:48.000Z (over 2 years ago)
- Last Synced: 2024-11-07T14:47:22.787Z (3 months ago)
- Topics: api, api-client, api-rest, javascript, js-client, netlify, nodejs, openapi, rest, swagger
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/netlify
- Size: 7.63 MB
- Stars: 215
- Watchers: 23
- Forks: 43
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
> ## !important Notice
>
> This repository was moved into the mono repository of [github.com/netlify/build](https://github.com/netlify/build) The
> package name and the versions are preserved!![netlify/js-client](js-client.png)
[![npm version][npm-img]][npm] [![build status][build-img]][build] [![coverage][coverage-img]][coverage]
[![dependencies][david-img]][david] [![downloads][dl-img]][dl]A Netlify [OpenAPI](https://github.com/netlify/open-api) client that works in the browser and Node.js.
## Usage
```js
import { NetlifyAPI } from 'netlify'const client = new NetlifyAPI('1234myAccessToken')
const sites = await client.listSites()
```## Using OpenAPI operations
```js
import { NetlifyAPI } from 'netlify'const client = new NetlifyAPI('1234myAccessToken')
// Fetch sites
const sites = await client.listSites()// Create a site. Notice `body` here for sending OpenAPI body
const site = await client.createSite({
body: {
name: `my-awesome-site`,
// ... https://open-api.netlify.com/#/default/createSite
},
})// Delete site. Notice `site_id` is a path parameter https://open-api.netlify.com/#/default/deleteSite
await client.deleteSite({ site_id: siteId })
```## API
### `client = new NetlifyAPI([accessToken], [opts])`
Create a new instance of the Netlify API client with the provided `accessToken`.
`accessToken` is optional. Without it, you can't make authorized requests.
`opts` includes:
```js
const opts = {
userAgent: 'netlify/js-client',
scheme: 'https',
host: 'api.netlify.com',
pathPrefix: '/api/v1',
accessToken: '1234myAccessToken',
agent: undefined, // e.g. HttpsProxyAgent
globalParams: {}, // parameters you want available for every request.
// Global params are only sent of the OpenAPI spec specifies the provided params.
}
```### `client.accessToken`
A setter/getter that returns the `accessToken` that the client is configured to use. You can set this after the class is
instantiated, and all subsequent calls will use the newly set `accessToken`.### `client.basePath`
A getter that returns the formatted base URL of the endpoint the client is configured to use.
### OpenAPI Client methods
The client is dynamically generated from the [OpenAPI](https://github.com/netlify/open-api) definition file. Each method
is is named after the `operationId` name of each operation. **To see a list of available operations, please see the
[OpenAPI website](https://open-api.netlify.com/)**.Every OpenAPI operation has the following signature:
#### `response = await client.operationId([params], [opts])`
Performs a call to the given endpoint corresponding with the `operationId`. Returns a promise resolved with the body of
the response, or rejected with an error with the details about the request attached. Rejects if the `status` > 400.- `params` is an object that includes any of the required or optional endpoint parameters.
- `params.body` should be an object which gets serialized to JSON automatically. Any object can live here but refer to
the OpenAPI specification for allowed fields in a particular request body. It can also be a function returning an
object.
- If the endpoint accepts `binary`, `params.body` can be a Node.js readable stream or a function returning one (e.g.
`() => fs.createReadStream('./foo')`). Using a function is recommended.```js
// example params
const params = {
any_param_needed: anyParamNeeded,
paramsCanAlsoBeCamelCase,
body: {
an: 'arbitrary js object',
},
}
```Optional `opts` can include any property you want passed to [`node-fetch`](https://github.com/bitinn/node-fetch). The
`headers` property is merged with some `defaultHeaders`.```js
// example opts
const opts = {
headers: {
// Default headers
'User-agent': 'netlify-js-client',
accept: 'application/json',
},
// any other properties for node-fetch
}
```All operations are conveniently consumed with async/await:
```js
try {
const siteDeploy = await client.getSiteDeploy({
siteId: '1234abcd',
deploy_id: '4567',
})
// Calls may fail!
} catch {
// handle error
}
```If the response includes `json` in the `contentType` header, fetch will deserialize the JSON body. Otherwise the `text`
of the response is returned.### API Flow Methods
Some methods have been added in addition to the open API operations that make certain actions simpler to perform.
#### `accessToken = await client.getAccessToken(ticket, [opts])`
Pass in a [`ticket`](https://open-api.netlify.com/#model-ticket) and get back an `accessToken`. Call this with the
response from a `client.createTicket({ client_id })` call. Automatically sets the `accessToken` to `this.accessToken`
and returns `accessToken` for the consumer to save for later.Optional `opts` include:
```js
const opts = {
poll: 1000, // number of ms to wait between polling
timeout: 3.6e6, // number of ms to wait before timing out
}
```See the [authenticating](https://www.netlify.com/docs/api/#authenticating) docs for more context.
```js
import open from 'open'const ticket = await client.createTicket({ clientId: CLIENT_ID })
// Open browser for authentication
await open(`https://app.netlify.com/authorize?response_type=ticket&ticket=${ticket.id}`)// API is also set up to use the returned access token as a side effect
// Save this for later so you can quickly set up an authenticated client
const accessToken = await client.getAccessToken(ticket)
```## Proxy support
**Node.js only**: If this client is used behind a corporate proxy, you can pass an `HttpsProxyAgent` or any other
`http.Agent` that can handle your situation as `agent` option:```js
import HttpsProxyAgent from 'https-proxy-agent'const proxyUri = 'http(s)://[user:password@]proxyhost:port'
const agent = new HttpsProxyAgent(proxyUri)
const client = new NetlifyAPI('1234myAccessToken', { agent })
```## Site deployment
Support for site deployment has been removed from this package in version 7.0.0. You should consider using the
[`deploy` command](https://cli.netlify.com/commands/deploy/) of Netlify CLI.## Contributing
See [CONTRIBUTING.md](CONTRIBUTING.md) for more info on how to make contributions to this project.
## License
MIT. See [LICENSE](LICENSE) for more details.
[npm-img]: https://img.shields.io/npm/v/netlify.svg
[npm]: https://npmjs.org/package/netlify
[build-img]: https://github.com/netlify/js-client/workflows/Build/badge.svg
[build]: https://github.com/netlify/js-client/actions
[dl-img]: https://img.shields.io/npm/dm/netlify.svg
[dl]: https://npmjs.org/package/netlify
[coverage-img]: https://codecov.io/gh/netlify/js-client/branch/main/graph/badge.svg
[coverage]: https://codecov.io/gh/netlify/js-client
[david-img]: https://david-dm.org/netlify/js-client/status.svg
[david]: https://david-dm.org/netlify/js-client