Author: mfranklin
Date: Thu Jan 16 14:48:41 2014
New Revision: 1558820
URL: http://svn.apache.org/r1558820
Log:
Updated JPA persistence layer to support page template properties
Added:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/persistence/jpa/JpaSerializable.java
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPage.java
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPageTemplate.java
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaWidget.java
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/conversion/JpaPageTemplateConverter.java
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageRepository.java
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageTemplateRepository.java
rave/trunk/rave-components/rave-mongodb/src/main/java/org/apache/rave/portal/model/conversion/impl/MongoDbPageTemplateConverter.java
Added:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/persistence/jpa/JpaSerializable.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/persistence/jpa/JpaSerializable.java?rev=1558820&view=auto
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/persistence/jpa/JpaSerializable.java
(added)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/persistence/jpa/JpaSerializable.java
Thu Jan 16 14:48:41 2014
@@ -0,0 +1,34 @@
+/*
+ * 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.
+ */
+package org.apache.rave.persistence.jpa;
+
+/**
+ * Provides methods for serializing complex properties into simple, serialized
structures
+ */
+public interface JpaSerializable {
+ /**
+ * Serialize the data into persisted fields
+ */
+ void serializeData();
+
+ /**
+ * Deserialize the data into the operational fields
+ */
+ void deserializeData();
+}
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPage.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPage.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPage.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPage.java
Thu Jan 16 14:48:41 2014
@@ -21,6 +21,7 @@ package org.apache.rave.portal.model;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonManagedReference;
import org.apache.rave.model.*;
+import org.apache.rave.persistence.jpa.JpaSerializable;
import org.apache.rave.portal.model.conversion.ConvertingListProxyFactory;
import org.apache.rave.portal.model.conversion.JpaConverter;
import org.apache.rave.util.JsonUtils;
@@ -53,7 +54,7 @@ import java.util.*;
@NamedQuery(name = JpaPage.GET_BY_CONTEXT_AND_PAGE_TYPE, query="SELECT
p FROM JpaPage p WHERE p.contextId = :contextId and p.pageType = :pageType")
})
@Access(AccessType.FIELD)
-public class JpaPage implements BasicEntity, Serializable, Page {
+public class JpaPage implements BasicEntity, Serializable, JpaSerializable,
Page {
private static final long serialVersionUID = 2L;
public static final String DELETE_BY_USER_ID_AND_PAGE_TYPE =
"JpaPage.deleteByUserIdAndPageType";
@@ -339,6 +340,7 @@ public class JpaPage implements BasicEnt
return "Page{" + "entityId=" + entityId + ", name=" + name + ",
ownerId=" + ownerId + ", pageLayout=" + pageLayout + ", pageType=" + pageType +
"}";
}
+ @Override
public void serializeData() {
Map<String, Object> properties = this.getProperties();
if(properties != null) {
@@ -346,6 +348,7 @@ public class JpaPage implements BasicEnt
}
}
+ @Override
@SuppressWarnings("unchecked")
public void deserializeData() {
if(serializedData != null) {
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPageTemplate.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPageTemplate.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPageTemplate.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaPageTemplate.java
Thu Jan 16 14:48:41 2014
@@ -24,8 +24,10 @@ import org.apache.rave.model.PageLayout;
import org.apache.rave.model.PageTemplate;
import org.apache.rave.model.PageTemplateRegion;
import org.apache.rave.model.PageType;
+import org.apache.rave.persistence.jpa.JpaSerializable;
import org.apache.rave.portal.model.conversion.ConvertingListProxyFactory;
import org.apache.rave.portal.model.conversion.JpaConverter;
+import org.apache.rave.util.JsonUtils;
import javax.persistence.*;
import java.io.Serializable;
@@ -41,7 +43,7 @@ import java.util.Map;
@NamedQuery(name = JpaPageTemplate.PAGE_TEMPLATE_GET_ALL_FOR_TYPE,
query = "SELECT p FROM JpaPageTemplate p WHERE p.pageType = :pageType")
})
@Access(AccessType.FIELD)
-public class JpaPageTemplate implements BasicEntity, Serializable,
PageTemplate {
+public class JpaPageTemplate implements BasicEntity, Serializable,
JpaSerializable, PageTemplate {
private static final long serialVersionUID = 1L;
public static final String PAGE_TEMPLATE_GET_ALL = "PageTemplate.getAll";
@@ -230,4 +232,20 @@ public class JpaPageTemplate implements
public void setProperties(Map<String, Object> properties) {
this.properties = properties;
}
+
+ @Override
+ public void serializeData() {
+ Map<String, Object> properties = this.getProperties();
+ if(properties != null) {
+ serializedData = JsonUtils.stringify(properties);
+ }
+ }
+
+ @Override
+ @SuppressWarnings("unchecked")
+ public void deserializeData() {
+ if(serializedData != null) {
+ this.setProperties(JsonUtils.parse(serializedData, Map.class));
+ }
+ }
}
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaWidget.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaWidget.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaWidget.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/JpaWidget.java
Thu Jan 16 14:48:41 2014
@@ -21,6 +21,7 @@ package org.apache.rave.portal.model;
import com.fasterxml.jackson.annotation.JsonIgnore;
import org.apache.rave.model.*;
+import org.apache.rave.persistence.jpa.JpaSerializable;
import org.apache.rave.portal.model.conversion.ConvertingListProxyFactory;
import org.apache.rave.util.JsonUtils;
@@ -65,7 +66,7 @@ import java.util.Map;
@NamedQuery(name = JpaWidget.WIDGET_COUNT_BY_TAG, query =
JpaWidget.SELECT_COUNT_W_FROM_WIDGET_W + JpaWidget.JOIN_TAGS +
JpaWidget.WHERE_CLAUSE_TAG_ID),
@NamedQuery(name = JpaWidget.WIDGET_UNASSIGN_OWNER, query = "UPDATE
JpaWidget w SET w.ownerId = null " + JpaWidget.WHERE_CLAUSE_OWNER )
})
-public class JpaWidget implements BasicEntity, Serializable, Widget {
+public class JpaWidget implements BasicEntity, Serializable, JpaSerializable,
Widget {
private static final long serialVersionUID = 2L;
public static final String PARAM_SEARCH_TERM = "searchTerm";
@@ -473,6 +474,7 @@ public class JpaWidget implements BasicE
this.serializedData = serializedData;
}
+ @Override
public void serializeData() {
Map<String, Object> properties = this.getProperties();
if(properties != null) {
@@ -480,6 +482,7 @@ public class JpaWidget implements BasicE
}
}
+ @Override
@SuppressWarnings("unchecked")
public void deserializeData() {
if(serializedData != null) {
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/conversion/JpaPageTemplateConverter.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/conversion/JpaPageTemplateConverter.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/conversion/JpaPageTemplateConverter.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/model/conversion/JpaPageTemplateConverter.java
Thu Jan 16 14:48:41 2014
@@ -67,5 +67,6 @@ public class JpaPageTemplateConverter im
converted.setPageTemplateRegions(source.getPageTemplateRegions());
converted.setRenderSequence(source.getRenderSequence());
converted.setDefaultTemplate(source.isDefaultTemplate());
+ converted.setProperties(source.getProperties());
}
}
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageRepository.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageRepository.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageRepository.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageRepository.java
Thu Jan 16 14:48:41 2014
@@ -158,13 +158,13 @@ public class JpaPageRepository implement
@Override
public List<Page> getAll() {
- TypedQuery<Page> query = manager.createNamedQuery(JpaPage.GET_ALL,
Page.class);
+ TypedQuery<JpaPage> query = manager.createNamedQuery(JpaPage.GET_ALL,
JpaPage.class);
return
expandProperties(CollectionUtils.<Page>toBaseTypedList(query.getResultList()));
}
@Override
public List<Page> getLimitedList(int offset, int limit) {
- TypedQuery<Page> query = manager.createNamedQuery(JpaPage.GET_ALL,
Page.class);
+ TypedQuery<JpaPage> query = manager.createNamedQuery(JpaPage.GET_ALL,
JpaPage.class);
return
expandProperties(CollectionUtils.<Page>toBaseTypedList(getPagedResultList(query,
offset, limit)));
}
Modified:
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageTemplateRepository.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageTemplateRepository.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageTemplateRepository.java
(original)
+++
rave/trunk/rave-components/rave-jpa/src/main/java/org/apache/rave/portal/repository/impl/JpaPageTemplateRepository.java
Thu Jan 16 14:48:41 2014
@@ -19,6 +19,7 @@
package org.apache.rave.portal.repository.impl;
import org.apache.commons.lang.NotImplementedException;
+import org.apache.rave.persistence.jpa.JpaSerializable;
import org.apache.rave.portal.model.JpaPageTemplate;
import org.apache.rave.model.PageTemplate;
import org.apache.rave.portal.model.conversion.JpaConverter;
@@ -43,13 +44,13 @@ public class JpaPageTemplateRepository i
@Override
public List<PageTemplate> getAll() {
TypedQuery<JpaPageTemplate> query =
manager.createNamedQuery(JpaPageTemplate.PAGE_TEMPLATE_GET_ALL,
JpaPageTemplate.class);
- return
CollectionUtils.<PageTemplate>toBaseTypedList(query.getResultList());
+ return
CollectionUtils.<PageTemplate>toBaseTypedList(expandProperties(query.getResultList()));
}
@Override
public List<PageTemplate> getLimitedList(int offset, int limit) {
TypedQuery<JpaPageTemplate> query =
manager.createNamedQuery(JpaPageTemplate.PAGE_TEMPLATE_GET_ALL,
JpaPageTemplate.class);
- return
CollectionUtils.<PageTemplate>toBaseTypedList(getPagedResultList(query, offset,
limit));
+ return
CollectionUtils.<PageTemplate>toBaseTypedList(expandProperties(getPagedResultList(query,
offset, limit)));
}
@Override
@@ -61,14 +62,14 @@ public class JpaPageTemplateRepository i
public List<PageTemplate> getAll(String pageType) {
TypedQuery<JpaPageTemplate> query =
manager.createNamedQuery(JpaPageTemplate.PAGE_TEMPLATE_GET_ALL_FOR_TYPE,
JpaPageTemplate.class);
query.setParameter("pageType", pageType.toUpperCase());
- return
CollectionUtils.<PageTemplate>toBaseTypedList(query.getResultList());
+ return
CollectionUtils.<PageTemplate>toBaseTypedList(expandProperties(query.getResultList()));
}
@Override
public JpaPageTemplate getDefaultPage(String pageType) {
TypedQuery<JpaPageTemplate> query =
manager.createNamedQuery(JpaPageTemplate.PAGE_TEMPLATE_GET_DEFAULT_PAGE_BY_TYPE,
JpaPageTemplate.class);
query.setParameter("pageType", pageType.toUpperCase());
- return query.getSingleResult();
+ return expandProperties(query.getSingleResult());
}
@Override
@@ -78,16 +79,30 @@ public class JpaPageTemplateRepository i
@Override
public PageTemplate get(String id) {
- return manager.find(JpaPageTemplate.class, id);
+ return expandProperties(manager.find(JpaPageTemplate.class, id));
}
@Override
public PageTemplate save(PageTemplate template) {
- return (PageTemplate) saveOrUpdate(template.getId(), manager,
JpaConverter.getInstance().convert(template, PageTemplate.class));
+ JpaPageTemplate converted =
JpaConverter.getInstance().convert(template, PageTemplate.class);
+ converted.serializeData();
+ return expandProperties(saveOrUpdate(template.getId(), manager,
converted));
}
@Override
public void delete(PageTemplate item) {
manager.remove(JpaConverter.getInstance().convert(item,
PageTemplate.class));
}
+
+ private List<JpaPageTemplate> expandProperties(List<JpaPageTemplate>
resultList) {
+ for(JpaSerializable serializable : resultList) {
+ expandProperties(serializable);
+ }
+ return resultList;
+ }
+
+ private <T extends JpaSerializable> T expandProperties(T jpaPageTemplate) {
+ jpaPageTemplate.deserializeData();
+ return jpaPageTemplate;
+ }
}
\ No newline at end of file
Modified:
rave/trunk/rave-components/rave-mongodb/src/main/java/org/apache/rave/portal/model/conversion/impl/MongoDbPageTemplateConverter.java
URL:
http://svn.apache.org/viewvc/rave/trunk/rave-components/rave-mongodb/src/main/java/org/apache/rave/portal/model/conversion/impl/MongoDbPageTemplateConverter.java?rev=1558820&r1=1558819&r2=1558820&view=diff
==============================================================================
---
rave/trunk/rave-components/rave-mongodb/src/main/java/org/apache/rave/portal/model/conversion/impl/MongoDbPageTemplateConverter.java
(original)
+++
rave/trunk/rave-components/rave-mongodb/src/main/java/org/apache/rave/portal/model/conversion/impl/MongoDbPageTemplateConverter.java
Thu Jan 16 14:48:41 2014
@@ -138,6 +138,7 @@ public class MongoDbPageTemplateConverte
converted.setId(source.getId() == null ? generateId() :
source.getId());
converted.setName(source.getName());
converted.setDescription(source.getDescription());
+ converted.setProperties(source.getProperties());
//Enforce consistent casing for page types
converted.setPageType(source.getPageType() == null ? null :
source.getPageType().toUpperCase());