merge with default branch

This commit is contained in:
Sebastian Sdorra
2011-11-24 19:53:29 +01:00
55 changed files with 2705 additions and 143 deletions

View File

@@ -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 ------------------------------------------------------------

View File

@@ -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
{ {

View File

@@ -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;
;
} }

View File

@@ -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;

View File

@@ -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())

View File

@@ -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 ---------------------------------------------------------------

View File

@@ -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;
} }

View File

@@ -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();
} }
} }

View File

@@ -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();
} }
} }

View File

@@ -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();
} }
} }

View File

@@ -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);

View File

@@ -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
* *

View 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;
}

View 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();
}

View 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);
}

View File

@@ -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;
}

View File

@@ -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();
}
}

View 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;
}

View 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();
}

View 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;
}
}

View File

@@ -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;
}

View File

@@ -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;
}

View 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;
}

View 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;
}

View File

@@ -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
* *

View 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;
}

View File

@@ -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>

View File

@@ -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>

View File

@@ -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);

View File

@@ -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)

View File

@@ -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;
} }

View 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 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;
}

View 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 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;
}

View 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;
}

View File

@@ -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
} }

View File

@@ -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,

View File

@@ -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'

View File

@@ -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);
} }
} }
}); });

View File

@@ -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'

View File

@@ -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,

View File

@@ -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){

View File

@@ -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){

View File

@@ -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){

View File

@@ -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

View File

@@ -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'
}, },

View File

@@ -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,

View File

@@ -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;
} }

View File

@@ -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);
} }
} }
}
}); });

View File

@@ -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){

View File

@@ -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);

View File

@@ -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();

View File

@@ -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){

View File

@@ -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();
}); });

View File

@@ -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){

View File

@@ -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);
}
}
}
});