Reddit provides a very convenient access to its data just by adding .json
to the end of normal URLs. For example, https://www.reddit.com/r/formula1.json
will present you the json response.
This is a very simple wrapper around this feature of Reedit. Thies to grant easy access to subreddit and user data.
Install it as a dependency using Composer
composer require raicem/reddit-public-api-wrapper
use RedditWrapper\Wrapper;
use RedditWrapper\WrapperClient;
$wrapper = new Wrapper(new WrapperClient());
Fetches information about a certain subreddit.
use RedditWrapper\Queries\SubredditQuery;
use RedditWrapper\Enums\SubredditSort;
use RedditWrapper\Enums\SubredditSortTime;
$query = new SubredditQuery([
'subreddit' => 'formula1',
]);
$response = $wrapper->fetch($query);
You may add sort options to your query for best, top, rising, controversial posts in a subreddit.
You may use the constants provided with the RedditWrapper\Enums\SubredditSort
and RedditWrapper\Enums\SubredditSortTime
.
use RedditWrapper\Queries\SubredditQuery;
use RedditWrapper\Enums\SubredditSort;
use RedditWrapper\Enums\SubredditSortTime;
$query = new SubredditQuery([
'subreddit' => 'formula1',
'sort' => SubredditSort::TOP,
'sortTime' => SubredditSortTime::WEEK,
]);
$response = $wrapper->fetch($query);
Fetches the feed belonging to a user.
use RedditWrapper\Queries\UserQuery;
$query = new UserQuery([
'username' => 'unidan',
]);
$response = $wrapper->fetch($query);
All of these queries extends the QueryInterface
in the package. So you can create your own query implementing QueryInterface
in your code base and then provide it to the Wrapper
.
I believe the main function of this library will be to fetch subreddit information. I wanted to streamline that functionality as much as possible.
So without creating a new query, you may call the subreddit's name as a method on this wrapper.
use RedditWrapper\Wrapper;
use RedditWrapper\WrapperClient;
$wrapper = new Wrapper(new WrapperClient());
$response = $wrapper->formula1();
When fetching subreddit information, Reddit sends a lot of information that is probaby not neccessery. The default response can very difficult to get through. fetchSimple
method removes all the clutter and tries to present response with only more general values.
$query = new SubredditQuery([
'subreddit' => 'formula1',
'sort' => SubredditSort::TOP,
'sortTime' => SubredditSortTime::WEEK,
]);
$response = $wrapper->fetchSimple($query);
fetchSimple
method returns these values. This method only works for SubredditQuery
instances.
Value |
---|
title |
id |
thumbnail |
permalink |
num_comments |
score |
created |