2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * Modifications Copyright (C) 2019 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.
19 * ============LICENSE_END=========================================================
22 package org.onap.dmaap.dbcapi.aaf;
24 import java.util.ArrayList;
26 import org.apache.log4j.Logger;
27 import org.onap.dmaap.dbcapi.util.DmaapConfig;
30 public class AafNamespace extends AafObject {
31 private static final Logger logger = Logger.getLogger(AafNamespace.class);
34 private ArrayList<String> admin;
35 private ArrayList<String> responsible;
37 // in some environments, an AAF Namespace must be owned by a human.
38 // So, when needed, this var can be set via a property
39 private static String NsOwnerIdentity;
41 public AafNamespace(String ns, String identity ) {
43 DmaapConfig p = (DmaapConfig)DmaapConfig.getConfig();
44 NsOwnerIdentity = p.getProperty( "aaf.NsOwnerIdentity", "");
45 this.admin = new ArrayList<>();
46 this.responsible = new ArrayList<>();
49 this.admin.add( identity );
50 this.responsible.add( NsOwnerIdentity );
52 public void setName( String ns ) {
55 public String getName() {
58 public ArrayList<String> getAdmin() {
61 public void setAdmin(ArrayList<String> admin) {
64 public ArrayList<String> getResponsible() {
67 public void setResponsible(ArrayList<String> responsible) {
68 this.responsible = responsible;
72 // given an Array of Strings, return a String that is a separated list of quoted strings.
73 // e.g. input [ a, b, c ]
74 // output "a", "b", "c"
75 private String separatedList( ArrayList<String> list, String sep ) {
76 if (list.isEmpty()) return null;
79 for( String item: list) {
80 if( ! item.isEmpty()) {
81 aList += String.format( "%s\"%s\"", delim, item );
88 public String toJSON() {
90 String postJSON = String.format(" { \"name\": \"%s\", \"admin\": [",
93 postJSON += separatedList( this.getAdmin(), "," );
94 postJSON += "], \"responsible\":[";
95 postJSON += separatedList( this.getResponsible(), ",");
97 logger.info( "returning JSON: " + postJSON);