Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/n6g7/damn
Node.js DeviantArt API client
https://github.com/n6g7/damn
api client damn deviantart node rest
Last synced: 2 months ago
JSON representation
Node.js DeviantArt API client
- Host: GitHub
- URL: https://github.com/n6g7/damn
- Owner: n6g7
- License: mit
- Created: 2015-07-20T20:54:36.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-05-24T22:13:20.000Z (8 months ago)
- Last Synced: 2024-10-18T19:06:09.939Z (3 months ago)
- Topics: api, client, damn, deviantart, node, rest
- Language: JavaScript
- Size: 287 KB
- Stars: 9
- Watchers: 4
- Forks: 4
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# dAmn
[![CircleCI](https://circleci.com/gh/n6g7/damn.svg?style=svg)](https://circleci.com/gh/n6g7/damn) [![npm version](https://badge.fury.io/js/damn.svg)](https://badge.fury.io/js/damn) [![Coverage Status](https://coveralls.io/repos/github/n6g7/damn/badge.svg?branch=master)](https://coveralls.io/github/n6g7/damn?branch=master) [![bitHound Score](https://www.bithound.io/github/n6g7/damn/badges/score.svg)](https://www.bithound.io/github/n6g7/damn)Node.js DeviantArt API client
## Quick start
Install:
```shell
yarn add damn
``````js
const Damn = require('damn');const clientId = 1234
const clientSecret = 'thisissecret'Damn.clientCredentials(clientId, clientSecret)
.then(damn => damn.getDailyDeviations())
.then(dailyDeviations => {
...
})```
## Client generation
dAmn currently supports two [authentication methods](https://www.deviantart.com/developers/authentication): *Client Credentials* and *Implicit*.
Both provide access to public endpoints but only the *Implicit* method grants access to user-specific APIs.Both methods require a `client_id` and a `client_secret` to be granted an access token. These are obtained by creating an app in [DeviantArt's application page](https://www.deviantart.com/developers/apps).
### Public API
The easiest way to access public API is to use the *Client Credentials* method, which is available via `Damn.clientCredentials`:```js
Damn.clientCredentials('4321', 'cl13nt_s3cr3t')
.then(damn => {
damn.getDailyDeviations()
...
})
```Where `4321` is your `client_id` and `cl13nt_s3cr3t` is your `client_secret`.
The `Damn.clientCredentials()` call returns a promise which resolves to a `Damn` object, from which you can call the methods marked *public* described below.
### Logged-in API
Accessing user-specific endpoints can only be done when using the *Implicit* authentication method. This methods requires you to provide an username, a password, a `client_id` and a `redirect_uri` for the application you created.If you're using this method, make sure your "OAuth2 Grant Type" settings is set to "Implicit" in your application parameters:
![DA application's OAuth Grant Type setting](doc/oauth-setting.png)To instanciate a "private" client you may use the `Damn.implicit` method:
```js
const clientId = 1234
const redirectUri = 'https://www.example.com'
const username = 'toto'
const password = 'h4xXx0r'
const scope = 'basic'Damn.implicit(clientId, redirectUri, username, password, scope)
.then(damn => {
damn.getDailyDeviations()
...
})
```The `Damn.implicit()` call returns a promise which resolves to a `Damn` object, from which you can call all the methods described below.
## Methods
All these methods are asynchronous and return promises.
### getDailyDeviations(*qs*)
> Public endpoint
Returns the list of today's [daily deviations](http://www.deviantart.com/dailydeviations/):
```js
damn.getDailyDeviations()
.then(dailyDeviations => {
...
})
```**Parameters**:
- `qs` (object): additional query parameters (eg. for pagination)### getNotifications(*qs*)
> Private endpoint
Returns the list of current user notifications:
```js
damn.getNotifications()
.then(notifications => {
...
})
```**Parameters**:
- `qs` (object): additional query parameters (eg. for pagination)### getWatchFeed(*qs*)
> Private endpoint
Returns the current user's watch feed:
```js
damn.getWatchFeed()
.then(feed => {
...
})
```**Parameters**:
- `qs` (object): additional query parameters (eg. for pagination)### getDeviation(*deviationId*, *qs*)
> Public endpoint
Returns the details of a specific deviation:
```js
const deviationId = 12345damn.getDeviation(deviationId)
.then(deviation => {
...
})
```**Parameters**:
- `deviationId` (string): the deviation id.
- `qs` (object): additional query parameters (eg. for pagination)### galleryAll(*username*, *qs*)
> Public endpoint
Returns the list of a user's deviations:
```js
const username = 'sdqlm'damn.galleryAll(username)
.then(deviations => {
...
})
```**Parameters**:
- `username` (string): optional `username`, defaults to current user
- `qs` (object): additional query parameters (eg. for pagination)### galleryFolder(*folderId*, *username*, *qs*)
> Public endpoint
Returns the list of a folder's deviations (all user's deviations if no `folderId` is given):
```js
const folderId = 12345damn.galleryFolder(folderId)
.then(deviations => {
...
})
```**Parameters**:
- `folderId` (string): optional `folderId`
- `username` (string): optional `username`, defaults to current user
- `qs` (object): additional query parameters (eg. for pagination)### galleryFolders(*username*, *qs*)
> Public endpoint
Returns the list of an user's gallery folders:
```js
const username = 'qpsdlq'damn.galleryFolders(username)
.then(deviations => {
...
})
```**Parameters**:
- `username` (string): optional `username`, defaults to current user
- `qs` (object): additional query parameters (eg. for pagination)### userFriends(*username*, *qs*)
> Public endpoint
Returns a list of the user's watched friends:
```js
const username = 'qpsdlq'damn.userFriends(username)
.then(friends => {
...
})
```**Parameters**:
- `username` (string): username to search for friends of
- `qs` (object): additional query parameters (eg. for pagination)### userFriendsSearch(*username*, *query*)
> Public endpoint
Returns a list of the user's watched friends:
```js
const username = 'qpsdlq'
const query = 'bob'damn.userFriendsSearch(username, query)
.then(friends => {
...
})
```**Parameters**:
- `username` (string): username to search for friends of
- `query` (string): Search query (min length: 1)### placebo()
> Public endpoint
Implementation of DA's [placebo](https://www.deviantart.com/developers/http/v1/20150824/placebo/53b9f8bd16df06555acb1dfc06e6df69) route. Use it to check you access token validity. Or better yet, use `checkAccessToken()`!
```js
damn.placebo.then(placebo => {
...
})
```### checkAccessToken()
Check the validity of your access token, returns a boolean.
```js
damn.checkAccessToken.then(validToken => {
...
})
```## Todo
- [X] Use [Node.js v4.0.0](https://github.com/nodejs/node/blob/v4.0.0/CHANGELOG.md) and ES6 features
- [ ] Automate token refresh
- [X] Setup linter
- [ ] Add access to the following routes:
- [X] `/user/friends/{username}` Get a list of watched friends
- [X] `/user/friends/search` Search a list of watched friends
- [X] `/deviation/{deviationid}` Fetch a deviation
- [ ] `/deviation/content` Fetch full data that is not included in the main deviation object
- [ ] `/browse/morelikethis` Fetch MoreLikeThis result for a seed deviation
- [ ] `/browse/newest` Browse newest deviations
- [ ] `/browse/popular` Browse popular deviations
- [ ] `/browse/hot` Browse whats hot deviations
- [ ] and all others routes ?
- [ ] Revoke access / logout
- [ ] Find a way to implement [Authorization Code](https://www.deviantart.com/developers/authentication) as an authentication method
- [X] Support for pagination params