2 * Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
4 * Licensed under the Apache License, Version 2.0 (the "License"); you may
5 * not use this file except in compliance with the License. You may obtain
6 * a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
13 * implied. See the License for the specific language governing
14 * permissions and limitations under the License.
16 package org.akraino.validation.ui.daoimpl;
18 import java.util.List;
20 import org.akraino.validation.ui.dao.SiloDAO;
21 import org.akraino.validation.ui.entity.LabSilo;
22 import org.hibernate.Criteria;
23 import org.hibernate.Session;
24 import org.hibernate.SessionFactory;
25 import org.hibernate.criterion.Restrictions;
26 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
27 import org.springframework.beans.factory.annotation.Autowired;
28 import org.springframework.stereotype.Repository;
31 public class SiloDAOImpl implements SiloDAO {
33 private static final EELFLoggerDelegate LOGGER = EELFLoggerDelegate.getLogger(SiloDAOImpl.class);
36 private SessionFactory sessionFactory;
38 protected Session getSession() {
39 return sessionFactory.getCurrentSession();
43 public List<LabSilo> getSilos() {
44 Criteria criteria = getSession().createCriteria(LabSilo.class);
45 return criteria.list();
49 public LabSilo getSilo(Integer siloId) {
50 Criteria criteria = getSession().createCriteria(LabSilo.class);
51 criteria.add(Restrictions.eq("id", String.valueOf(siloId)));
52 return criteria.list() == null ? null : (LabSilo) criteria.list().get(0);
56 public void saveOrUpdate(LabSilo silo) {
57 getSession().saveOrUpdate(silo);
61 public void merge(LabSilo silo) {
62 getSession().merge(silo);
66 public void deleteSilo(LabSilo silo) {
67 getSession().delete(silo);
71 public void deleteAll() {
72 if (getSession().createQuery("delete from Silo").executeUpdate() > 0) {
73 LOGGER.info(EELFLoggerDelegate.applicationLogger, "All silo entries are cleaned up");