X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Forg%2Fonap%2Fdmaap%2Fdbcapi%2Fdatabase%2FDatabaseClass.java;fp=src%2Fmain%2Fjava%2Forg%2Fonap%2Fdmaap%2Fdbcapi%2Fdatabase%2FDatabaseClass.java;h=9b7c8ffc018ba385ad586fd08979c3ca489d307f;hb=0bff051a842b164b680bc938f4a56db435dd5841;hp=0000000000000000000000000000000000000000;hpb=89e6d8f0b87a84b2de6cdab641b28692b9cf3be1;p=dmaap%2Fdbcapi.git diff --git a/src/main/java/org/onap/dmaap/dbcapi/database/DatabaseClass.java b/src/main/java/org/onap/dmaap/dbcapi/database/DatabaseClass.java new file mode 100644 index 0000000..9b7c8ff --- /dev/null +++ b/src/main/java/org/onap/dmaap/dbcapi/database/DatabaseClass.java @@ -0,0 +1,270 @@ +/*- + * ============LICENSE_START======================================================= + * org.onap.dmaap + * ================================================================================ + * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved. + * ================================================================================ + * 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. + * ============LICENSE_END========================================================= + */ + +package org.onap.dmaap.dbcapi.database; + +import java.util.*; +import java.sql.*; + +import org.onap.dmaap.dbcapi.logging.BaseLoggingClass; +import org.onap.dmaap.dbcapi.logging.DmaapbcLogMessageEnum; +import org.onap.dmaap.dbcapi.model.*; +import org.onap.dmaap.dbcapi.util.DmaapConfig; +import org.onap.dmaap.dbcapi.util.Singleton; + + + + +public class DatabaseClass extends BaseLoggingClass { + + private static Singleton dmaap; + private static Map dcaeLocations; + private static Map dr_nodes; + private static Map dr_pubs; + private static Map dr_subs; + private static Map mr_clients; + private static Map mr_clusters; + private static Map feeds; + private static Map topics; + private static Map mirrors; + + private static long lastTime = 0L; + + private static class MirrorVectorHandler implements DBFieldHandler.SqlOp { + public Object get(ResultSet rs, int index) throws Exception { + String val = rs.getString(index); + if (val == null) { + return(null); + } + Set rv = new HashSet(); + for (String s: val.split(",")) { + String[] f = s.split(";"); + if (f.length < 3) { + continue; + } + rv.add(new ReplicationVector(DBFieldHandler.funesc(f[0]), DBFieldHandler.funesc(f[1]), DBFieldHandler.funesc(f[2]))); + } + return(rv); + } + public void set(PreparedStatement ps, int index, Object val) throws Exception { + if (val == null) { + ps.setString(index, null); + return; + } + Set xv = (Set)val; + StringBuffer sb = new StringBuffer(); + String sep = ""; + for (Object o: xv) { + ReplicationVector rv = (ReplicationVector)o; + sb.append(sep).append(DBFieldHandler.fesc(rv.getFqtn())).append(';').append(DBFieldHandler.fesc(rv.getSourceCluster())).append(';').append(DBFieldHandler.fesc(rv.getTargetCluster())); + sep = ","; + } + ps.setString(index, sb.toString()); + } + } + + // modified version of MirrorVectorHandler for Topics + private static class MirrorTopicsHandler implements DBFieldHandler.SqlOp { + public Object get(ResultSet rs, int index) throws Exception { + String val = rs.getString(index); + if (val == null) { + return(null); + } + List rv = new ArrayList(); + for (String s: val.split(",")) { + //String[] f = s.split(";"); + //if (f.length < 3) { + // continue; + //} + rv.add(new String(s)); + } + return(rv); + } + public void set(PreparedStatement ps, int index, Object val) throws Exception { + if (val == null) { + ps.setString(index, null); + return; + } + @SuppressWarnings("unchecked") + List xv = (List)val; + StringBuffer sb = new StringBuffer(); + String sep = ""; + for (Object o: xv) { + String rv = (String)o; + sb.append(sep).append(DBFieldHandler.fesc(rv)); + sep = ","; + } + ps.setString(index, sb.toString()); + } + } + private static class TopicReplicationTypeHandler implements DBFieldHandler.SqlOp { + public Object get(ResultSet rs, int index) throws Exception { + int val = rs.getInt(index); + + return (ReplicationType.valueOf(val)); + } + public void set(PreparedStatement ps, int index, Object val) throws Exception { + if (val == null) { + ps.setInt(index, 0); + return; + } + @SuppressWarnings("unchecked") + ReplicationType rep = (ReplicationType) val; + ps.setInt(index, rep.getValue()); + } + } + public static Singleton getDmaap() { + return dmaap; + } + + + + public static Map getDcaeLocations() { + return dcaeLocations; + } + + public static Map getDr_nodes() { + return dr_nodes; + } + + public static Map getDr_subs() { + return dr_subs; + } + public static Map getDr_pubs() { + return dr_pubs; + } + + public static Map getMr_clients() { + return mr_clients; + } + + + public static Map getMr_clusters() { + return mr_clusters; + } + + public static Map getFeeds() { + return feeds; + } + public static Map getTopics() { + return topics; + } + public static Map getMirrorMakers() { + return mirrors; + } + + static { + try { + appLogger.info( "begin static initialization"); + appLogger.info( "initializing dmaap" ); + DmaapConfig p = (DmaapConfig)DmaapConfig.getConfig(); + if ("true".equalsIgnoreCase(p.getProperty("UsePGSQL", "false"))) { + appLogger.info("Data from database"); + try { + LoadSchema.upgrade(); + } catch (Exception e) { + appLogger.warn("Problem updating DB schema", e); + } + try { + dmaap = new DBSingleton(Dmaap.class, "dmaap"); + dcaeLocations = new DBMap(DcaeLocation.class, "dcae_location", "dcae_location_name"); + dr_nodes = new DBMap(DR_Node.class, "dr_node", "fqdn"); + dr_pubs = new DBMap(DR_Pub.class, "dr_pub", "pub_id"); + dr_subs = new DBMap(DR_Sub.class, "dr_sub", "sub_id"); + mr_clients = new DBMap(MR_Client.class, "mr_client", "mr_client_id"); + mr_clusters = new DBMap(MR_Cluster.class, "mr_cluster", "dcae_location_name"); + feeds = new DBMap(Feed.class, "feed", "feed_id"); + TableHandler.setSpecialCase("topic", "replication_case", new TopicReplicationTypeHandler()); + topics = new DBMap(Topic.class, "topic", "fqtn"); + //TableHandler.setSpecialCase("mirror_maker", "vectors", new MirrorVectorHandler()); + TableHandler.setSpecialCase("mirror_maker", "topics", new MirrorTopicsHandler()); + mirrors = new DBMap(MirrorMaker.class, "mirror_maker", "mm_name"); + } catch (Exception e) { + errorLogger.error("Error initializing database access " + e, e); + System.exit(1); + } + } else { + appLogger.info("Data from memory"); + dmaap = new Singleton() { + private Dmaap dmaap; + public void remove() { + dmaap = null; + } + public void init(Dmaap val) { + if (dmaap == null) { + dmaap = val; + } + } + public Dmaap get() { + return(dmaap); + } + public void update(Dmaap nd) { + dmaap.setVersion(nd.getVersion()); + dmaap.setTopicNsRoot(nd.getTopicNsRoot()); + dmaap.setDmaapName(nd.getDmaapName()); + dmaap.setDrProvUrl(nd.getDrProvUrl()); + dmaap.setBridgeAdminTopic(nd.getBridgeAdminTopic()); + dmaap.setLoggingUrl(nd.getLoggingUrl()); + dmaap.setNodeKey(nd.getNodeKey()); + dmaap.setAccessKeyOwner(nd.getAccessKeyOwner()); + } + }; + dcaeLocations = new HashMap(); + dr_nodes = new HashMap(); + dr_pubs = new HashMap(); + dr_subs = new HashMap(); + mr_clients = new HashMap(); + mr_clusters = new HashMap(); + feeds = new HashMap(); + topics = new HashMap(); + mirrors = new HashMap(); + } + dmaap.init(new Dmaap("0", "", "", "", "", "", "", "")); + // check for, and set up initial data, if it isn't already there + Dmaap dmx = dmaap.get(); + if ("0".equals(dmx.getVersion())) { + + dmx = new Dmaap("0", "", "", "", "", "", "", ""); + dmx.setDmaapName(p.getProperty("DmaapName")); + dmx.setDrProvUrl("https://" + p.getProperty("DR.provhost", "notSet")); + dmx.setTopicNsRoot(p.getProperty("topicNsRoot")); + dmx.setBridgeAdminTopic("DCAE_MM_AGENT"); + + dmaap.update(dmx); + } + } catch (Exception e) { + errorLogger.error(DmaapbcLogMessageEnum.DB_UPDATE_ERROR, e.getMessage()); + } + } + + public synchronized static String getNextClientId() { + + long id = System.currentTimeMillis(); + if ( id <= lastTime ) { + id = lastTime + 1; + } + lastTime = id; + return Long.toString(id); + } + + + + +}