aboutsummaryrefslogtreecommitdiffstats
path: root/archiva-modules/archiva-base/archiva-repository-admin
diff options
context:
space:
mode:
authorOlivier Lamy <olamy@apache.org>2012-02-09 23:08:27 +0000
committerOlivier Lamy <olamy@apache.org>2012-02-09 23:08:27 +0000
commite711aa2679bd7e82ad28b7652d6d6a5fcd9831b1 (patch)
tree3ed312ab58bc8a93ea56661d2440c16dde83c42b /archiva-modules/archiva-base/archiva-repository-admin
parent128af35a7ec7768322af12997760eb53dcf3950a (diff)
downloadarchiva-e711aa2679bd7e82ad28b7652d6d6a5fcd9831b1.tar.gz
archiva-e711aa2679bd7e82ad28b7652d6d6a5fcd9831b1.zip
add convenient getter/setter to ease json mapping for Map fields.
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1242597 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'archiva-modules/archiva-base/archiva-repository-admin')
-rw-r--r--archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/AbstractRepositoryConnector.java52
-rw-r--r--archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/beans/PropertyEntry.java79
2 files changed, 131 insertions, 0 deletions
diff --git a/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/AbstractRepositoryConnector.java b/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/AbstractRepositoryConnector.java
index 4f29d1540..4efc1a818 100644
--- a/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/AbstractRepositoryConnector.java
+++ b/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/AbstractRepositoryConnector.java
@@ -18,6 +18,8 @@ package org.apache.archiva.admin.model;
* under the License.
*/
+import org.apache.archiva.admin.model.beans.PropertyEntry;
+
import java.io.Serializable;
import java.util.ArrayList;
import java.util.HashMap;
@@ -62,11 +64,25 @@ public abstract class AbstractRepositoryConnector
private Map<String, String> policies;
/**
+ * field to ease json mapping wrapper on <code>policies</code> field
+ *
+ * @since 1.4-M3
+ */
+ private List<PropertyEntry> policiesEntries;
+
+ /**
* Field properties.
*/
private Map<String, String> properties;
/**
+ * field to ease json mapping wrapper on <code>properties</code> field
+ *
+ * @since 1.4-M3
+ */
+ private List<PropertyEntry> propertiesEntries;
+
+ /**
* If the the repository proxy connector is disabled or not
*/
private boolean disabled = false;
@@ -347,6 +363,42 @@ public abstract class AbstractRepositoryConnector
return value;
}
+ public List<PropertyEntry> getPoliciesEntries()
+ {
+ policiesEntries = new ArrayList<PropertyEntry>( getPolicies().size() );
+ for ( Map.Entry<String, String> entry : getPolicies().entrySet() )
+ {
+ policiesEntries.add( new PropertyEntry( entry.getKey(), entry.getValue() ) );
+ }
+ return policiesEntries;
+ }
+
+ public void setPoliciesEntries( List<PropertyEntry> policiesEntries )
+ {
+ for ( PropertyEntry propertyEntry : policiesEntries )
+ {
+ addPolicy( propertyEntry.getKey(), propertyEntry.getValue() );
+ }
+ }
+
+ public List<PropertyEntry> getPropertiesEntries()
+ {
+ propertiesEntries = new ArrayList<PropertyEntry>( getProperties().size() );
+ for ( Map.Entry<String, String> entry : getProperties().entrySet() )
+ {
+ propertiesEntries.add( new PropertyEntry( entry.getKey(), entry.getValue() ) );
+ }
+ return propertiesEntries;
+ }
+
+ public void setPropertiesEntries( List<PropertyEntry> propertiesEntries )
+ {
+ for ( PropertyEntry propertyEntry : policiesEntries )
+ {
+ addProperty( propertyEntry.getKey(), propertyEntry.getValue() );
+ }
+ }
+
@Override
public boolean equals( Object o )
{
diff --git a/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/beans/PropertyEntry.java b/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/beans/PropertyEntry.java
new file mode 100644
index 000000000..e218d6d25
--- /dev/null
+++ b/archiva-modules/archiva-base/archiva-repository-admin/archiva-repository-admin-api/src/main/java/org/apache/archiva/admin/model/beans/PropertyEntry.java
@@ -0,0 +1,79 @@
+package org.apache.archiva.admin.model.beans;
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import javax.xml.bind.annotation.XmlRootElement;
+import java.io.Serializable;
+
+/**
+ * Bean to expose Map entries as Json
+ *
+ * @author Olivier Lamy
+ * @since 1.4-M3
+ */
+@XmlRootElement( name = "propertyEntry" )
+public class PropertyEntry
+ implements Serializable
+{
+ private String key;
+
+ private String value;
+
+ public PropertyEntry()
+ {
+ // no op
+ }
+
+ public PropertyEntry( String key, String value )
+ {
+ this.key = key;
+ this.value = value;
+ }
+
+ public String getKey()
+ {
+ return key;
+ }
+
+ public void setKey( String key )
+ {
+ this.key = key;
+ }
+
+ public String getValue()
+ {
+ return value;
+ }
+
+ public void setValue( String value )
+ {
+ this.value = value;
+ }
+
+ @Override
+ public String toString()
+ {
+ final StringBuilder sb = new StringBuilder();
+ sb.append( "PropertyEntry" );
+ sb.append( "{key='" ).append( key ).append( '\'' );
+ sb.append( ", value='" ).append( value ).append( '\'' );
+ sb.append( '}' );
+ return sb.toString();
+ }
+}