From 2e0e004c8ae488b9c0c3df0e9d23c7a68fac5cfc Mon Sep 17 00:00:00 2001 From: Trung Hoang Date: Tue, 18 Apr 2017 15:07:42 +1000 Subject: [PATCH] Update documentation for Spring Config class --- README.md | 31 ++++++++++++++++++++-- src/main/java/com/xero/api/XeroClient.java | 4 +++ 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index acde9650..eeffa55d 100644 --- a/README.md +++ b/README.md @@ -35,11 +35,11 @@ We have a build.sbt file defined in the root. ### Configure -The Xero Java SDK depends on an external JSON file to configure values unique to your Application. +The Xero Java SDK is easily configured using an external JSON file to configure values unique to your Application. This is the default configuration method, however you can implement the `Config` interface and pass it to the `XeroClient`. We include an Example App (in this repo) built using Eclipse. We started with a Maven Project and selected the maven-archetype-webapp with the setup Wizard. This created a web application structure good for use with Servlets & JSPs. By default a src/main/resources directory is added to the project. **Place the config.json file you create in the resources directory**. -The Xero Java SDK - Config.java class parses the JSON file from the resources directory using the following bit of code. +The Xero Java SDK JsonConfig.java class parses the JSON file from the resources directory using the following bit of code. ```java final ClassLoader loader = Config.class.getClassLoader(); @@ -97,6 +97,33 @@ In a text editor, create a file called config.json (examples are below) Refer t * AuthenticateUrl: path for redirect to authorize *default is /oauth/RequestToken* * AccessTokenPath: path for Access Token *default is https://api.xero.com/oauth/Authorize* +### Spring Framework based Config + +An alternative method of configuring the Xero Java SDK can be found in the `example/src/main/java` folder named `SpringConfig.java`. + +This class reads the configuration from the spring `Environment` backed by the `application.properties`. This handy way of configuring the SDK +allows spring profiles to control your production and development environments. + +```java + @Bean + public XeroClient xeroClient(Environment environment) { + SpringConfig config = new SpringConfig("xero.", environment); + XeroClient client = new XeroClient(config); + client.setOAuthToken(config.getConsumerKey(), config.getConsumerSecret()); + return client; + } +``` + +Application.properties +``` +xero.AppType=PRIVATE +xero.UserAgent=Your App Name +xero.ConsumerKey=FA6UXXXXXXXXXXXXXXXXXXXXXXRC7 +xero.ConsumerSecret=7FMXXXXXXXXXXXXXXXXXXXXXXXXXCSA +xero.PrivateKeyCert=certs/public_privatekey.pfx +xero.PrivateKeyPassword= +``` + ### Example App This repo includes an Example App mentioned above. The file structure mirrors that of an Eclipse Maven Project with the maven-archetype-webapp diff --git a/src/main/java/com/xero/api/XeroClient.java b/src/main/java/com/xero/api/XeroClient.java index 08b626eb..06fa88d8 100644 --- a/src/main/java/com/xero/api/XeroClient.java +++ b/src/main/java/com/xero/api/XeroClient.java @@ -100,6 +100,10 @@ public class XeroClient { protected static final Pattern MESSAGE_PATTERN = Pattern.compile("(.*)"); protected final ObjectFactory objFactory = new ObjectFactory(); + public XeroClient() { + this.config = JsonConfig.getInstance(); + } + public XeroClient(Config config) { this.config = config; }