This project is a wrapper for the Spotify Web API. It uses Retrofit to create Java interfaces from API endpoints.
This project is built using Gradle:
- Clone the repository:
git clone https://github.com/kaaes/spotify-web-api-android.git
- Build:
./gradlew assemble
- Grab the
aar
that can be found inbuild/outputs/aar/spotify-web-api-android-0.1.0.aar
and put it in thelibs
folder in your application
This project depends on Retrofit 1.9.0
and OkHttp 2.2.0
. When you build it, it creates an aar
that doesn't contain Retrofit and OkHttp files. To make your app work you'll need to include these
dependencies in your app's gradle.build
file.
The repositories
section tells your application to look for the spotify-web-api-android-0.1.0.aar
in the local repository in the libs
folder.
Add following to the gradle.build
file in your app:
repositories {
mavenCentral()
flatDir {
dirs 'libs'
}
}
dependencies {
compile(name:'spotify-web-api-android-0.1.0', ext:'aar')
compile 'com.squareup.retrofit:retrofit:1.9.0'
compile 'com.squareup.okhttp:okhttp:2.2.0'
// Other dependencies your app might use
}
Out of the box it uses OkHttp HTTP client and a single thread executor.
SpotifyApi api = new SpotifyApi();
// Most (but not all) of the Spotify Web API endpoints require authorisation.
// If you know you'll only use the ones that don't require authorisation you can skip this step
api.setAccessToken("myAccessToken");
SpotifyService spotify = api.getService();
spotify.getAlbum("2dIGnmEIy1WZIcZCFSj6i8", new Callback<Album>() {
@Override
public void success(Album album, Response response) {
Log.d("Album success", album.name);
}
@Override
public void failure(RetrofitError error) {
Log.d("Album failure", error.toString());
}
});
It is also possible to construct the adapter with custom parameters.
final String accessToken = "myAccessToken";
RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint(SpotifyApi.SPOTIFY_WEB_API_ENDPOINT)
.setRequestInterceptor(new RequestInterceptor() {
@Override
public void intercept(RequestFacade request) {
request.addHeader("Authorization", "Bearer " + accessToken);
}
})
.build();
SpotifyService spotify = restAdapter.create(SpotifyService.class);
The most straightforward way to get the access token is to use the Authentication Library from the Spotify Android SDK. Detailed information how to use it can be found in the Spotify Android SDK Authentication Guide.
Feeling adventurous? You can implement the auth flow yourself, following the Spotify Authorization Guide.
When using Retrofit, errors are returned as RetrofitError
objects. These objects, among others, contain HTTP status codes and their descriptions,
for example 400 - Bad Request
.
In many cases this will work well enough but in some cases Spotify Web API returns more detailed information,
for example 400 - No search query
.
To use the data returned in the response from the Web API SpotifyCallback
object should be passed to the
request method instead of regular Retrofit's Callback
:
spotify.getMySavedTracks(new SpotifyCallback<Pager<SavedTrack>>;() {
@Override
public void success(Pager<SavedTrack> savedTrackPager, Response response) {
// handle successful response
}
@Override
public void failure(SpotifyError error) {
// handle error
}
});
For synchronous requests RetrofitError
can be converted to SpotifyError
if needed:
try {
Pager<SavedTrack> mySavedTracks = spotify.getMySavedTracks();
} catch (RetrofitError error) {
SpotifyError spotifyError = SpotifyError.fromRetrofitError(error);
// handle error
}
We use Semantic Versioning 2.0.0 as our versioning policy.
Found a bug? Something that's missing? Feedback is an important part of improving the project, so please open an issue.
Fork this project and start working on your own feature branch. When you're done, send a Pull Request to have your suggested changes merged into the master branch by the project's collaborators. Read more about the GitHub flow.