v1.2.1
Published
Simple Reddit API client
Downloads
935
Maintainers
Readme
Simple Reddit API client
Install
npm install reddit
This package is used by BitMidi to post MIDI files to the /r/BitMidi subreddit.
Features
- Lightweight – no unecessary dependencies, easy-to-audit source code
- Modern API – uses async/await and promises
- Powered by the official Reddit API
Usage
First, create a Reddit App.
- Click "Create app"
- For simple scripts, you can select a type of "script".
- You can enter anything in the "about URL" and "redirect URL" fields.
- Note your app ID (appears below the app name) and your app secret.
Now, let's take an action on Reddit:
const Reddit = require('reddit')
const reddit = new Reddit({
username: 'TODO',
password: 'TODO',
appId: 'TODO',
appSecret: 'TODO',
userAgent: 'MyApp/1.0.0 (http://example.com)'
})
// Submit a link to the /r/BitMidi subreddit
const res = await reddit.post('/api/submit', {
sr: 'WeAreTheMusicMakers',
kind: 'link',
resubmit: true,
title: 'BitMidi – 100K+ Free MIDI files',
url: 'https://bitmidi.com'
})
console.log(res)
// Prints:
// {
// json: {
// errors: [],
// data: {
// url: 'https://www.reddit.com/r/WeAreTheMusicMakers/comments/96ak55/',
// drafts_count: 0,
// id: '96ak55',
// name: 't3_96ak55'
// }
// }
// }
API
reddit = new Reddit(opts)
Create a new Reddit API client.
You must provide opts
, an object with the following required properties:
username
- Username of the reddit userpassword
- Password of the reddit userappId
- Reddit App IDappSecret
- Reddit App Secret
The following opts
properties are optional:
opts.userAgent
- String to use as theUser-Agent
header in http requests
reddit.get(url, [data])
Invoke the Reddit API using the GET
HTTP method.
The url
parameter is used to specify which API to invoke. For example, /api/submit
or /api/vote
. A complete listing of possible APIs is available in the Reddit API documentation.
The optional data
parameter is used to specify relevant data for the selected API. The necessary data varies depending on which API is being used. Again, see the Reddit API documentation.
reddit.post(url, [data])
Invoke the Reddit API using the POST
HTTP method.
reddit.patch(url, [data])
Invoke the Reddit API using the PATCH
HTTP method.
reddit.put(url, [data])
Invoke the Reddit API using the PUT
HTTP method.
reddit.delete(url, [data])
Invoke the Reddit API using the DELETE
HTTP method.
License
The Prosperity Public License. Copyright (c) Feross Aboukhadijeh.
To obtain a commercial license, visit feross.org/commercial.