summaryrefslogtreecommitdiffstats
path: root/common/src/main/java/org/onap/so/client/graphinventory/entities/DSLQueryBuilder.java
blob: 73dccea8e6fe804c1a5cf72e298c8bf0540d69fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*-
 * ============LICENSE_START=======================================================
 * ONAP - SO
 * ================================================================================
 * Copyright (C) 2017 - 2019 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.so.client.graphinventory.entities;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

import org.onap.so.client.aai.entities.QueryStep;

import com.google.common.base.Joiner;


public class DSLQueryBuilder<S, E> implements QueryStep {

	private List<QueryStep> steps = new ArrayList<>();
	
	
	public DSLQueryBuilder() {
		
	}
	public DSLQueryBuilder(DSLNode node) {
		steps.add(node);
	}
	
	public DSLQueryBuilder<S, DSLNode> node(DSLNode node) {
		steps.add(node);
		
		return (DSLQueryBuilder<S, DSLNode>) this;
	}
	public DSLQueryBuilder<S, E> output() {
		if (steps.get(steps.size() -1) instanceof DSLNode) {
			((DSLNode)steps.get(steps.size() -1)).output();
		}
		return this;
	}
	
	public <E2> DSLQueryBuilder<S, E2> union(final DSLQueryBuilder<?, E2>... union) {
		
		List<DSLQueryBuilder<?, ?>> unions = Arrays.asList(union);
		steps.add(() -> {
			StringBuilder query = new StringBuilder();
		
			query.append("> [ ").append(
					Joiner.on(", ").join(
						unions.stream().map(item -> item.build()).collect(Collectors.toList())))
					.append(" ]");
			return query.toString();
		});
		
		return (DSLQueryBuilder<S, E2>) this;
	}
	
	public DSLQueryBuilder<S, E> where(DSLQueryBuilder<?, ?> where) {

		steps.add(() -> {
			StringBuilder query = new StringBuilder();
			query.append(where.build()).append(")");
			String result = query.toString();
			if (!result.startsWith(">")) {
				result = "> " + result;
			}
			return "(" + result;
		});
		return this;
	}
	
	public DSLQueryBuilder<S, E> to(DSLQueryBuilder<?, ?> to) {
		steps.add(() -> {
			StringBuilder query = new StringBuilder();
			
			query.append("> ").append(to.build());
			return query.toString();
		});
		return this;
	}
	
	public String limit(int limit) {
		return compile() + " LIMIT " + limit;
	}
	
	@Override
	public String build() {
		return compile();
	}
	
	private String compile() {
		return Joiner.on(" ").join(steps.stream().map(item -> item.build()).collect(Collectors.toList()));
	}
	
	protected QueryStep getFirst() {
		return steps.get(0);
	}
}