3e9862126a54a276daf91d1ac1c62e2b170677a0
[aai/search-data-service.git] / src / main / java / org / openecomp / sa / searchdbabstraction / searchapi / Sort.java
1 /**
2  * ============LICENSE_START=======================================================
3  * org.onap.aai
4  * ================================================================================
5  * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6  * Copyright © 2017 Amdocs
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
11  *
12  *       http://www.apache.org/licenses/LICENSE-2.0
13  *
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=========================================================
20  *
21  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
22  */
23 package org.openecomp.sa.searchdbabstraction.searchapi;
24
25 public class Sort {
26
27   private String field;
28   private SortDirection order = null;
29
30   public enum SortDirection {
31     ascending,
32     descending
33   }
34
35   public String getField() {
36     return field;
37   }
38
39   public void setField(String field) {
40     this.field = field;
41   }
42
43   public SortDirection getOrder() {
44     return order;
45   }
46
47   public void setOrder(SortDirection order) {
48     this.order = order;
49   }
50
51   public String toElasticSearch() {
52
53     StringBuilder sb = new StringBuilder();
54
55     sb.append("{ \"").append(field).append("\": { \"order\": ");
56
57     // If a sort order wasn't explicitly supplied, default to 'ascending'.
58     if (order != null) {
59       switch (order) {
60         case ascending:
61           sb.append("\"asc\"}}");
62           break;
63         case descending:
64           sb.append("\"desc\"}}");
65           break;
66         default:
67       }
68     } else {
69       sb.append("\"asc\"}}");
70     }
71
72     return sb.toString();
73   }
74 }