Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/0xf4b1/tidal-kt

Tidal API client library for Kotlin
https://github.com/0xf4b1/tidal-kt

api client kotlin library tidal

Last synced: 27 days ago
JSON representation

Tidal API client library for Kotlin

Awesome Lists containing this project

README

        

# tidal-kt
Tidal API client library for Kotlin

## Building

`./gradlew jar`

## Usage

### Session

```kotlin
val api = TidalApi(TidalApi.Session(, ::callback))

// Callback to let you save session parameters
private fun callback(session: TidalApi.Session) {
session.userId
session.countryCode
session.accessToken
session.refreshToken
}

// Start new device auth
val verificationUriComplete = api.auth()

// Let the user visit verificationUriComplete and finish auth and
// periodically check if its completed
if (api.getAccessToken()) {
println("Auth complete")
}

// If you have a stored session, you can restore it without starting new auth
api.session.setAuth(, , , )
```

### Tracks

```kotlin
private fun printTracks(tracks: List) {
tracks.forEach { println("id: ${it.id}, artist: ${it.artist}, title: ${it.title}, duration: ${it.duration}, artwork: ${it.artwork}, url: ${it.url}, liked: ${it.liked}") }
}

// Get tracks saved by the user
// You can call this function multiple times to get next results by passing false.
// If you want to refresh and get results from the beginning, you can reset by passing true.
val tracks = api.getTracks(false /* reset? */)
printTracks(tracks)
```

### Artists

```kotlin
private fun printArtists(artists: List) {
artists.forEach { println("id: ${it.id}, name: ${it.name}, artwork: ${it.artwork}, url: ${it.url}") }
}

// Get artists followed by the user
val artists = api.getArtists(false /* reset? */)
printArtists(first)

// Get tracks from the an artist id
val tracks = api.getArtist(artists[0].id, false /* reset? */)
printTracks(tracks)
```

### Mixes

```kotlin
// Get mixes
val tracks = api.getMix(Endpoints.Mixes.MIX_DAILY_DISCOVERY, false /* reset? */)
printTracks(tracks)
```

### Search

```kotlin
// Search for tracks
val tracks = api.query("Solee", false /* reset? */)
printTracks(tracks)
```

### Stream

```kotlin
// Get stream url for track id
val stream = api.getStreamUrl(tracks[0].id)
println("stream: $stream")
```