/** * Copyright 2017 ZTE Corporation. *

* 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.onap.holmes.engine.db; import org.onap.holmes.common.api.entity.AlarmInfo; import org.onap.holmes.common.exception.AlarmInfoException; import org.onap.holmes.common.utils.AlarmInfoMapper; import org.skife.jdbi.v2.sqlobject.*; import org.skife.jdbi.v2.sqlobject.customizers.RegisterMapper; import java.util.List; @RegisterMapper(AlarmInfoMapper.class) public abstract class AlarmInfoDao { @GetGeneratedKeys @SqlUpdate("INSERT INTO ALARM_INFO (EVENTID,EVENTNAME,STARTEPOCHMICROSEC,SOURCEID,SOURCENAME,ALARMISCLEARED,ROOTFLAG,LASTEPOCHMICROSEC) VALUES (:eventId,:eventName,:startEpochMicroSec,:sourceId,:sourceName,:alarmIsCleared,:rootFlag,:lastEpochMicroSec)") protected abstract String addAlarm(@BindBean AlarmInfo alarmInfo); @SqlQuery("SELECT * FROM ALARM_INFO") protected abstract List queryAlarm(); @SqlUpdate("DELETE FROM ALARM_INFO WHERE EVENTNAME=:eventName AND SOURCEID=:sourceId AND SOURCENAME=:sourceName") protected abstract int deleteAlarmByAlarmIsCleared(@Bind("eventName") String eventName, @Bind("sourceId") String sourceId, @Bind("sourceName") String sourceName); public AlarmInfo saveAlarm(AlarmInfo alarmInfo) throws AlarmInfoException { try { addAlarm(alarmInfo); return alarmInfo; } catch (Exception e) { throw new AlarmInfoException("Can not access the database. Please contact the administrator for help.", e); } } public List queryAllAlarm() throws AlarmInfoException { try { return queryAlarm(); } catch (Exception e) { throw new AlarmInfoException("Can not access the database. Please contact the administrator for help.", e); } } public void deleteAlarm(AlarmInfo alarmInfo) { if (alarmInfo.getAlarmIsCleared() != 1) { return; } String sourceId = alarmInfo.getSourceId(); String sourceName = alarmInfo.getSourceName(); String eventName = alarmInfo.getEventName(); eventName = eventName.substring(0, eventName.lastIndexOf("Cleared")); deleteAlarmByAlarmIsCleared(eventName, sourceId, sourceName); } }