diff options
author | mallowlabs <mallowlabs@gmail.com> | 2012-09-08 21:40:53 +0900 |
---|---|---|
committer | mallowlabs <mallowlabs@gmail.com> | 2012-09-08 21:40:53 +0900 |
commit | 98ba4e116e79dfda72810b1e5135a4d9b1ddab6e (patch) | |
tree | ae8b2c8993d7d547dd08b28088519cb365465102 /src/com/gitblit/RedmineUserService.java | |
parent | 13a3f5bc3e2d25fc76850f86070dc34efe60d77a (diff) | |
download | gitblit-98ba4e116e79dfda72810b1e5135a4d9b1ddab6e.tar.gz gitblit-98ba4e116e79dfda72810b1e5135a4d9b1ddab6e.zip |
Added RedmineUserService
Diffstat (limited to 'src/com/gitblit/RedmineUserService.java')
-rw-r--r-- | src/com/gitblit/RedmineUserService.java | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/src/com/gitblit/RedmineUserService.java b/src/com/gitblit/RedmineUserService.java new file mode 100644 index 00000000..93d1af85 --- /dev/null +++ b/src/com/gitblit/RedmineUserService.java @@ -0,0 +1,128 @@ +package com.gitblit;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStreamReader;
+import java.net.HttpURLConnection;
+import java.net.URL;
+
+import org.apache.wicket.util.io.IOUtils;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import com.gitblit.models.UserModel;
+import com.google.gson.Gson;
+
+/**
+ * Implementation of an Redmine user service.<br>
+ * you can login to gitblit with Redmine user id and api key.
+ */
+public class RedmineUserService extends GitblitUserService {
+
+ private final Logger logger = LoggerFactory.getLogger(RedmineUserService.class);
+
+ private IStoredSettings settings;
+
+ private String testingJson;
+
+ private class RedmineCurrent {
+ private class RedmineUser {
+ public String login;
+ public String firstname;
+ public String lastname;
+ public String mail;
+ }
+
+ public RedmineUser user;
+ }
+
+ public RedmineUserService() {
+ super();
+ }
+
+ @Override
+ public void setup(IStoredSettings settings) {
+ this.settings = settings;
+
+ String file = settings.getString(Keys.realm.redmine.backingUserService, "users.conf");
+ File realmFile = GitBlit.getFileOrFolder(file);
+
+ serviceImpl = createUserService(realmFile);
+ logger.info("Redmine User Service backed by " + serviceImpl.toString());
+ }
+
+ @Override
+ public boolean supportsCredentialChanges() {
+ return false;
+ }
+
+ @Override
+ public boolean supportsDisplayNameChanges() {
+ return false;
+ }
+
+ @Override
+ public boolean supportsEmailAddressChanges() {
+ return false;
+ }
+
+ @Override
+ public boolean supportsTeamMembershipChanges() {
+ return false;
+ }
+
+ @Override
+ public boolean supportsCookies() {
+ return false;
+ }
+
+ @Override
+ public UserModel authenticate(String username, char[] password) {
+ String urlText = this.settings.getString(Keys.realm.redmine.url, "");
+ if (!urlText.endsWith("/")) {
+ urlText.concat("/");
+ }
+ String apiKey = String.valueOf(password);
+
+ try {
+ String jsonString = getCurrentUserAsJson(urlText, apiKey);
+
+ RedmineCurrent current = new Gson().fromJson(jsonString, RedmineCurrent.class);
+ String login = current.user.login;
+
+ if (username.equalsIgnoreCase(login)) {
+ UserModel userModel = new UserModel(login);
+ userModel.displayName = current.user.firstname + " " + current.user.lastname;
+ userModel.emailAddress = current.user.mail;
+ userModel.canAdmin = true;
+ return userModel;
+ }
+
+ } catch (IOException e) {
+ logger.error("authenticate", e);
+ }
+ return null;
+ }
+
+ private String getCurrentUserAsJson(String url, String apiKey) throws IOException {
+ if (testingJson != null) { // for testing
+ return testingJson;
+ }
+
+ URL apiUrl = new URL(url + "users/current.json?key=" + apiKey);
+ HttpURLConnection http = (HttpURLConnection) apiUrl.openConnection();
+ http.setRequestMethod("GET");
+ http.connect();
+ InputStreamReader reader = new InputStreamReader(http.getInputStream());
+ return IOUtils.toString(reader);
+ }
+
+ /**
+ * set json response. do NOT invoke from production code.
+ * @param json json
+ */
+ public void setTestingCurrentUserAsJson(String json) {
+ this.testingJson = json;
+ }
+
+}
|