Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/master'
Browse files Browse the repository at this point in the history
  • Loading branch information
ryanhcode committed Jun 5, 2021
2 parents db77ea6 + b5fd9c8 commit ad8269b
Showing 1 changed file with 79 additions and 0 deletions.
79 changes: 79 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
# KoPixel
Simple & flexible asynchronous Hypixel API for Kotlin
# KoPixel
[![](https://jitpack.io/v/ryanhcode/KoPixel.svg)](https://jitpack.io/#ryanhcode/KoPixel)

KoPixel is a simple & flexible asynchronous Hypixel API for Kotlin

## Installation

Add the following to your build.gradle(.kts)

```groovy
dependencies {
implementation 'com.github.ryanhcode:KoPixel:$kopixel_version'
}
```
Or visit Jitpack and [select a version](https://jitpack.io/#ryanhcode/KoPixel/latest)

## Usage

In order to obtain a `KoPixelAPI` instance, use NewKoPixelAPI
If you plan on just using the library synchronously, you can use NewKoPixelAPI wherever you like.

```kotlin
val hypixelAPIKey = "..."
val api = NewKoPixelAPI(hypixelAPIKey)
...
```
However, if you are planning to use KoPixel asynchronously, the API must be created inside of a CoroutineScope, or inside of a block such as `runBlocking` which is recommended.
```kotlin
fun main() = runBlocking {
val hypixelAPIKey = "..."
val api = NewKoPixelAPI(hypixelAPIKey)
...
}
```

KoPixel has both asynchronous and synchronous methods for all functions.

Here you can see a method of synchronously obtaining if a player is online:
```kotlin
val online = api.getSync("skyf").online()
println("Online: $online")
```
And here is a asynchronous method of obtaining if a player is online:
```kotlin
api.get("skyf").whenComplete { player->
val online = player.online()
println("Online: $online")
}
```
If you choose to use KoPixel asynchronously, you may also use error handling for all requests.
```kotlin
api.get("skyf").whenComplete { player->
val online = player.online()
println("Online: $online")
}.catch { exception ->
println("woah! there was an error: $exception")
}
```
Here you can see an example of utilizing KoPixel's asynchronous API to scan a player for Exotic Armor:
```kotlin
fun scan(uuid: UUID) {
// Grab the profiles of the player asynchronously
api.getSkyblockProfiles(uuid).whenComplete { profiles ->
profiles.forEach { profile ->
profile.scan { uuid, member, inv, item ->
if (item.colorable() && item.exotic())
println("Exotic Found: \n\t${item.id()} \n\t${item.hexColor()} \n\t$uuid \n\t${inv.name}")
}
}
}.catch { exception -> println("Swallowing exception.") }
}
scan("cab60d114bd84d5fbcc46383ee8f6ed1".toUUID())
```
KoPixel currently supports a portion of the skyblock API and regular player API, although status, guild, auction, bazaar, and dungeon implementations are planned for the near future.

## License
[MIT](https://choosealicense.com/licenses/mit/)

0 comments on commit ad8269b

Please sign in to comment.