A Java library that keeps OAuth 2.0 service access tokens in memory for your usage.
<dependency>
<groupId>org.zalando.stups</groupId>
<artifactId>tokens</artifactId>
<version>see above</version>
</dependency>
So, you also have to add it with:
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>your version</version>
</dependency>
AccessTokens tokens = Tokens.createAccessTokensWithUri(new URI("https://example.com/access_tokens"))
.manageToken("exampleRW")
.addScope("read")
.addScope("write")
.done()
.manageToken("exampleRO")
.addScope("read")
.done()
.start();
while (true) {
final String token = tokens.get("exampleRO");
Request.Get("https://api.example.com")
.addHeader("Authorization", "Bearer " + token)
.execute():
Thread.sleep(1000);
}
The "tokens" library allows injecting fixed OAuth2 access tokens via the OAUTH2_ACCESS_TOKENS
environment variable.
This allows testing applications using the library locally with personal OAuth2 tokens (e.g. generated by "zign"):
$ MY_TOKEN=$(zign token -n mytok)
$ export OAUTH2_ACCESS_TOKENS=mytok=$MY_TOKEN
$ lein repl # start my local Clojure app using the tokens library
Copyright © 2015 Zalando SE
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.