Java SDK for Contentful's Content Delivery API.
Contentful is a content management platform for web applications, mobile apps and connected devices. It allows you to create, edit & manage content in the cloud and publish it anywhere via powerful API. Contentful offers tools for managing editorial teams and enabling cooperation between organizations.
Grab via Maven:
<dependency>
<groupId>com.contentful.java</groupId>
<artifactId>java-sdk</artifactId>
<version>7.2.0</version>
</dependency>
or Gradle:
compile 'com.contentful.java:java-sdk:7.2.0'
Snapshots of the development version are available in Sonatype's snapshots
repository.
The SDK requires at minimum Java 6 or Android 2.3.
The SDK uses Retrofit under the hood as a REST client, which detects OkHttp in your classpath and uses it if it's available, otherwise falls back to the default HttpURLConnection
.
The recommended approach would be to add okhttp-urlconnection as a dependency to your project (okhttp already included), but that is completely optional.
You can also specify a custom client to be used, refer to the official documentation for instructions.
Grab the ProGuard configuration file and apply to your project.
The CDAClient
manages all your interaction with the Contentful Delivery API.
CDAClient client = CDAClient.builder()
.setSpace("space-key-goes-here")
.setToken("access-token-goes-here")
.build();
In order to fetch resources use the CDAClient.fetch()
method, and provide the type of resource(s) you want to fetch:
// Fetch entries
CDAArray array = client.fetch(CDAEntry.class).all();
// Fetch an entry matching a specific id
CDAEntry entry = client.fetch(CDAEntry.class).one("entry-id");
// Fetch entries with custom query
CDAArray result = client.fetch(CDAEntry.class)
.where("content_type", "cat")
.where("order", "sys.updatedAt")
.all();
All of the above examples are synchronous. In order to invoke the request asynchronously, it is possible to provide a callback:
client.fetch(CDAAsset.class).all(new CDACallback<CDAArray>() {
@Override protected void onSuccess(CDAArray result) {
// ...
}
});
Note that the return value for any asynchronous methods is the callback itself, so make sure to keep a reference to it and clear it according to its host lifecycle events.
If you want to use RxJava instead, call the observe()
method to get an Observable
instance:
client.observe(CDAAsset.class)
.one("jake")
.subscribe(System.out::println);
Bear in mind that there is no default ordering included for any method which returns a CDAArray
instance. This means that if you plan to page through more than 100 results with multiple requests, there is no guarantee that you will cover all entries. It is however possible to specify custom ordering:
CDAArray result = client.fetch(CDAEntry.class)
.where("order", "-sys.createdAt")
.all();
The above snippet will fetch all Entries, ordered by newest-to-oldest.
The Content Delivery API only returns published Entries. However, you might want to preview content in your app before making it public for your users. For this, you can use the preview mode, which will return all Entries, regardless of their published status:
CDAClient client = CDAClient.builder()
.setSpace("space-key-goes-here")
.setToken("access-token-goes-here")
.preview()
.build();
Apart from the configuration option, you can use the SDK without modifications with one exception: you need to obtain a preview access token, which you can get in the "API" tab of the Contentful app. In preview mode, data can be invalid, because no validation is performed on unpublished entries. Your app needs to deal with that. Be aware that the access token is read-write and should in no case be shipped with a production app.
Migration guide to 3.x is available in the wiki.
For further information, check out our official JavaDoc site or browse the API documentation.
Copyright (c) 2016 Contentful GmbH. See LICENSE.txt for further details.