mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-09 15:05:44 +01:00
merge with default branch
This commit is contained in:
@@ -36,7 +36,6 @@ package sonia.scm.client;
|
|||||||
//~--- non-JDK imports --------------------------------------------------------
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
import sonia.scm.ScmState;
|
import sonia.scm.ScmState;
|
||||||
import sonia.scm.user.User;
|
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ package sonia.scm.client;
|
|||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
import sonia.scm.util.Util;
|
import sonia.scm.util.Util;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
@@ -47,6 +48,16 @@ import java.text.MessageFormat;
|
|||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Sebastian Sdorra
|
* @author Sebastian Sdorra
|
||||||
|
* @deprecated use {@link UrlProvider} instead. For example:
|
||||||
|
* <pre>
|
||||||
|
* {@code
|
||||||
|
* URLProvider provider = URLProviderFactory.createUrlProvider(
|
||||||
|
* baseUrl,
|
||||||
|
* UrlProviderFactory.TYPE_RESTAPI_XML
|
||||||
|
* );
|
||||||
|
* String authUrl = provider.getAuthenticationUrl();
|
||||||
|
* }
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
public class ScmUrlProvider
|
public class ScmUrlProvider
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -35,7 +35,11 @@ package sonia.scm.client;
|
|||||||
|
|
||||||
//~--- non-JDK imports --------------------------------------------------------
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import sonia.scm.ModelObject;
|
import sonia.scm.ModelObject;
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
import sonia.scm.util.AssertUtil;
|
import sonia.scm.util.AssertUtil;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
@@ -57,6 +61,12 @@ public abstract class AbstractClientHandler<T extends ModelObject>
|
|||||||
implements ClientHandler<T>
|
implements ClientHandler<T>
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/** the logger for AbstractClientHandler */
|
||||||
|
private static final Logger logger =
|
||||||
|
LoggerFactory.getLogger(AbstractClientHandler.class);
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs ...
|
* Constructs ...
|
||||||
*
|
*
|
||||||
@@ -233,7 +243,15 @@ public abstract class AbstractClientHandler<T extends ModelObject>
|
|||||||
public List<T> getAll()
|
public List<T> getAll()
|
||||||
{
|
{
|
||||||
List<T> items = null;
|
List<T> items = null;
|
||||||
WebResource resource = client.resource(getItemsUrl());
|
String url = getItemsUrl();
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("fetch all items of {} from url", itemClass.getSimpleName(),
|
||||||
|
url);
|
||||||
|
}
|
||||||
|
|
||||||
|
WebResource resource = client.resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
try
|
try
|
||||||
@@ -283,6 +301,11 @@ public abstract class AbstractClientHandler<T extends ModelObject>
|
|||||||
*/
|
*/
|
||||||
protected T getItemByUrl(String url)
|
protected T getItemByUrl(String url)
|
||||||
{
|
{
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("fetch item {} from url {}", itemClass.getSimpleName(), url);
|
||||||
|
}
|
||||||
|
|
||||||
T item = null;
|
T item = null;
|
||||||
WebResource resource = client.resource(url);
|
WebResource resource = client.resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
@@ -316,10 +339,8 @@ public abstract class AbstractClientHandler<T extends ModelObject>
|
|||||||
protected JerseyClientSession session;
|
protected JerseyClientSession session;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
protected ScmUrlProvider urlProvider;
|
protected UrlProvider urlProvider;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private Class<T> itemClass;
|
private Class<T> itemClass;
|
||||||
|
|
||||||
;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,8 +80,8 @@ public class JerseyClientChangesetHandler implements ClientChangesetHandler
|
|||||||
{
|
{
|
||||||
ChangesetPagingResult result = null;
|
ChangesetPagingResult result = null;
|
||||||
String url =
|
String url =
|
||||||
session.getUrlProvider().getRepositoryChangesetUrl(repository.getId(),
|
session.getUrlProvider().getRepositoryUrlProvider().getChangesetUrl(
|
||||||
start, limit);
|
repository.getId(), start, limit);
|
||||||
WebResource resource = session.getClient().resource(url);
|
WebResource resource = session.getClient().resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
@@ -121,8 +121,8 @@ public class JerseyClientChangesetHandler implements ClientChangesetHandler
|
|||||||
{
|
{
|
||||||
ChangesetPagingResult result = null;
|
ChangesetPagingResult result = null;
|
||||||
String url =
|
String url =
|
||||||
session.getUrlProvider().getRepositoryChangesetUrl(repository.getId(),
|
session.getUrlProvider().getRepositoryUrlProvider().getChangesetUrl(
|
||||||
path, revision, start, limit);
|
repository.getId(), path, revision, start, limit);
|
||||||
WebResource resource = session.getClient().resource(url);
|
WebResource resource = session.getClient().resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
|
|||||||
@@ -42,6 +42,8 @@ import org.sonatype.spice.jersey.client.ahc.AhcHttpClient;
|
|||||||
import org.sonatype.spice.jersey.client.ahc.config.DefaultAhcConfig;
|
import org.sonatype.spice.jersey.client.ahc.config.DefaultAhcConfig;
|
||||||
|
|
||||||
import sonia.scm.ScmState;
|
import sonia.scm.ScmState;
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
|
import sonia.scm.url.UrlProviderFactory;
|
||||||
import sonia.scm.util.AssertUtil;
|
import sonia.scm.util.AssertUtil;
|
||||||
import sonia.scm.util.Util;
|
import sonia.scm.util.Util;
|
||||||
|
|
||||||
@@ -114,15 +116,22 @@ public class JerseyClientProvider implements ScmClientProvider
|
|||||||
logger.info("create new session for {} with username {}", url, user);
|
logger.info("create new session for {} with username {}", url, user);
|
||||||
}
|
}
|
||||||
|
|
||||||
ScmUrlProvider urlProvider = new ScmUrlProvider(url);
|
UrlProvider urlProvider = UrlProviderFactory.createUrlProvider(url,
|
||||||
|
UrlProviderFactory.TYPE_RESTAPI_XML);
|
||||||
DefaultAhcConfig config = new DefaultAhcConfig();
|
DefaultAhcConfig config = new DefaultAhcConfig();
|
||||||
AhcHttpClient client = AhcHttpClient.create(config);
|
AhcHttpClient client = AhcHttpClient.create(config);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
if (Util.isNotEmpty(username) && Util.isNotEmpty(password))
|
if (Util.isNotEmpty(username) && Util.isNotEmpty(password))
|
||||||
{
|
{
|
||||||
WebResource resource = ClientUtil.createResource(client,
|
String authUrl = urlProvider.getAuthenticationUrl();
|
||||||
urlProvider.getAuthenticationLoginUrl(),
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("try login at {}", authUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
WebResource resource = ClientUtil.createResource(client, authUrl,
|
||||||
enableLogging);
|
enableLogging);
|
||||||
|
|
||||||
if (logger.isDebugEnabled())
|
if (logger.isDebugEnabled())
|
||||||
@@ -139,8 +148,14 @@ public class JerseyClientProvider implements ScmClientProvider
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
WebResource resource = ClientUtil.createResource(client,
|
String stateUrl = urlProvider.getStateUrl();
|
||||||
urlProvider.getAuthenticationUrl(),
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("retrive state from {}", stateUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
WebResource resource = ClientUtil.createResource(client, stateUrl,
|
||||||
enableLogging);
|
enableLogging);
|
||||||
|
|
||||||
if (logger.isDebugEnabled())
|
if (logger.isDebugEnabled())
|
||||||
|
|||||||
@@ -91,8 +91,8 @@ public class JerseyClientRepositoryBrowser implements ClientRepositoryBrowser
|
|||||||
{
|
{
|
||||||
List<BlameLine> blameLines = null;
|
List<BlameLine> blameLines = null;
|
||||||
String url =
|
String url =
|
||||||
session.getUrlProvider().getBlameUrl(repository.getId(), path,
|
session.getUrlProvider().getRepositoryUrlProvider().getBlameUrl(
|
||||||
revision);
|
repository.getId(), path, revision);
|
||||||
WebResource resource = session.getClient().resource(url);
|
WebResource resource = session.getClient().resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
@@ -134,8 +134,8 @@ public class JerseyClientRepositoryBrowser implements ClientRepositoryBrowser
|
|||||||
{
|
{
|
||||||
InputStream input = null;
|
InputStream input = null;
|
||||||
String url =
|
String url =
|
||||||
session.getUrlProvider().getRepositoryContentUrl(repository.getId(),
|
session.getUrlProvider().getRepositoryUrlProvider().getContentUrl(
|
||||||
path, revision);
|
repository.getId(), path, revision);
|
||||||
WebResource resource = session.getClient().resource(url);
|
WebResource resource = session.getClient().resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
@@ -171,8 +171,8 @@ public class JerseyClientRepositoryBrowser implements ClientRepositoryBrowser
|
|||||||
{
|
{
|
||||||
List<FileObjectWrapper> files = null;
|
List<FileObjectWrapper> files = null;
|
||||||
String url =
|
String url =
|
||||||
session.getUrlProvider().getRepositoryBrowseUrl(repository.getId(), path,
|
session.getUrlProvider().getRepositoryUrlProvider().getBrowseUrl(
|
||||||
revision);
|
repository.getId(), path, revision);
|
||||||
WebResource resource = session.getClient().resource(url);
|
WebResource resource = session.getClient().resource(url);
|
||||||
ClientResponse response = null;
|
ClientResponse response = null;
|
||||||
|
|
||||||
@@ -219,7 +219,7 @@ public class JerseyClientRepositoryBrowser implements ClientRepositoryBrowser
|
|||||||
@Override
|
@Override
|
||||||
public List<FileObjectWrapper> getFiles(String revision)
|
public List<FileObjectWrapper> getFiles(String revision)
|
||||||
{
|
{
|
||||||
return getFiles(revision, "");
|
return getFiles(revision, Util.EMPTY_STRING);
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- fields ---------------------------------------------------------------
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ import org.slf4j.Logger;
|
|||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import sonia.scm.ScmState;
|
import sonia.scm.ScmState;
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
@@ -65,7 +66,7 @@ public class JerseyClientSession implements ScmClientSession
|
|||||||
* @param urlProvider
|
* @param urlProvider
|
||||||
* @param state
|
* @param state
|
||||||
*/
|
*/
|
||||||
public JerseyClientSession(Client client, ScmUrlProvider urlProvider,
|
public JerseyClientSession(Client client, UrlProvider urlProvider,
|
||||||
ScmState state)
|
ScmState state)
|
||||||
{
|
{
|
||||||
this.client = client;
|
this.client = client;
|
||||||
@@ -146,7 +147,7 @@ public class JerseyClientSession implements ScmClientSession
|
|||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public ScmUrlProvider getUrlProvider()
|
public UrlProvider getUrlProvider()
|
||||||
{
|
{
|
||||||
return urlProvider;
|
return urlProvider;
|
||||||
}
|
}
|
||||||
@@ -172,5 +173,5 @@ public class JerseyClientSession implements ScmClientSession
|
|||||||
private ScmState state;
|
private ScmState state;
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
private ScmUrlProvider urlProvider;
|
private UrlProvider urlProvider;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ public class JerseyGroupClientHandler extends AbstractClientHandler<Group>
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemUrl(String itemId)
|
protected String getItemUrl(String itemId)
|
||||||
{
|
{
|
||||||
return urlProvider.getGroupUrl(itemId);
|
return urlProvider.getGroupUrlProvider().getDetailUrl(itemId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -117,6 +117,6 @@ public class JerseyGroupClientHandler extends AbstractClientHandler<Group>
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemsUrl()
|
protected String getItemsUrl()
|
||||||
{
|
{
|
||||||
return urlProvider.getGroupsUrl();
|
return urlProvider.getGroupUrlProvider().getAllUrl();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -160,7 +160,7 @@ public class JerseyRepositoryClientHandler
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemUrl(String itemId)
|
protected String getItemUrl(String itemId)
|
||||||
{
|
{
|
||||||
return urlProvider.getRepositoryUrl(itemId);
|
return urlProvider.getRepositoryUrlProvider().getDetailUrl(itemId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -172,6 +172,6 @@ public class JerseyRepositoryClientHandler
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemsUrl()
|
protected String getItemsUrl()
|
||||||
{
|
{
|
||||||
return urlProvider.getRepositoriesUrl();
|
return urlProvider.getRepositoryUrlProvider().getAllUrl();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ public class JerseyUserClientHandler extends AbstractClientHandler<User>
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemUrl(String itemId)
|
protected String getItemUrl(String itemId)
|
||||||
{
|
{
|
||||||
return urlProvider.getUserUrl(itemId);
|
return urlProvider.getUserUrlProvider().getDetailUrl(itemId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -117,6 +117,6 @@ public class JerseyUserClientHandler extends AbstractClientHandler<User>
|
|||||||
@Override
|
@Override
|
||||||
protected String getItemsUrl()
|
protected String getItemsUrl()
|
||||||
{
|
{
|
||||||
return urlProvider.getUsersUrl();
|
return urlProvider.getUserUrlProvider().getAllUrl();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,6 +40,7 @@ import sonia.scm.client.JerseyClientProvider;
|
|||||||
import sonia.scm.client.JerseyClientSession;
|
import sonia.scm.client.JerseyClientSession;
|
||||||
import sonia.scm.client.ScmUrlProvider;
|
import sonia.scm.client.ScmUrlProvider;
|
||||||
import sonia.scm.config.ScmConfiguration;
|
import sonia.scm.config.ScmConfiguration;
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
@@ -124,10 +125,10 @@ public class ClientTestUtil
|
|||||||
public static void setAnonymousAccess(boolean access)
|
public static void setAnonymousAccess(boolean access)
|
||||||
{
|
{
|
||||||
JerseyClientSession adminSession = createAdminSession();
|
JerseyClientSession adminSession = createAdminSession();
|
||||||
ScmUrlProvider up = adminSession.getUrlProvider();
|
UrlProvider up = adminSession.getUrlProvider();
|
||||||
Client client = adminSession.getClient();
|
Client client = adminSession.getClient();
|
||||||
WebResource resource = ClientUtil.createResource(client,
|
WebResource resource = ClientUtil.createResource(client, up.getConfigUrl(),
|
||||||
up.getResourceUrl("config"), REQUEST_LOGGING);
|
REQUEST_LOGGING);
|
||||||
ScmConfiguration config = resource.get(ScmConfiguration.class);
|
ScmConfiguration config = resource.get(ScmConfiguration.class);
|
||||||
|
|
||||||
config.setAnonymousAccessEnabled(access);
|
config.setAnonymousAccessEnabled(access);
|
||||||
|
|||||||
@@ -59,6 +59,19 @@ public interface HttpClient
|
|||||||
*/
|
*/
|
||||||
public HttpResponse post(String url) throws IOException;
|
public HttpResponse post(String url) throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @since 1.9
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public HttpResponse post(HttpRequest request) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
@@ -87,6 +100,19 @@ public interface HttpClient
|
|||||||
*/
|
*/
|
||||||
public HttpResponse get(String url) throws IOException;
|
public HttpResponse get(String url) throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @since 1.9
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public HttpResponse get(HttpRequest request) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
|
|||||||
264
scm-core/src/main/java/sonia/scm/net/HttpRequest.java
Normal file
264
scm-core/src/main/java/sonia/scm/net/HttpRequest.java
Normal file
@@ -0,0 +1,264 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.net;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.AssertUtil;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public class HttpRequest
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param url
|
||||||
|
*/
|
||||||
|
public HttpRequest(String url)
|
||||||
|
{
|
||||||
|
this.url = url;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param values
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public HttpRequest addHeader(String name, String... values)
|
||||||
|
{
|
||||||
|
AssertUtil.assertIsNotNull(name);
|
||||||
|
|
||||||
|
if (headers == null)
|
||||||
|
{
|
||||||
|
headers = new HashMap<String, List<String>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
appendValues(headers, name, values);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param values
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public HttpRequest addParameters(String name, String... values)
|
||||||
|
{
|
||||||
|
AssertUtil.assertIsNotNull(name);
|
||||||
|
|
||||||
|
if (parameters == null)
|
||||||
|
{
|
||||||
|
parameters = new HashMap<String, List<String>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
appendValues(parameters, name, values);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Map<String, List<String>> getHeaders()
|
||||||
|
{
|
||||||
|
return headers;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Map<String, List<String>> getParameters()
|
||||||
|
{
|
||||||
|
return parameters;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getPassword()
|
||||||
|
{
|
||||||
|
return password;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getUrl()
|
||||||
|
{
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getUsername()
|
||||||
|
{
|
||||||
|
return username;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- set methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param username
|
||||||
|
* @param password
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public HttpRequest setBasicAuthentication(String username, String password)
|
||||||
|
{
|
||||||
|
this.username = username;
|
||||||
|
this.password = password;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param headers
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public HttpRequest setHeaders(Map<String, List<String>> headers)
|
||||||
|
{
|
||||||
|
this.headers = headers;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param parameters
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public HttpRequest setParameters(Map<String, List<String>> parameters)
|
||||||
|
{
|
||||||
|
this.parameters = parameters;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param map
|
||||||
|
* @param name
|
||||||
|
* @param values
|
||||||
|
*/
|
||||||
|
private void appendValues(Map<String, List<String>> map, String name,
|
||||||
|
String[] values)
|
||||||
|
{
|
||||||
|
List<String> valueList = map.get(name);
|
||||||
|
|
||||||
|
if (valueList == null)
|
||||||
|
{
|
||||||
|
valueList = new ArrayList<String>();
|
||||||
|
map.put(name, valueList);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (values != null)
|
||||||
|
{
|
||||||
|
valueList.addAll(Arrays.asList(values));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private Map<String, List<String>> headers;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private Map<String, List<String>> parameters;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String password;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String url;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String username;
|
||||||
|
}
|
||||||
58
scm-core/src/main/java/sonia/scm/url/ModelUrlProvider.java
Normal file
58
scm-core/src/main/java/sonia/scm/url/ModelUrlProvider.java
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public interface ModelUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getDetailUrl(String name);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getAllUrl();
|
||||||
|
|
||||||
|
}
|
||||||
117
scm-core/src/main/java/sonia/scm/url/RepositoryUrlProvider.java
Normal file
117
scm-core/src/main/java/sonia/scm/url/RepositoryUrlProvider.java
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public interface RepositoryUrlProvider extends ModelUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getBlameUrl(String repositoryId, String path, String revision);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getBrowseUrl(String repositoryId, String path, String revision);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getChangesetUrl(String repositoryId, String path,
|
||||||
|
String revision, int start, int limit);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getChangesetUrl(String repositoryId, int start, int limit);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getContentUrl(String repositoryId, String path,
|
||||||
|
String revision);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getDiffUrl(String repositoryId, String revision);
|
||||||
|
}
|
||||||
@@ -0,0 +1,97 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.HttpUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class RestModelUrlProvider implements ModelUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param modelSuffix
|
||||||
|
* @param extension
|
||||||
|
*/
|
||||||
|
public RestModelUrlProvider(String baseUrl, String modelSuffix,
|
||||||
|
String extension)
|
||||||
|
{
|
||||||
|
this.base = HttpUtil.append(baseUrl, modelSuffix);
|
||||||
|
this.extension = extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getAllUrl()
|
||||||
|
{
|
||||||
|
return base.concat(extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getDetailUrl(String name)
|
||||||
|
{
|
||||||
|
return HttpUtil.append(base, name).concat(extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
protected String base;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
protected String extension;
|
||||||
|
}
|
||||||
@@ -0,0 +1,207 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.UrlBuilder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class RestRepositoryUrlProvider extends RestModelUrlProvider
|
||||||
|
implements RepositoryUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PARAMETER_LIMIT = "limit";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PARAMETER_PATH = "path";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PARAMETER_REVISION = "revision";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PARAMETER_START = "start";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_BLAME = "blame";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_BROWSE = "browse";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_CHANGESETS = "changesets";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_CONTENT = "content";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_DIFF = "diff";
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param modelSuffix
|
||||||
|
* @param extension
|
||||||
|
*/
|
||||||
|
public RestRepositoryUrlProvider(String baseUrl, String modelSuffix,
|
||||||
|
String extension)
|
||||||
|
{
|
||||||
|
super(baseUrl, modelSuffix, extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getBlameUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_BLAME).append(extension).appendParameter(
|
||||||
|
PARAMETER_PATH, path).appendParameter(
|
||||||
|
PARAMETER_REVISION, revision).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getBrowseUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_BROWSE).append(extension).appendParameter(
|
||||||
|
PARAMETER_PATH, path).appendParameter(
|
||||||
|
PARAMETER_REVISION, revision).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getChangesetUrl(String repositoryId, String path,
|
||||||
|
String revision, int start, int limit)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_CHANGESETS).append(extension).appendParameter(
|
||||||
|
PARAMETER_PATH, path).appendParameter(
|
||||||
|
PARAMETER_REVISION, revision).appendParameter(
|
||||||
|
PARAMETER_START, start).appendParameter(
|
||||||
|
PARAMETER_LIMIT, limit).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getChangesetUrl(String repositoryId, int start, int limit)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_CHANGESETS).append(extension).appendParameter(
|
||||||
|
PARAMETER_START, start).appendParameter(
|
||||||
|
PARAMETER_LIMIT, limit).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getContentUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_CONTENT).appendParameter(PARAMETER_PATH, path).appendParameter(
|
||||||
|
PARAMETER_REVISION, revision).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getDiffUrl(String repositoryId, String revision)
|
||||||
|
{
|
||||||
|
return new UrlBuilder(base).appendUrlPart(repositoryId).appendUrlPart(
|
||||||
|
PART_DIFF).appendParameter(PARAMETER_REVISION, revision).toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
164
scm-core/src/main/java/sonia/scm/url/RestUrlProvider.java
Normal file
164
scm-core/src/main/java/sonia/scm/url/RestUrlProvider.java
Normal file
@@ -0,0 +1,164 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.HttpUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class RestUrlProvider implements UrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_API = "api/rest/";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_AUTHENTICATION = "authentication/login";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_CONFIG = "config";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_GROUP = "groups";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_REPOSITORIES = "repositories";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_STATE = "authentication";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_USER = "users";
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param extension
|
||||||
|
*/
|
||||||
|
public RestUrlProvider(String baseUrl, String extension)
|
||||||
|
{
|
||||||
|
this.baseUrl = HttpUtil.append(baseUrl, PART_API);
|
||||||
|
this.extension = extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getAuthenticationUrl()
|
||||||
|
{
|
||||||
|
return HttpUtil.append(baseUrl, PART_AUTHENTICATION).concat(extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getConfigUrl()
|
||||||
|
{
|
||||||
|
return HttpUtil.append(baseUrl, PART_CONFIG).concat(extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ModelUrlProvider getGroupUrlProvider()
|
||||||
|
{
|
||||||
|
return new RestModelUrlProvider(baseUrl, PART_GROUP, extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public RepositoryUrlProvider getRepositoryUrlProvider()
|
||||||
|
{
|
||||||
|
return new RestRepositoryUrlProvider(baseUrl, PART_REPOSITORIES, extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getStateUrl()
|
||||||
|
{
|
||||||
|
return HttpUtil.append(baseUrl, PART_STATE).concat(extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ModelUrlProvider getUserUrlProvider()
|
||||||
|
{
|
||||||
|
return new RestModelUrlProvider(baseUrl, PART_USER, extension);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
protected String baseUrl;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
protected String extension;
|
||||||
|
}
|
||||||
90
scm-core/src/main/java/sonia/scm/url/UrlProvider.java
Normal file
90
scm-core/src/main/java/sonia/scm/url/UrlProvider.java
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public interface UrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getAuthenticationUrl();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getConfigUrl();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public ModelUrlProvider getGroupUrlProvider();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public RepositoryUrlProvider getRepositoryUrlProvider();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getStateUrl();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public ModelUrlProvider getUserUrlProvider();
|
||||||
|
}
|
||||||
89
scm-core/src/main/java/sonia/scm/url/UrlProviderFactory.java
Normal file
89
scm-core/src/main/java/sonia/scm/url/UrlProviderFactory.java
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class UrlProviderFactory
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String TYPE_RESTAPI_JSON = "json-rest-api";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String TYPE_RESTAPI_XML = "xml-rest-api";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String TYPE_WUI = "wui";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private static final String EXTENSION_JSON = ".json";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private static final String EXTENSION_XML = ".xml";
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param type
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static UrlProvider createUrlProvider(String baseUrl, String type)
|
||||||
|
{
|
||||||
|
UrlProvider provider = null;
|
||||||
|
|
||||||
|
if (TYPE_RESTAPI_JSON.equals(type))
|
||||||
|
{
|
||||||
|
provider = new RestUrlProvider(baseUrl, EXTENSION_JSON);
|
||||||
|
}
|
||||||
|
else if (TYPE_RESTAPI_XML.equals(type))
|
||||||
|
{
|
||||||
|
provider = new RestUrlProvider(baseUrl, EXTENSION_XML);
|
||||||
|
}
|
||||||
|
else if (TYPE_WUI.equals(type))
|
||||||
|
{
|
||||||
|
provider = new WUIUrlProvider(baseUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
return provider;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,91 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.HttpUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class WUIModelUrlProvider implements ModelUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param component
|
||||||
|
*/
|
||||||
|
public WUIModelUrlProvider(String baseUrl, String component)
|
||||||
|
{
|
||||||
|
this.url = HttpUtil.appendHash(baseUrl, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getAllUrl()
|
||||||
|
{
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getDetailUrl(String name)
|
||||||
|
{
|
||||||
|
return url.concat(WUIUrlBuilder.SEPARATOR).concat(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String url;
|
||||||
|
}
|
||||||
@@ -0,0 +1,196 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class WUIRepositoryUrlProvider extends WUIModelUrlProvider
|
||||||
|
implements RepositoryUrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_BROWSER = "repositoryBrowser";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_CHANGESETS =
|
||||||
|
"repositoryChangesetViewerPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_CONTENT = "contentPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_DIFF = "diffPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String VIEW_BLAME = "blame";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String VIEW_CONTENT = "content";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String VIEW_HISTORY = "history";
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param component
|
||||||
|
*/
|
||||||
|
public WUIRepositoryUrlProvider(String baseUrl, String component)
|
||||||
|
{
|
||||||
|
super(baseUrl, component);
|
||||||
|
this.baseUrl = baseUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getBlameUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_CONTENT).append(
|
||||||
|
repositoryId).append(revision).append(path).append(
|
||||||
|
VIEW_BLAME).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getBrowseUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_BROWSER).append(
|
||||||
|
repositoryId).append(revision).append(path).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getChangesetUrl(String repositoryId, String path,
|
||||||
|
String revision, int start, int limit)
|
||||||
|
{
|
||||||
|
|
||||||
|
// TODO handle start and limit
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_CONTENT).append(
|
||||||
|
repositoryId).append(revision).append(path).append(
|
||||||
|
VIEW_HISTORY).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param start
|
||||||
|
* @param limit
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getChangesetUrl(String repositoryId, int start, int limit)
|
||||||
|
{
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_CHANGESETS).append(
|
||||||
|
repositoryId).append(start).append(limit).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param path
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getContentUrl(String repositoryId, String path, String revision)
|
||||||
|
{
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_CONTENT).append(
|
||||||
|
repositoryId).append(revision).append(path).append(
|
||||||
|
VIEW_HISTORY).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param repositoryId
|
||||||
|
* @param revision
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getDiffUrl(String repositoryId, String revision)
|
||||||
|
{
|
||||||
|
return new WUIUrlBuilder(baseUrl, COMPONENT_DIFF).append(
|
||||||
|
repositoryId).append(revision).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String baseUrl;
|
||||||
|
}
|
||||||
123
scm-core/src/main/java/sonia/scm/url/WUIUrlBuilder.java
Normal file
123
scm-core/src/main/java/sonia/scm/url/WUIUrlBuilder.java
Normal file
@@ -0,0 +1,123 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.HttpUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class WUIUrlBuilder
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String NULL = "null";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String SEPARATOR = ";";
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
* @param component
|
||||||
|
*/
|
||||||
|
public WUIUrlBuilder(String baseUrl, String component)
|
||||||
|
{
|
||||||
|
this.url = HttpUtil.appendHash(baseUrl, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WUIUrlBuilder append(String value)
|
||||||
|
{
|
||||||
|
if (value == null)
|
||||||
|
{
|
||||||
|
value = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.url.endsWith(SEPARATOR))
|
||||||
|
{
|
||||||
|
this.url = this.url.concat(SEPARATOR);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.url = this.url.concat(value);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public WUIUrlBuilder append(int value)
|
||||||
|
{
|
||||||
|
return append(String.valueOf(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString()
|
||||||
|
{
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String url;
|
||||||
|
}
|
||||||
157
scm-core/src/main/java/sonia/scm/url/WUIUrlProvider.java
Normal file
157
scm-core/src/main/java/sonia/scm/url/WUIUrlProvider.java
Normal file
@@ -0,0 +1,157 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import sonia.scm.util.HttpUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class WUIUrlProvider implements UrlProvider
|
||||||
|
{
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_CONFIG = "scmConfig";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_GROUP = "groupPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_REPOSITORY = "repositoryPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String COMPONENT_USER = "userPanel";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String PART_INDEX = "index.html";
|
||||||
|
|
||||||
|
//~--- constructors ---------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
*/
|
||||||
|
public WUIUrlProvider(String baseUrl)
|
||||||
|
{
|
||||||
|
this.baseUrl = HttpUtil.append(baseUrl, PART_INDEX);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getAuthenticationUrl()
|
||||||
|
{
|
||||||
|
|
||||||
|
// ???
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getConfigUrl()
|
||||||
|
{
|
||||||
|
return HttpUtil.appendHash(baseUrl, COMPONENT_CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ModelUrlProvider getGroupUrlProvider()
|
||||||
|
{
|
||||||
|
return new WUIModelUrlProvider(baseUrl, COMPONENT_GROUP);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public RepositoryUrlProvider getRepositoryUrlProvider()
|
||||||
|
{
|
||||||
|
return new WUIRepositoryUrlProvider(baseUrl, COMPONENT_REPOSITORY);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String getStateUrl()
|
||||||
|
{
|
||||||
|
|
||||||
|
// ???
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ModelUrlProvider getUserUrlProvider()
|
||||||
|
{
|
||||||
|
return new WUIModelUrlProvider(baseUrl, COMPONENT_USER);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String baseUrl;
|
||||||
|
}
|
||||||
@@ -92,6 +92,30 @@ public class HttpUtil
|
|||||||
*/
|
*/
|
||||||
public static final String SCHEME_HTTPS = "https";
|
public static final String SCHEME_HTTPS = "https";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Url hash separator
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static final String SEPARATOR_HASH = "#";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Url parameter separator
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static final String SEPARATOR_PARAMETER = "&";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Url parameters separator
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static final String SEPARATOR_PARAMETERS = "?";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Url parameter value separator
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static final String SEPARATOR_PARAMETER_VALUE = "=";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Url folder separator
|
* Url folder separator
|
||||||
* @since 1.5
|
* @since 1.5
|
||||||
@@ -119,6 +143,69 @@ public class HttpUtil
|
|||||||
|
|
||||||
//~--- methods --------------------------------------------------------------
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param uri
|
||||||
|
* @param suffix
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static String append(String uri, String suffix)
|
||||||
|
{
|
||||||
|
if (!uri.endsWith(SEPARATOR_PATH))
|
||||||
|
{
|
||||||
|
uri = uri.concat(SEPARATOR_PATH);
|
||||||
|
}
|
||||||
|
|
||||||
|
return uri.concat(suffix);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param uri
|
||||||
|
* @param hash
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static String appendHash(String uri, String hash)
|
||||||
|
{
|
||||||
|
return uri.concat(SEPARATOR_HASH).concat(hash);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param uri
|
||||||
|
* @param name
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public static String appendParameter(String uri, String name, String value)
|
||||||
|
{
|
||||||
|
String s = null;
|
||||||
|
|
||||||
|
if (uri.contains(SEPARATOR_PARAMETERS))
|
||||||
|
{
|
||||||
|
s = SEPARATOR_PARAMETERS;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
s = SEPARATOR_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new StringBuilder(uri).append(s).append(name).append(
|
||||||
|
SEPARATOR_PARAMETER_VALUE).append(value).toString();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
|
|||||||
208
scm-core/src/main/java/sonia/scm/util/UrlBuilder.java
Normal file
208
scm-core/src/main/java/sonia/scm/util/UrlBuilder.java
Normal file
@@ -0,0 +1,208 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.util;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 1.9
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class UrlBuilder
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param baseUrl
|
||||||
|
*/
|
||||||
|
public UrlBuilder(String baseUrl)
|
||||||
|
{
|
||||||
|
this.url = baseUrl;
|
||||||
|
|
||||||
|
if (baseUrl.contains(HttpUtil.SEPARATOR_PARAMETERS))
|
||||||
|
{
|
||||||
|
separator = HttpUtil.SEPARATOR_PARAMETER;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
separator = HttpUtil.SEPARATOR_PARAMETERS;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param part
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder append(String part)
|
||||||
|
{
|
||||||
|
url = url.concat(part);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder appendParameter(String name, boolean value)
|
||||||
|
{
|
||||||
|
return appendParameter(name, String.valueOf(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder appendParameter(String name, int value)
|
||||||
|
{
|
||||||
|
return appendParameter(name, String.valueOf(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder appendParameter(String name, long value)
|
||||||
|
{
|
||||||
|
return appendParameter(name, String.valueOf(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @param value
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder appendParameter(String name, String value)
|
||||||
|
{
|
||||||
|
if (Util.isNotEmpty(name) && Util.isNotEmpty(value))
|
||||||
|
{
|
||||||
|
url = new StringBuilder(url).append(separator).append(name).append(
|
||||||
|
HttpUtil.SEPARATOR_PARAMETER_VALUE).append(value).toString();
|
||||||
|
parameterAdded = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param part
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public UrlBuilder appendUrlPart(String part)
|
||||||
|
{
|
||||||
|
if (parameterAdded)
|
||||||
|
{
|
||||||
|
throw new IllegalStateException("parameter added");
|
||||||
|
}
|
||||||
|
|
||||||
|
url = HttpUtil.append(url, part);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString()
|
||||||
|
{
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public URL toURL()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return new URL(url);
|
||||||
|
}
|
||||||
|
catch (MalformedURLException ex)
|
||||||
|
{
|
||||||
|
throw new RuntimeException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private boolean parameterAdded = false;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String separator;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private String url;
|
||||||
|
}
|
||||||
@@ -96,6 +96,7 @@
|
|||||||
<exclude>.hg/**</exclude>
|
<exclude>.hg/**</exclude>
|
||||||
<exclude>**/html5.js</exclude>
|
<exclude>**/html5.js</exclude>
|
||||||
<exclude>**/*.html</exclude>
|
<exclude>**/*.html</exclude>
|
||||||
|
<exclude>**/fancybox/**</exclude>
|
||||||
</excludes>
|
</excludes>
|
||||||
<strictCheck>true</strictCheck>
|
<strictCheck>true</strictCheck>
|
||||||
</configuration>
|
</configuration>
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>commons-daemon</groupId>
|
<groupId>commons-daemon</groupId>
|
||||||
<artifactId>commons-daemon</artifactId>
|
<artifactId>commons-daemon</artifactId>
|
||||||
<version>1.0.5</version>
|
<version>1.0.8</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
@@ -75,6 +75,7 @@
|
|||||||
<daemon>
|
<daemon>
|
||||||
|
|
||||||
<id>scm-server</id>
|
<id>scm-server</id>
|
||||||
|
<version>1.0.8</version>
|
||||||
<mainClass>sonia.scm.server.ScmServerDaemon</mainClass>
|
<mainClass>sonia.scm.server.ScmServerDaemon</mainClass>
|
||||||
<platforms>
|
<platforms>
|
||||||
<platform>commons-daemon</platform>
|
<platform>commons-daemon</platform>
|
||||||
|
|||||||
@@ -77,6 +77,11 @@ import sonia.scm.store.StoreFactory;
|
|||||||
import sonia.scm.template.FreemarkerTemplateHandler;
|
import sonia.scm.template.FreemarkerTemplateHandler;
|
||||||
import sonia.scm.template.TemplateHandler;
|
import sonia.scm.template.TemplateHandler;
|
||||||
import sonia.scm.template.TemplateServlet;
|
import sonia.scm.template.TemplateServlet;
|
||||||
|
import sonia.scm.url.RestJsonUrlProvider;
|
||||||
|
import sonia.scm.url.RestXmlUrlProvider;
|
||||||
|
import sonia.scm.url.UrlProvider;
|
||||||
|
import sonia.scm.url.UrlProviderFactory;
|
||||||
|
import sonia.scm.url.WebUIUrlProvider;
|
||||||
import sonia.scm.user.UserManager;
|
import sonia.scm.user.UserManager;
|
||||||
import sonia.scm.user.xml.XmlUserManager;
|
import sonia.scm.user.xml.XmlUserManager;
|
||||||
import sonia.scm.util.DebugServlet;
|
import sonia.scm.util.DebugServlet;
|
||||||
@@ -244,6 +249,17 @@ public class ScmServletModule extends ServletModule
|
|||||||
// bind httpclient
|
// bind httpclient
|
||||||
bind(HttpClient.class).to(URLHttpClient.class);
|
bind(HttpClient.class).to(URLHttpClient.class);
|
||||||
|
|
||||||
|
// bind url provider staff
|
||||||
|
bind(UrlProvider.class).annotatedWith(
|
||||||
|
Names.named(UrlProviderFactory.TYPE_RESTAPI_JSON)).toProvider(
|
||||||
|
RestJsonUrlProvider.class);
|
||||||
|
bind(UrlProvider.class).annotatedWith(
|
||||||
|
Names.named(UrlProviderFactory.TYPE_RESTAPI_XML)).toProvider(
|
||||||
|
RestXmlUrlProvider.class);
|
||||||
|
bind(UrlProvider.class).annotatedWith(
|
||||||
|
Names.named(UrlProviderFactory.TYPE_WUI)).toProvider(
|
||||||
|
WebUIUrlProvider.class);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* filter(PATTERN_PAGE,
|
* filter(PATTERN_PAGE,
|
||||||
* PATTERN_STATIC_RESOURCES).through(StaticResourceFilter.class);
|
* PATTERN_STATIC_RESOURCES).through(StaticResourceFilter.class);
|
||||||
|
|||||||
@@ -66,7 +66,6 @@ import sonia.scm.repository.RepositoryManager;
|
|||||||
import sonia.scm.repository.RepositoryNotFoundException;
|
import sonia.scm.repository.RepositoryNotFoundException;
|
||||||
import sonia.scm.util.AssertUtil;
|
import sonia.scm.util.AssertUtil;
|
||||||
import sonia.scm.util.HttpUtil;
|
import sonia.scm.util.HttpUtil;
|
||||||
import sonia.scm.util.SecurityUtil;
|
|
||||||
import sonia.scm.util.Util;
|
import sonia.scm.util.Util;
|
||||||
import sonia.scm.web.security.WebSecurityContext;
|
import sonia.scm.web.security.WebSecurityContext;
|
||||||
|
|
||||||
@@ -244,18 +243,7 @@ public class RepositoryResource
|
|||||||
@Override
|
@Override
|
||||||
public Response get(@Context Request request, @PathParam("id") String id)
|
public Response get(@Context Request request, @PathParam("id") String id)
|
||||||
{
|
{
|
||||||
Response response = null;
|
return super.get(request, id);
|
||||||
|
|
||||||
if (SecurityUtil.isAdmin(securityContextProvider))
|
|
||||||
{
|
|
||||||
response = super.get(request, id);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
response = Response.status(Response.Status.FORBIDDEN).build();
|
|
||||||
}
|
|
||||||
|
|
||||||
return response;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -410,6 +398,47 @@ public class RepositoryResource
|
|||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a repository.<br />
|
||||||
|
* <br />
|
||||||
|
* Status codes:
|
||||||
|
* <ul>
|
||||||
|
* <li>200 get successful</li>
|
||||||
|
* <li>404 not found,
|
||||||
|
* no repository with the specified type and name available</li>
|
||||||
|
* <li>500 internal server error</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @param request the current request
|
||||||
|
* @param type the type of the repository
|
||||||
|
* @param name the name of the repository
|
||||||
|
*
|
||||||
|
* @return the {@link Repository} with the specified type and name
|
||||||
|
*/
|
||||||
|
@GET
|
||||||
|
@Path("{type}/{name}")
|
||||||
|
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
|
||||||
|
@TypeHint(Repository.class)
|
||||||
|
public Response getByTypeAndName(@Context Request request,
|
||||||
|
@PathParam("type") String type,
|
||||||
|
@PathParam("name") String name)
|
||||||
|
{
|
||||||
|
Response response = null;
|
||||||
|
Repository repository = repositoryManager.get(type, name);
|
||||||
|
|
||||||
|
if (repository != null)
|
||||||
|
{
|
||||||
|
prepareForReturn(repository);
|
||||||
|
response = Response.ok(repository).build();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
response = Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of {@link Changeset} for the given repository.<br />
|
* Returns a list of {@link Changeset} for the given repository.<br />
|
||||||
* <br />
|
* <br />
|
||||||
@@ -570,7 +599,7 @@ public class RepositoryResource
|
|||||||
@GET
|
@GET
|
||||||
@Path("{id}/diff")
|
@Path("{id}/diff")
|
||||||
@TypeHint(DiffStreamingOutput.class)
|
@TypeHint(DiffStreamingOutput.class)
|
||||||
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
|
@Produces(MediaType.APPLICATION_OCTET_STREAM)
|
||||||
public Response getDiff(@PathParam("id") String id,
|
public Response getDiff(@PathParam("id") String id,
|
||||||
@QueryParam("revision") String revision,
|
@QueryParam("revision") String revision,
|
||||||
@QueryParam("path") String path)
|
@QueryParam("path") String path)
|
||||||
|
|||||||
@@ -83,6 +83,9 @@ public class URLHttpClient implements HttpClient
|
|||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String HEADER_ACCEPT_ENCODING_VALUE = "gzip";
|
public static final String HEADER_ACCEPT_ENCODING_VALUE = "gzip";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String HEADER_AUTHORIZATION = "Authorization";
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String HEADER_PROXY_AUTHORIZATION = "Proxy-Authorization";
|
public static final String HEADER_PROXY_AUTHORIZATION = "Proxy-Authorization";
|
||||||
|
|
||||||
@@ -141,7 +144,8 @@ public class URLHttpClient implements HttpClient
|
|||||||
@Override
|
@Override
|
||||||
public HttpResponse post(String url) throws IOException
|
public HttpResponse post(String url) throws IOException
|
||||||
{
|
{
|
||||||
HttpURLConnection connection = (HttpURLConnection) openConnection(url);
|
HttpURLConnection connection = (HttpURLConnection) openConnection(null,
|
||||||
|
url);
|
||||||
|
|
||||||
connection.setRequestMethod(METHOD_POST);
|
connection.setRequestMethod(METHOD_POST);
|
||||||
|
|
||||||
@@ -163,10 +167,180 @@ public class URLHttpClient implements HttpClient
|
|||||||
public HttpResponse post(String url, Map<String, List<String>> parameters)
|
public HttpResponse post(String url, Map<String, List<String>> parameters)
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
HttpURLConnection connection = (HttpURLConnection) openConnection(url);
|
HttpURLConnection connection = (HttpURLConnection) openConnection(null,
|
||||||
|
url);
|
||||||
|
|
||||||
connection.setRequestMethod(METHOD_POST);
|
connection.setRequestMethod(METHOD_POST);
|
||||||
|
appendPostParameter(connection, parameters);
|
||||||
|
|
||||||
|
return new URLHttpResponse(connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpResponse post(HttpRequest request) throws IOException
|
||||||
|
{
|
||||||
|
HttpURLConnection connection = (HttpURLConnection) openConnection(request,
|
||||||
|
request.getUrl());
|
||||||
|
|
||||||
|
connection.setRequestMethod(METHOD_POST);
|
||||||
|
appendPostParameter(connection, request.getParameters());
|
||||||
|
|
||||||
|
return new URLHttpResponse(connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param spec
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpResponse get(String spec) throws IOException
|
||||||
|
{
|
||||||
|
return new URLHttpResponse(openConnection(null, spec));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param url
|
||||||
|
* @param parameters
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpResponse get(String url, Map<String, List<String>> parameters)
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
|
url = createGetUrl(url, parameters);
|
||||||
|
|
||||||
|
return new URLHttpResponse(openConnection(null, url));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public HttpResponse get(HttpRequest request) throws IOException
|
||||||
|
{
|
||||||
|
String url = createGetUrl(request.getUrl(), request.getParameters());
|
||||||
|
|
||||||
|
return new URLHttpResponse(openConnection(request, url));
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param connection
|
||||||
|
* @param header
|
||||||
|
* @param username
|
||||||
|
* @param password
|
||||||
|
*/
|
||||||
|
private void appendBasicAuthHeader(HttpURLConnection connection,
|
||||||
|
String header, String username,
|
||||||
|
String password)
|
||||||
|
{
|
||||||
|
if (Util.isNotEmpty(username) || Util.isNotEmpty(password))
|
||||||
|
{
|
||||||
|
username = Util.nonNull(username);
|
||||||
|
password = Util.nonNull(password);
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("append {} header for user {}", header, username);
|
||||||
|
}
|
||||||
|
|
||||||
|
String auth = username.concat(CREDENTIAL_SEPARATOR).concat(password);
|
||||||
|
|
||||||
|
auth = new String(Base64.encode(auth.getBytes()));
|
||||||
|
connection.addRequestProperty(header,
|
||||||
|
PREFIX_BASIC_AUTHENTICATION.concat(auth));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param headers
|
||||||
|
* @param connection
|
||||||
|
*/
|
||||||
|
private void appendHeaders(Map<String, List<String>> headers,
|
||||||
|
URLConnection connection)
|
||||||
|
{
|
||||||
|
if (Util.isNotEmpty(headers))
|
||||||
|
{
|
||||||
|
for (Map.Entry<String, List<String>> e : headers.entrySet())
|
||||||
|
{
|
||||||
|
String name = e.getKey();
|
||||||
|
List<String> values = e.getValue();
|
||||||
|
|
||||||
|
if (Util.isNotEmpty(name) && Util.isNotEmpty(values))
|
||||||
|
{
|
||||||
|
for (String value : values)
|
||||||
|
{
|
||||||
|
if (logger.isTraceEnabled())
|
||||||
|
{
|
||||||
|
logger.trace("append header {}:{}", name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
connection.setRequestProperty(name, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (logger.isWarnEnabled())
|
||||||
|
{
|
||||||
|
logger.warn("value of {} header is empty", name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (logger.isTraceEnabled())
|
||||||
|
{
|
||||||
|
logger.trace("header map is emtpy");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param connection
|
||||||
|
* @param parameters
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
private void appendPostParameter(HttpURLConnection connection,
|
||||||
|
Map<String, List<String>> parameters)
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
if (Util.isNotEmpty(parameters))
|
if (Util.isNotEmpty(parameters))
|
||||||
{
|
{
|
||||||
connection.setDoOutput(true);
|
connection.setDoOutput(true);
|
||||||
@@ -206,26 +380,6 @@ public class URLHttpClient implements HttpClient
|
|||||||
IOUtil.close(writer);
|
IOUtil.close(writer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new URLHttpResponse(connection);
|
|
||||||
}
|
|
||||||
|
|
||||||
//~--- get methods ----------------------------------------------------------
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param spec
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
*
|
|
||||||
* @throws IOException
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public HttpResponse get(String spec) throws IOException
|
|
||||||
{
|
|
||||||
return new URLHttpResponse(openConnection(spec));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -236,12 +390,8 @@ public class URLHttpClient implements HttpClient
|
|||||||
* @param parameters
|
* @param parameters
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*
|
|
||||||
* @throws IOException
|
|
||||||
*/
|
*/
|
||||||
@Override
|
private String createGetUrl(String url, Map<String, List<String>> parameters)
|
||||||
public HttpResponse get(String url, Map<String, List<String>> parameters)
|
|
||||||
throws IOException
|
|
||||||
{
|
{
|
||||||
if (Util.isNotEmpty(parameters))
|
if (Util.isNotEmpty(parameters))
|
||||||
{
|
{
|
||||||
@@ -275,11 +425,9 @@ public class URLHttpClient implements HttpClient
|
|||||||
url = ub.toString();
|
url = ub.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new URLHttpResponse(openConnection(url));
|
return url;
|
||||||
}
|
}
|
||||||
|
|
||||||
//~--- methods --------------------------------------------------------------
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
@@ -306,30 +454,36 @@ public class URLHttpClient implements HttpClient
|
|||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
* @param spec
|
* @param spec
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*
|
*
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
private URLConnection openConnection(String spec) throws IOException
|
private HttpURLConnection openConnection(HttpRequest request, String spec)
|
||||||
|
throws IOException
|
||||||
{
|
{
|
||||||
return openConnection(new URL(spec));
|
return openConnection(request, new URL(spec));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
* @param url
|
* @param url
|
||||||
*
|
*
|
||||||
* @return
|
* @return
|
||||||
*
|
*
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
private URLConnection openConnection(URL url) throws IOException
|
private HttpURLConnection openConnection(HttpRequest request, URL url)
|
||||||
|
throws IOException
|
||||||
{
|
{
|
||||||
URLConnection connection = null;
|
HttpURLConnection connection = null;
|
||||||
|
|
||||||
if (configuration.isEnableProxy())
|
if (configuration.isEnableProxy())
|
||||||
{
|
{
|
||||||
@@ -345,7 +499,9 @@ public class URLHttpClient implements HttpClient
|
|||||||
new InetSocketAddress(configuration.getProxyServer(),
|
new InetSocketAddress(configuration.getProxyServer(),
|
||||||
configuration.getProxyPort());
|
configuration.getProxyPort());
|
||||||
|
|
||||||
connection = url.openConnection(new Proxy(Proxy.Type.HTTP, address));
|
connection =
|
||||||
|
(HttpURLConnection) url.openConnection(new Proxy(Proxy.Type.HTTP,
|
||||||
|
address));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -354,11 +510,25 @@ public class URLHttpClient implements HttpClient
|
|||||||
logger.debug("fetch '{}'", url.toExternalForm());
|
logger.debug("fetch '{}'", url.toExternalForm());
|
||||||
}
|
}
|
||||||
|
|
||||||
connection = url.openConnection();
|
connection = (HttpURLConnection) url.openConnection();
|
||||||
}
|
}
|
||||||
|
|
||||||
connection.setReadTimeout(TIMEOUT_RAED);
|
connection.setReadTimeout(TIMEOUT_RAED);
|
||||||
connection.setConnectTimeout(TIMEOUT_CONNECTION);
|
connection.setConnectTimeout(TIMEOUT_CONNECTION);
|
||||||
|
|
||||||
|
if (request != null)
|
||||||
|
{
|
||||||
|
Map<String, List<String>> headers = request.getHeaders();
|
||||||
|
|
||||||
|
appendHeaders(headers, connection);
|
||||||
|
|
||||||
|
String username = request.getUsername();
|
||||||
|
String password = request.getPassword();
|
||||||
|
|
||||||
|
appendBasicAuthHeader(connection, HEADER_AUTHORIZATION, username,
|
||||||
|
password);
|
||||||
|
}
|
||||||
|
|
||||||
connection.setRequestProperty(HEADER_ACCEPT_ENCODING,
|
connection.setRequestProperty(HEADER_ACCEPT_ENCODING,
|
||||||
HEADER_ACCEPT_ENCODING_VALUE);
|
HEADER_ACCEPT_ENCODING_VALUE);
|
||||||
connection.setRequestProperty(
|
connection.setRequestProperty(
|
||||||
@@ -367,21 +537,8 @@ public class URLHttpClient implements HttpClient
|
|||||||
String username = configuration.getProxyUser();
|
String username = configuration.getProxyUser();
|
||||||
String password = configuration.getProxyPassword();
|
String password = configuration.getProxyPassword();
|
||||||
|
|
||||||
if (Util.isNotEmpty(username) || Util.isNotEmpty(password))
|
appendBasicAuthHeader(connection, HEADER_PROXY_AUTHORIZATION, username,
|
||||||
{
|
password);
|
||||||
if (logger.isDebugEnabled())
|
|
||||||
{
|
|
||||||
logger.debug("enable proxy authentication for user '{}'",
|
|
||||||
Util.nonNull(username));
|
|
||||||
}
|
|
||||||
|
|
||||||
String auth = Util.nonNull(username).concat(CREDENTIAL_SEPARATOR).concat(
|
|
||||||
Util.nonNull(password));
|
|
||||||
|
|
||||||
auth = PREFIX_BASIC_AUTHENTICATION.concat(
|
|
||||||
new String(Base64.encode(auth.getBytes())));
|
|
||||||
connection.setRequestProperty(HEADER_PROXY_AUTHORIZATION, auth);
|
|
||||||
}
|
|
||||||
|
|
||||||
return connection;
|
return connection;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,81 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Provider;
|
||||||
|
|
||||||
|
import sonia.scm.config.ScmConfiguration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class RestJsonUrlProvider implements Provider<UrlProvider>
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param configuration
|
||||||
|
*/
|
||||||
|
@Inject
|
||||||
|
public RestJsonUrlProvider(ScmConfiguration configuration)
|
||||||
|
{
|
||||||
|
this.configuration = configuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public UrlProvider get()
|
||||||
|
{
|
||||||
|
return UrlProviderFactory.createUrlProvider(configuration.getBaseUrl(),
|
||||||
|
UrlProviderFactory.TYPE_RESTAPI_JSON);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private ScmConfiguration configuration;
|
||||||
|
}
|
||||||
@@ -0,0 +1,81 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Provider;
|
||||||
|
|
||||||
|
import sonia.scm.config.ScmConfiguration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class RestXmlUrlProvider implements Provider<UrlProvider>
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param configuration
|
||||||
|
*/
|
||||||
|
@Inject
|
||||||
|
public RestXmlUrlProvider(ScmConfiguration configuration)
|
||||||
|
{
|
||||||
|
this.configuration = configuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public UrlProvider get()
|
||||||
|
{
|
||||||
|
return UrlProviderFactory.createUrlProvider(configuration.getBaseUrl(),
|
||||||
|
UrlProviderFactory.TYPE_RESTAPI_XML);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private ScmConfiguration configuration;
|
||||||
|
}
|
||||||
81
scm-webapp/src/main/java/sonia/scm/url/WebUIUrlProvider.java
Normal file
81
scm-webapp/src/main/java/sonia/scm/url/WebUIUrlProvider.java
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.url;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Provider;
|
||||||
|
|
||||||
|
import sonia.scm.config.ScmConfiguration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
public class WebUIUrlProvider implements Provider<UrlProvider>
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs ...
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param configuration
|
||||||
|
*/
|
||||||
|
@Inject
|
||||||
|
public WebUIUrlProvider(ScmConfiguration configuration)
|
||||||
|
{
|
||||||
|
this.configuration = configuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- get methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public UrlProvider get()
|
||||||
|
{
|
||||||
|
return UrlProviderFactory.createUrlProvider(configuration.getBaseUrl(),
|
||||||
|
UrlProviderFactory.TYPE_WUI);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
private ScmConfiguration configuration;
|
||||||
|
}
|
||||||
@@ -34,6 +34,7 @@ Sonia.config.RepositoryConfig = Ext.extend(Sonia.config.ConfigPanel,{
|
|||||||
initComponent: function(){
|
initComponent: function(){
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
|
title: main.tabRepositoryTypesText,
|
||||||
panels: repositoryConfigPanels
|
panels: repositoryConfigPanels
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -90,6 +90,7 @@ Sonia.config.ScmConfigPanel = Ext.extend(Sonia.config.ConfigPanel,{
|
|||||||
initComponent: function(){
|
initComponent: function(){
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
|
title: main.navGeneralConfigText,
|
||||||
panels: [{
|
panels: [{
|
||||||
xtype: 'configForm',
|
xtype: 'configForm',
|
||||||
title: this.titleText,
|
title: this.titleText,
|
||||||
|
|||||||
@@ -48,7 +48,7 @@ Sonia.group.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
url: restUrl + 'groups.json',
|
url: restUrl + 'groups.json',
|
||||||
disableCaching: false
|
disableCaching: false
|
||||||
}),
|
}),
|
||||||
id: 'name',
|
idProperty: 'name',
|
||||||
fields: [ 'name', 'members', 'description', 'creationDate', 'type', 'properties'],
|
fields: [ 'name', 'members', 'description', 'creationDate', 'type', 'properties'],
|
||||||
sortInfo: {
|
sortInfo: {
|
||||||
field: 'name'
|
field: 'name'
|
||||||
|
|||||||
@@ -181,14 +181,25 @@ Sonia.History.register('groupPanel', {
|
|||||||
return token;
|
return token;
|
||||||
},
|
},
|
||||||
|
|
||||||
onChange: function(repoId){
|
onChange: function(groupId){
|
||||||
var panel = Ext.getCmp('groups');
|
var panel = Ext.getCmp('groups');
|
||||||
if ( ! panel ){
|
if ( ! panel ){
|
||||||
main.addGroupsTabPanel();
|
main.addGroupsTabPanel();
|
||||||
panel = Ext.getCmp('groups');
|
panel = Ext.getCmp('groups');
|
||||||
|
if (groupId){
|
||||||
|
var selected = false;
|
||||||
|
panel.getGrid().getStore().addListener('load', function(){
|
||||||
|
if (!selected){
|
||||||
|
panel.getGrid().selectById(groupId);
|
||||||
|
selected = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
main.addTab(panel);
|
||||||
|
if (groupId){
|
||||||
|
panel.getGrid().selectById(groupId);
|
||||||
}
|
}
|
||||||
if (repoId){
|
|
||||||
panel.getGrid().selectById(repoId);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -65,6 +65,7 @@ Sonia.plugin.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
});
|
});
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
|
title: main.tabPluginsText,
|
||||||
autoExpandColumn: 'description',
|
autoExpandColumn: 'description',
|
||||||
store: new Sonia.plugin.Store({
|
store: new Sonia.plugin.Store({
|
||||||
url: restUrl + 'plugins/overview.json'
|
url: restUrl + 'plugins/overview.json'
|
||||||
|
|||||||
@@ -140,7 +140,7 @@ Sonia.repository.ChangesetViewerGrid = Ext.extend(Ext.grid.GridPanel, {
|
|||||||
|
|
||||||
openDiffViewer: function(revision){
|
openDiffViewer: function(revision){
|
||||||
main.addTab({
|
main.addTab({
|
||||||
id: 'diffPanel|' + this.repository.id + '|' + revision,
|
id: 'diffPanel;' + this.repository.id + ';' + revision,
|
||||||
xtype: 'diffPanel',
|
xtype: 'diffPanel',
|
||||||
repository: this.repository,
|
repository: this.repository,
|
||||||
revision: revision,
|
revision: revision,
|
||||||
@@ -150,7 +150,7 @@ Sonia.repository.ChangesetViewerGrid = Ext.extend(Ext.grid.GridPanel, {
|
|||||||
|
|
||||||
openRepositoryBrowser: function(revision){
|
openRepositoryBrowser: function(revision){
|
||||||
main.addTab({
|
main.addTab({
|
||||||
id: 'repositoryBrowser|' + this.repository.id + '|' + revision,
|
id: 'repositoryBrowser;' + this.repository.id + ';' + revision,
|
||||||
xtype: 'repositoryBrowser',
|
xtype: 'repositoryBrowser',
|
||||||
repository: this.repository,
|
repository: this.repository,
|
||||||
revision: revision,
|
revision: revision,
|
||||||
|
|||||||
@@ -154,7 +154,7 @@ Sonia.History.register('repositoryChangesetViewerPanel', {
|
|||||||
if (limit){
|
if (limit){
|
||||||
limit = parseInt(limit);
|
limit = parseInt(limit);
|
||||||
}
|
}
|
||||||
var id = 'repositoryChangesetViewerPanel|' + repoId;
|
var id = 'repositoryChangesetViewerPanel;' + repoId;
|
||||||
Sonia.repository.get(repoId, function(repository){
|
Sonia.repository.get(repoId, function(repository){
|
||||||
var panel = Ext.getCmp(id);
|
var panel = Ext.getCmp(id);
|
||||||
if (! panel){
|
if (! panel){
|
||||||
|
|||||||
@@ -210,7 +210,7 @@ Sonia.History.register('contentPanel', {
|
|||||||
if (!view || view == 'null'){
|
if (!view || view == 'null'){
|
||||||
view = 'content';
|
view = 'content';
|
||||||
}
|
}
|
||||||
var id = 'contentPanel|' + repoId + '|' + revision + '|' + path;
|
var id = 'contentPanel;' + repoId + ';' + revision + ';' + path;
|
||||||
Sonia.repository.get(repoId, function(repository){
|
Sonia.repository.get(repoId, function(repository){
|
||||||
var panel = Ext.getCmp(id);
|
var panel = Ext.getCmp(id);
|
||||||
if (! panel){
|
if (! panel){
|
||||||
|
|||||||
@@ -81,7 +81,7 @@ Sonia.History.register('diffPanel', {
|
|||||||
},
|
},
|
||||||
|
|
||||||
onChange: function(repoId, revision){
|
onChange: function(repoId, revision){
|
||||||
var id = 'diffPanel|' + repoId + '|' + revision;
|
var id = 'diffPanel;' + repoId + ';' + revision;
|
||||||
Sonia.repository.get(repoId, function(repository){
|
Sonia.repository.get(repoId, function(repository){
|
||||||
var panel = Ext.getCmp(id);
|
var panel = Ext.getCmp(id);
|
||||||
if (! panel){
|
if (! panel){
|
||||||
|
|||||||
@@ -95,7 +95,7 @@ Sonia.repository.ExtendedInfoPanel = Ext.extend(Sonia.repository.InfoPanel,{
|
|||||||
|
|
||||||
createRepositoryBrowser: function(){
|
createRepositoryBrowser: function(){
|
||||||
return {
|
return {
|
||||||
id: 'repositoryBrowser|' + this.item.id + '|null',
|
id: 'repositoryBrowser;' + this.item.id + ';null',
|
||||||
xtype: 'repositoryBrowser',
|
xtype: 'repositoryBrowser',
|
||||||
repository: this.item,
|
repository: this.item,
|
||||||
closable: true
|
closable: true
|
||||||
|
|||||||
@@ -55,6 +55,7 @@ Sonia.repository.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
url: restUrl + 'repositories.json',
|
url: restUrl + 'repositories.json',
|
||||||
disableCaching: false
|
disableCaching: false
|
||||||
}),
|
}),
|
||||||
|
idProperty: 'id',
|
||||||
reader: new Ext.data.JsonReader({
|
reader: new Ext.data.JsonReader({
|
||||||
fields: [{
|
fields: [{
|
||||||
name: 'id'
|
name: 'id'
|
||||||
@@ -81,7 +82,6 @@ Sonia.repository.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
name: 'properties'
|
name: 'properties'
|
||||||
}]
|
}]
|
||||||
}),
|
}),
|
||||||
id: 'id',
|
|
||||||
sortInfo: {
|
sortInfo: {
|
||||||
field: 'name'
|
field: 'name'
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -148,7 +148,7 @@ Sonia.repository.InfoPanel = Ext.extend(Ext.Panel, {
|
|||||||
|
|
||||||
createChangesetViewer: function(){
|
createChangesetViewer: function(){
|
||||||
return {
|
return {
|
||||||
id: 'repositoryChangesetViewerPanel|' + this.item.id,
|
id: 'repositoryChangesetViewerPanel;' + this.item.id,
|
||||||
repository: this.item,
|
repository: this.item,
|
||||||
xtype: 'repositoryChangesetViewerPanel',
|
xtype: 'repositoryChangesetViewerPanel',
|
||||||
closable: true,
|
closable: true,
|
||||||
|
|||||||
@@ -107,7 +107,20 @@ Sonia.repository.get = function(id, callback){
|
|||||||
if ( grid ){
|
if ( grid ){
|
||||||
var store = grid.getStore();
|
var store = grid.getStore();
|
||||||
if (store){
|
if (store){
|
||||||
var rec = store.getById(id);
|
var rec = null;
|
||||||
|
var index = id.indexOf('/');
|
||||||
|
if ( index > 0 ){
|
||||||
|
var type = id.substring(0, index);
|
||||||
|
var name = id.substring(index);
|
||||||
|
index = store.findBy(function(rec){
|
||||||
|
return rec.get('name') == name && rec.get('type') == type;
|
||||||
|
});
|
||||||
|
if ( index >= 0 ){
|
||||||
|
rec = store.getAt(index);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
rec = store.getById(id);
|
||||||
|
}
|
||||||
if (rec){
|
if (rec){
|
||||||
repository = rec.data;
|
repository = rec.data;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -295,9 +295,20 @@ Sonia.History.register('repositoryPanel', {
|
|||||||
if ( ! panel ){
|
if ( ! panel ){
|
||||||
main.addRepositoriesTabPanel();
|
main.addRepositoriesTabPanel();
|
||||||
panel = Ext.getCmp('repositories');
|
panel = Ext.getCmp('repositories');
|
||||||
|
if ( repoId ){
|
||||||
|
var selected = false;
|
||||||
|
panel.getGrid().getStore().addListener('load', function(){
|
||||||
|
if (!selected){
|
||||||
|
panel.getGrid().selectedById(repoId);
|
||||||
|
selected = true;
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
main.addTab(panel);
|
||||||
if (repoId){
|
if (repoId){
|
||||||
panel.getGrid().selectById(repoId);
|
panel.getGrid().selectById(repoId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
@@ -329,7 +329,7 @@ Sonia.History.register('repositoryBrowser', {
|
|||||||
if (path == 'null'){
|
if (path == 'null'){
|
||||||
path = '';
|
path = '';
|
||||||
}
|
}
|
||||||
var id = 'repositoryBrowser|' + repoId + "|" + revision;
|
var id = 'repositoryBrowser;' + repoId + ';' + revision;
|
||||||
Sonia.repository.get(repoId, function(repository){
|
Sonia.repository.get(repoId, function(repository){
|
||||||
var panel = Ext.getCmp(id);
|
var panel = Ext.getCmp(id);
|
||||||
if (! panel){
|
if (! panel){
|
||||||
|
|||||||
@@ -134,6 +134,9 @@ Sonia.rest.Grid = Ext.extend(Ext.grid.GridPanel, {
|
|||||||
},
|
},
|
||||||
|
|
||||||
selectById: function(id){
|
selectById: function(id){
|
||||||
|
if (debug){
|
||||||
|
console.debug( 'select by id ' + id );
|
||||||
|
}
|
||||||
var index = this.getStore().indexOfId(id);
|
var index = this.getStore().indexOfId(id);
|
||||||
if ( index >= 0 ){
|
if ( index >= 0 ){
|
||||||
this.getSelectionModel().selectRow(index);
|
this.getSelectionModel().selectRow(index);
|
||||||
|
|||||||
@@ -85,7 +85,7 @@ var groupSearchStore = new Ext.data.JsonStore({
|
|||||||
|
|
||||||
Sonia = {
|
Sonia = {
|
||||||
|
|
||||||
idSeparator: '|',
|
idSeparator: ';',
|
||||||
idNoneObject: '-',
|
idNoneObject: '-',
|
||||||
|
|
||||||
id: function(){
|
id: function(){
|
||||||
@@ -93,7 +93,7 @@ Sonia = {
|
|||||||
for ( var i=0; i<arguments.length; i++ ){
|
for ( var i=0; i<arguments.length; i++ ){
|
||||||
id += arguments[i];
|
id += arguments[i];
|
||||||
if ( (i+1) < arguments.length ){
|
if ( (i+1) < arguments.length ){
|
||||||
id += '|';
|
id += this.idSeparator;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (id.length() == 0){
|
if (id.length() == 0){
|
||||||
@@ -110,6 +110,3 @@ var main = null;
|
|||||||
|
|
||||||
// enable extjs quicktips
|
// enable extjs quicktips
|
||||||
Ext.QuickTips.init();
|
Ext.QuickTips.init();
|
||||||
|
|
||||||
// enable history
|
|
||||||
Ext.History.init();
|
|
||||||
@@ -33,6 +33,7 @@ Ext.ns('Sonia');
|
|||||||
Sonia.History = {
|
Sonia.History = {
|
||||||
|
|
||||||
initialized: false,
|
initialized: false,
|
||||||
|
|
||||||
historyElements: [],
|
historyElements: [],
|
||||||
recentlyAdded: [],
|
recentlyAdded: [],
|
||||||
recentlyChanged: [],
|
recentlyChanged: [],
|
||||||
@@ -56,7 +57,7 @@ Sonia.History = {
|
|||||||
for (var i=0; i<arguments.length; i++){
|
for (var i=0; i<arguments.length; i++){
|
||||||
token += arguments[i];
|
token += arguments[i];
|
||||||
if ( (i+1)<arguments.length ){
|
if ( (i+1)<arguments.length ){
|
||||||
token += '|';
|
token += ';';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return token;
|
return token;
|
||||||
@@ -74,17 +75,17 @@ Sonia.History = {
|
|||||||
for (var i=0; i<item.length; i++){
|
for (var i=0; i<item.length; i++){
|
||||||
tokenSuffix += item[i];
|
tokenSuffix += item[i];
|
||||||
if ( (i+1)<item.length ){
|
if ( (i+1)<item.length ){
|
||||||
tokenSuffix += '|';
|
tokenSuffix += ';';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
tokenSuffix = item;
|
tokenSuffix = item;
|
||||||
}
|
}
|
||||||
|
|
||||||
var parts = token.split('|');
|
var parts = token.split(';');
|
||||||
var newToken = '';
|
var newToken = '';
|
||||||
for (var j=0; j<depth; j++){
|
for (var j=0; j<depth; j++){
|
||||||
newToken += parts[j] + '|';
|
newToken += parts[j] + ';';
|
||||||
}
|
}
|
||||||
newToken += tokenSuffix;
|
newToken += tokenSuffix;
|
||||||
this.add(newToken);
|
this.add(newToken);
|
||||||
@@ -133,12 +134,9 @@ Sonia.History = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
onChange: function(token){
|
onChange: function(token){
|
||||||
if (!this.initialized){
|
|
||||||
this.initialized = true;
|
|
||||||
}
|
|
||||||
if(token){
|
if(token){
|
||||||
if (this.isInvokeable(this.recentlyAdded, token)){
|
if (this.isInvokeable(this.recentlyAdded, token)){
|
||||||
var parts = token.split('|');
|
var parts = token.split(';');
|
||||||
var id = parts[0];
|
var id = parts[0];
|
||||||
this.recentlyChanged.push(token);
|
this.recentlyChanged.push(token);
|
||||||
Sonia.History.handleChange(id, parts.splice(1));
|
Sonia.History.handleChange(id, parts.splice(1));
|
||||||
@@ -173,16 +171,10 @@ Sonia.History = {
|
|||||||
|
|
||||||
Ext.History.on('ready', function(history){
|
Ext.History.on('ready', function(history){
|
||||||
var token = history.getToken();
|
var token = history.getToken();
|
||||||
if (!token || token == 'null'){
|
if (token && token != 'null'){
|
||||||
Sonia.History.initialized = true;
|
|
||||||
} else {
|
|
||||||
setTimeout(function(){
|
|
||||||
if (debug){
|
|
||||||
console.debug('history ready, handle history token ' + token);
|
|
||||||
}
|
|
||||||
Sonia.History.onChange(token);
|
Sonia.History.onChange(token);
|
||||||
}, 750);
|
|
||||||
}
|
}
|
||||||
|
Sonia.History.initialized = true;
|
||||||
});
|
});
|
||||||
|
|
||||||
Ext.History.on('change', function(token){
|
Ext.History.on('change', function(token){
|
||||||
|
|||||||
@@ -528,6 +528,10 @@ Ext.onReady(function(){
|
|||||||
main.addListeners('login', loginCallbacks);
|
main.addListeners('login', loginCallbacks);
|
||||||
main.addListeners('logout', logoutCallbacks);
|
main.addListeners('logout', logoutCallbacks);
|
||||||
|
|
||||||
|
main.addListeners('login', function(){
|
||||||
|
Ext.History.init();
|
||||||
|
});
|
||||||
|
|
||||||
main.init();
|
main.init();
|
||||||
main.checkLogin();
|
main.checkLogin();
|
||||||
});
|
});
|
||||||
@@ -41,6 +41,9 @@ Sonia.user.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
colLastModifiedText: 'Last modified',
|
colLastModifiedText: 'Last modified',
|
||||||
colTypeText: 'Type',
|
colTypeText: 'Type',
|
||||||
|
|
||||||
|
// parent for history
|
||||||
|
parentPanel: null,
|
||||||
|
|
||||||
initComponent: function(){
|
initComponent: function(){
|
||||||
|
|
||||||
var userStore = new Sonia.rest.JsonStore({
|
var userStore = new Sonia.rest.JsonStore({
|
||||||
@@ -48,7 +51,7 @@ Sonia.user.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
url: restUrl + 'users.json',
|
url: restUrl + 'users.json',
|
||||||
disableCaching: false
|
disableCaching: false
|
||||||
}),
|
}),
|
||||||
id: 'name',
|
idProperty: 'name',
|
||||||
fields: [ 'name', 'displayName', 'mail', 'admin', 'creationDate', 'lastModified', 'type', 'properties'],
|
fields: [ 'name', 'displayName', 'mail', 'admin', 'creationDate', 'lastModified', 'type', 'properties'],
|
||||||
sortInfo: {
|
sortInfo: {
|
||||||
field: 'name'
|
field: 'name'
|
||||||
@@ -85,6 +88,10 @@ Sonia.user.Grid = Ext.extend(Sonia.rest.Grid, {
|
|||||||
|
|
||||||
Ext.apply(this, Ext.apply(this.initialConfig, config));
|
Ext.apply(this, Ext.apply(this.initialConfig, config));
|
||||||
Sonia.user.Grid.superclass.initComponent.apply(this, arguments);
|
Sonia.user.Grid.superclass.initComponent.apply(this, arguments);
|
||||||
|
|
||||||
|
if (this.parentPanel){
|
||||||
|
this.parentPanel.userGrid = this;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onFallBelowMinHeight: function(height, minHeight){
|
onFallBelowMinHeight: function(height, minHeight){
|
||||||
|
|||||||
@@ -38,6 +38,9 @@ Sonia.user.Panel = Ext.extend(Sonia.rest.Panel, {
|
|||||||
errorTitleText: 'Error',
|
errorTitleText: 'Error',
|
||||||
errorMsgText: 'User deletion failed',
|
errorMsgText: 'User deletion failed',
|
||||||
|
|
||||||
|
// userGrid for history
|
||||||
|
userGrid: null,
|
||||||
|
|
||||||
initComponent: function(){
|
initComponent: function(){
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
@@ -51,7 +54,8 @@ Sonia.user.Panel = Ext.extend(Sonia.rest.Panel, {
|
|||||||
items: [{
|
items: [{
|
||||||
id: 'userGrid',
|
id: 'userGrid',
|
||||||
xtype: 'userGrid',
|
xtype: 'userGrid',
|
||||||
region: 'center'
|
region: 'center',
|
||||||
|
parentPanel: this
|
||||||
},{
|
},{
|
||||||
id: 'userEditPanel',
|
id: 'userEditPanel',
|
||||||
layout: 'fit',
|
layout: 'fit',
|
||||||
@@ -73,6 +77,16 @@ Sonia.user.Panel = Ext.extend(Sonia.rest.Panel, {
|
|||||||
Sonia.user.Panel.superclass.initComponent.apply(this, arguments);
|
Sonia.user.Panel.superclass.initComponent.apply(this, arguments);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getGrid: function(){
|
||||||
|
if (!this.userGrid){
|
||||||
|
if (debug){
|
||||||
|
console.debug('userGrid not found retrvie by id');
|
||||||
|
}
|
||||||
|
this.userGrid = Ext.getCmp('userGrid');
|
||||||
|
}
|
||||||
|
return this.userGrid;
|
||||||
|
},
|
||||||
|
|
||||||
showAddPanel: function(){
|
showAddPanel: function(){
|
||||||
var editPanel = Ext.getCmp('userEditPanel');
|
var editPanel = Ext.getCmp('userEditPanel');
|
||||||
editPanel.removeAll();
|
editPanel.removeAll();
|
||||||
@@ -99,7 +113,7 @@ Sonia.user.Panel = Ext.extend(Sonia.rest.Panel, {
|
|||||||
|
|
||||||
removeUser: function(){
|
removeUser: function(){
|
||||||
|
|
||||||
var grid = Ext.getCmp('userGrid');
|
var grid = this.getGrid();
|
||||||
var selected = grid.getSelectionModel().getSelected();
|
var selected = grid.getSelectionModel().getSelected();
|
||||||
if ( selected ){
|
if ( selected ){
|
||||||
var item = selected.data;
|
var item = selected.data;
|
||||||
@@ -146,10 +160,48 @@ Sonia.user.Panel = Ext.extend(Sonia.rest.Panel, {
|
|||||||
},
|
},
|
||||||
|
|
||||||
reload: function(){
|
reload: function(){
|
||||||
Ext.getCmp('userGrid').reload();
|
this.getGrid().reload();
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// register xtype
|
// register xtype
|
||||||
Ext.reg('userPanel', Sonia.user.Panel);
|
Ext.reg('userPanel', Sonia.user.Panel);
|
||||||
|
|
||||||
|
|
||||||
|
// register history handler
|
||||||
|
Sonia.History.register('userPanel', {
|
||||||
|
|
||||||
|
onActivate: function(panel){
|
||||||
|
var token = null;
|
||||||
|
var rec = panel.getGrid().getSelectionModel().getSelected();
|
||||||
|
if (rec){
|
||||||
|
token = Sonia.History.createToken('userPanel', rec.get('name'));
|
||||||
|
} else {
|
||||||
|
token = Sonia.History.createToken('userPanel');
|
||||||
|
}
|
||||||
|
return token;
|
||||||
|
},
|
||||||
|
|
||||||
|
onChange: function(userId){
|
||||||
|
var panel = Ext.getCmp('users');
|
||||||
|
if ( ! panel ){
|
||||||
|
main.addUsersTabPanel();
|
||||||
|
panel = Ext.getCmp('users');
|
||||||
|
if ( userId ){
|
||||||
|
var selected = false;
|
||||||
|
panel.getGrid().getStore().addListener('load', function(){
|
||||||
|
if (!selected){
|
||||||
|
panel.getGrid().selectById(userId);
|
||||||
|
selected = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
main.addTab(panel);
|
||||||
|
if (userId){
|
||||||
|
panel.getGrid().selectById(userId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user