Skip to content

Latest commit

 

History

History
84 lines (60 loc) · 3.79 KB

README.md

File metadata and controls

84 lines (60 loc) · 3.79 KB

#Java Reddit API Wrapper

travis-ci build status Coverage Status Reddit API coverage

JRAW is currently in an experimental stage, and therefore subject to application-breaking API changes that could occur at any time before v1.0.

##Notable Features

  • Java 7 compatible
  • Mini HTTP framework that wraps OkHttp
  • Basic site actions (login, vote, submit, comment, read inbox, etc.)
  • Full multireddit support
  • Full captcha support
  • Get trending subreddits
  • Get random posts and subreddits
  • Incubating OAuth2 usage

##Getting Started ####Adding the Dependency

JRAW is hosted on Bintray's jCenter.

Gradle:

repositories {
    jcenter()
}

dependencies {
    compile(group: 'net.dean.jraw', name: 'JRAW', version: '0.5.0')
}

Maven:

Add jCenter to your repositories (see here and press "Set me up!" on the right hand side) and then add the repository:

<dependency>
    <groupId>net.dean.jraw</groupId>
    <artifactId>JRAW</artifactId>
    <version>0.5.0</version>
</dependency>

####Using the Library See the wiki to get you up and running

Javadoc can be found here

##Building

JRAW uses Gradle as its build system. If you're coming from a Maven background, you can read this StackOverflow question to help you get started.

./gradlew release will generate four Jar files in build/releases/: a normal jar with just the library, a "fat" jar with all of JRAW's runtime dependencies, a Javadoc jar, and a sources jar. See here for an example.

./gradlew test will run the unit tests

##Contributing

Before contributing, it is recommended that you have a decent knowledge of how the Reddit API works.

Some references:

####Want to contribute? Follow these steps:

  1. Fork the repository
  2. Put your testing user's credentials in /src/test/java/resources/credentials.json. It should be in this format
  3. Add your code. Implement an endpoint, make the code prettier, or even just fix up some whitespace or documentation.
  4. Write TestNG tests covering your changes
  5. Test your code by executing ./gradlew test
  6. Update ENDPOINTS.md and Endpoints.java by running ./gradlew endpoints:update
  7. Send the pull request

####Creating a user for unit testing

  1. It is recommended to create an entire new user for the unit testing, since this library aims to test all endpoints (including moderation tasks and submitting and deleting submissions and comments).
  2. Create a multireddit whose name is not "jraw_testing", containing at least one subreddit
  3. Create a Reddit app. The type is recommended to be 'script'.
  4. Be a moderator of at least one subreddit. See here to create one.
  5. Submit at least one selfpost (how about on /r/jraw_testing2?)