-/*-\r
- * ================================================================================\r
- * ECOMP Portal\r
- * ================================================================================\r
- * Copyright (C) 2017 AT&T Intellectual Property\r
- * ================================================================================\r
- * Licensed under the Apache License, Version 2.0 (the "License");\r
- * you may not use this file except in compliance with the License.\r
- * You may obtain a copy of the License at\r
- * \r
- * http://www.apache.org/licenses/LICENSE-2.0\r
- * \r
- * Unless required by applicable law or agreed to in writing, software\r
- * distributed under the License is distributed on an "AS IS" BASIS,\r
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
- * See the License for the specific language governing permissions and\r
- * limitations under the License.\r
- * ================================================================================\r
- */\r
-package org.openecomp.portalapp.portal.service;\r
-\r
-import java.text.SimpleDateFormat;\r
-import java.util.ArrayList;\r
-import java.util.Date;\r
-import java.util.List;\r
-\r
-import org.hibernate.criterion.Criterion;\r
-import org.hibernate.criterion.Restrictions;\r
-import org.springframework.beans.factory.annotation.Autowired;\r
-import org.springframework.context.annotation.EnableAspectJAutoProxy;\r
-import org.springframework.stereotype.Service;\r
-import org.springframework.transaction.annotation.Transactional;\r
-\r
-import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate;\r
-import org.openecomp.portalsdk.core.service.DataAccessService;\r
-import org.openecomp.portalapp.portal.domain.SharedContext;\r
-import org.openecomp.portalapp.portal.logging.aop.EPMetricsLog;\r
-\r
-/**\r
- * Implementation of the shared-context service that talks to the database.\r
- */\r
-@Service("sharedContextService")\r
-@Transactional\r
-@org.springframework.context.annotation.Configuration\r
-@EnableAspectJAutoProxy\r
-@EPMetricsLog\r
-public class SharedContextServiceImpl implements SharedContextService {\r
-\r
- @Autowired\r
- private DataAccessService dataAccessService;\r
-\r
- private EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(SharedContextServiceImpl.class);\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalsdk.core.service.SharedContextService#\r
- * getSharedContexts()\r
- */\r
- @Override\r
- @SuppressWarnings("unchecked")\r
- public List<SharedContext> getSharedContexts(String contextId) {\r
- List<Criterion> restrictionsList = new ArrayList<Criterion>();\r
- Criterion contextIdCrit = Restrictions.eq("context_id", contextId);\r
- restrictionsList.add(contextIdCrit);\r
- List<SharedContext> contexts = (List<SharedContext>) getDataAccessService().getList(SharedContext.class, null,\r
- restrictionsList, null);\r
-\r
- return contexts;\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalsdk.core.service.SharedContextService#\r
- * getSharedContext(java. lang.String, java.lang.String)\r
- */\r
- @Override\r
- public SharedContext getSharedContext(String contextId, String key) {\r
- SharedContext context = null;\r
- List<Criterion> restrictionsList = new ArrayList<Criterion>();\r
- Criterion contextIdCrit = Restrictions.eq("context_id", contextId);\r
- Criterion keyCrit = Restrictions.eq("ckey", key);\r
- restrictionsList.add(contextIdCrit);\r
- restrictionsList.add(keyCrit);\r
- @SuppressWarnings("unchecked")\r
- List<SharedContext> contexts = (List<SharedContext>) getDataAccessService().getList(SharedContext.class, null,\r
- restrictionsList, null);\r
- if (contexts != null && contexts.size() == 1)\r
- context = contexts.get(0);\r
-\r
- return context;\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalapp.portal.service.SharedContextService#\r
- * addSharedContext(java.lang.String, java.lang.String, java.lang.String)\r
- */\r
- @Override\r
- public void addSharedContext(String contextId, String key, String value) {\r
- SharedContext context = new SharedContext(contextId, key, value);\r
- saveSharedContext(context);\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalsdk.core.service.SharedContextService#\r
- * saveSharedContext(com. att.fusion.core.domain.SharedContext)\r
- */\r
- @Override\r
- public void saveSharedContext(SharedContext context) {\r
- getDataAccessService().saveDomainObject(context, null);\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalsdk.core.service.SharedContextService#\r
- * deleteSharedContext(com. att.fusion.core.domain.SharedContext)\r
- */\r
- @Override\r
- public void deleteSharedContext(SharedContext context) {\r
- getDataAccessService().deleteDomainObject(context, null);\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalapp.portal.service.SharedContextService#\r
- * deleteSharedContexts(java.lang.String)\r
- */\r
- @Override\r
- public int deleteSharedContexts(String contextId) {\r
- // Uses an inefficient method to avoid a where clause\r
- // that could be used to mount a SQL injection attack.\r
- List<SharedContext> contexts = getSharedContexts(contextId);\r
- if (contexts == null)\r
- return 0;\r
-\r
- logger.debug(EELFLoggerDelegate.debugLogger, "deleteSharedContexts: count is " + contexts.size());\r
- for (SharedContext sc : contexts)\r
- deleteSharedContext(sc);\r
-\r
- return contexts.size();\r
- }\r
-\r
- /*\r
- * (non-Javadoc)\r
- * \r
- * @see org.openecomp.portalapp.portal.service.SharedContextService#\r
- * expireSharedContexts(int)\r
- */\r
- @Override\r
- public void expireSharedContexts(int ageInSeconds) {\r
- // Specific to the MySQL database.\r
- // final String whereClause = " where create_time < ADDDATE(NOW(),\r
- // INTERVAL - " + ageInSeconds + " SECOND)";\r
- final SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");\r
- Date expiredDateTime = new Date(System.currentTimeMillis() - ageInSeconds * 1000);\r
- logger.debug(EELFLoggerDelegate.debugLogger,\r
- "expireSharedContexts: expire time is " + expiredDateTime.toString());\r
- final String whereClause = " create_time < '" + dateFormat.format(expiredDateTime) + "'";\r
- getDataAccessService().deleteDomainObjects(SharedContext.class, whereClause, null);\r
- }\r
-\r
- public DataAccessService getDataAccessService() {\r
- return dataAccessService;\r
- }\r
-\r
- public void setDataAccessService(DataAccessService dataAccessService) {\r
- this.dataAccessService = dataAccessService;\r
- }\r
-\r
-}\r
+/*-
+ * ================================================================================
+ * ECOMP Portal
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property
+ * ================================================================================
+ * Licensed 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.openecomp.portalapp.portal.service;
+
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+
+import org.hibernate.criterion.Criterion;
+import org.hibernate.criterion.Restrictions;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.EnableAspectJAutoProxy;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate;
+import org.openecomp.portalsdk.core.service.DataAccessService;
+import org.openecomp.portalapp.portal.domain.SharedContext;
+import org.openecomp.portalapp.portal.logging.aop.EPMetricsLog;
+
+/**
+ * Implementation of the shared-context service that talks to the database.
+ */
+@Service("sharedContextService")
+@Transactional
+@org.springframework.context.annotation.Configuration
+@EnableAspectJAutoProxy
+@EPMetricsLog
+public class SharedContextServiceImpl implements SharedContextService {
+
+ @Autowired
+ private DataAccessService dataAccessService;
+
+ private EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(SharedContextServiceImpl.class);
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalsdk.core.service.SharedContextService#
+ * getSharedContexts()
+ */
+ @Override
+ @SuppressWarnings("unchecked")
+ public List<SharedContext> getSharedContexts(String contextId) {
+ List<Criterion> restrictionsList = new ArrayList<Criterion>();
+ Criterion contextIdCrit = Restrictions.eq("context_id", contextId);
+ restrictionsList.add(contextIdCrit);
+ List<SharedContext> contexts = (List<SharedContext>) getDataAccessService().getList(SharedContext.class, null,
+ restrictionsList, null);
+
+ return contexts;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalsdk.core.service.SharedContextService#
+ * getSharedContext(java. lang.String, java.lang.String)
+ */
+ @Override
+ public SharedContext getSharedContext(String contextId, String key) {
+ SharedContext context = null;
+ List<Criterion> restrictionsList = new ArrayList<Criterion>();
+ Criterion contextIdCrit = Restrictions.eq("context_id", contextId);
+ Criterion keyCrit = Restrictions.eq("ckey", key);
+ restrictionsList.add(contextIdCrit);
+ restrictionsList.add(keyCrit);
+ @SuppressWarnings("unchecked")
+ List<SharedContext> contexts = (List<SharedContext>) getDataAccessService().getList(SharedContext.class, null,
+ restrictionsList, null);
+ if (contexts != null && contexts.size() == 1)
+ context = contexts.get(0);
+
+ return context;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalapp.portal.service.SharedContextService#
+ * addSharedContext(java.lang.String, java.lang.String, java.lang.String)
+ */
+ @Override
+ public void addSharedContext(String contextId, String key, String value) {
+ SharedContext context = new SharedContext(contextId, key, value);
+ saveSharedContext(context);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalsdk.core.service.SharedContextService#
+ * saveSharedContext(com. att.fusion.core.domain.SharedContext)
+ */
+ @Override
+ public void saveSharedContext(SharedContext context) {
+ getDataAccessService().saveDomainObject(context, null);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalsdk.core.service.SharedContextService#
+ * deleteSharedContext(com. att.fusion.core.domain.SharedContext)
+ */
+ @Override
+ public void deleteSharedContext(SharedContext context) {
+ getDataAccessService().deleteDomainObject(context, null);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalapp.portal.service.SharedContextService#
+ * deleteSharedContexts(java.lang.String)
+ */
+ @Override
+ public int deleteSharedContexts(String contextId) {
+ // Uses an inefficient method to avoid a where clause
+ // that could be used to mount a SQL injection attack.
+ List<SharedContext> contexts = getSharedContexts(contextId);
+ if (contexts == null)
+ return 0;
+
+ logger.debug(EELFLoggerDelegate.debugLogger, "deleteSharedContexts: count is " + contexts.size());
+ for (SharedContext sc : contexts)
+ deleteSharedContext(sc);
+
+ return contexts.size();
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.openecomp.portalapp.portal.service.SharedContextService#
+ * expireSharedContexts(int)
+ */
+ @Override
+ public void expireSharedContexts(int ageInSeconds) {
+ // Specific to the MySQL database.
+ // final String whereClause = " where create_time < ADDDATE(NOW(),
+ // INTERVAL - " + ageInSeconds + " SECOND)";
+ final SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+ Date expiredDateTime = new Date(System.currentTimeMillis() - ageInSeconds * 1000);
+ logger.debug(EELFLoggerDelegate.debugLogger,
+ "expireSharedContexts: expire time is " + expiredDateTime.toString());
+ final String whereClause = " create_time < '" + dateFormat.format(expiredDateTime) + "'";
+ getDataAccessService().deleteDomainObjects(SharedContext.class, whereClause, null);
+ }
+
+ public DataAccessService getDataAccessService() {
+ return dataAccessService;
+ }
+
+ public void setDataAccessService(DataAccessService dataAccessService) {
+ this.dataAccessService = dataAccessService;
+ }
+
+}