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