2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (c) 2017 AT&T Intellectual Property
6 * Modifications Copyright (C) 2018 IBM.
7 * ===================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
20 * ============LICENSE_END=============================================
21 * ====================================================================
24 package org.onap.music.datastore.jsonobjects;
26 import java.io.ByteArrayOutputStream;
27 import java.io.IOException;
28 import java.io.ObjectOutput;
29 import java.io.ObjectOutputStream;
30 import java.io.Serializable;
33 import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
35 import io.swagger.annotations.ApiModel;
36 import io.swagger.annotations.ApiModelProperty;
38 import org.onap.music.eelf.logging.EELFLoggerDelegate;
39 import org.onap.music.eelf.logging.format.AppMessages;
40 import org.onap.music.eelf.logging.format.ErrorSeverity;
41 import org.onap.music.eelf.logging.format.ErrorTypes;
43 @ApiModel(value = "JsonTable", description = "Json model for table vlaues insert")
44 @JsonIgnoreProperties(ignoreUnknown = true)
45 public class JsonInsert implements Serializable {
46 private String keyspaceName;
47 private String tableName;
48 private transient Map<String, Object> values;
50 private String timestamp;
51 private transient Map<String, Object> rowSpecification;
52 private Map<String, String> consistencyInfo;
53 private Map<String, byte[]> objectMap;
54 private static EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(JsonInsert.class);
56 @ApiModelProperty(value = "objectMap")
57 public Map<String, byte[]> getObjectMap() {
61 public void setObjectMap(Map<String, byte[]> objectMap) {
62 this.objectMap = objectMap;
65 @ApiModelProperty(value = "keyspace")
66 public String getKeyspaceName() {
70 public void setKeyspaceName(String keyspaceName) {
71 this.keyspaceName = keyspaceName;
74 @ApiModelProperty(value = "Table name")
75 public String getTableName() {
79 public void setTableName(String tableName) {
80 this.tableName = tableName;
83 @ApiModelProperty(value = "Consistency level", allowableValues = "eventual,critical,atomic")
84 public Map<String, String> getConsistencyInfo() {
85 return consistencyInfo;
88 public void setConsistencyInfo(Map<String, String> consistencyInfo) {
89 this.consistencyInfo = consistencyInfo;
92 @ApiModelProperty(value = "Time to live information")
93 public String getTtl() {
97 public void setTtl(String ttl) {
101 @ApiModelProperty(value = "Time stamp")
102 public String getTimestamp() {
106 public void setTimestamp(String timestamp) {
107 this.timestamp = timestamp;
110 @ApiModelProperty(value = "values returned")
111 public Map<String, Object> getValues() {
115 public void setValues(Map<String, Object> values) {
116 this.values = values;
119 @ApiModelProperty(value = "Information for selecting specific rows for insert")
120 public Map<String, Object> getRow_specification() {
121 return rowSpecification;
124 public void setRow_specification(Map<String, Object> rowSpecification) {
125 this.rowSpecification = rowSpecification;
128 public byte[] serialize() {
129 ByteArrayOutputStream bos = new ByteArrayOutputStream();
130 ObjectOutput out = null;
132 out = new ObjectOutputStream(bos);
133 out.writeObject(this);
134 } catch (IOException e) {
135 logger.error(EELFLoggerDelegate.errorLogger, e, AppMessages.IOERROR, ErrorSeverity.ERROR, ErrorTypes.DATAERROR);
137 return bos.toByteArray();