summaryrefslogtreecommitdiffstats
path: root/mso-catalog-db/src/main/java/org/onap/so/db/catalog/utils/MavenLikeVersioning.java
blob: a7610fec92546d16c41e2f0ccd952c7a2d2a12eb (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
114
/*-
 * ============LICENSE_START=======================================================
 * ONAP - SO
 * ================================================================================
 * Copyright (C) 2017 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.db.catalog.utils;


import java.io.Serializable;

/**
 * This class is the base class for object that requires a Version in Catalog DB. The version is built on a string as
 * ASDC provides a number like 1.2 or 2.0 ... This class supports also 1.2.3.4... (Maven like version)
 *
 *
 */
public class MavenLikeVersioning implements Serializable {

    protected String version;

    public String getVersion() {
        return version;
    }

    public void setVersion(String version) {
        this.version = version;
    }

    /**
     * This method is used to compare the current object version to a specified one It is assumed that the version is
     * like the maven one, eg: 2.0.1.5.6
     *
     * @param versionToCompare The version that will be used for comparison
     * @return True if the current object is more recent than the specified version, False otherwise
     *
     */
    public boolean isMoreRecentThan(String versionToCompare) {
        if (versionToCompare == null || versionToCompare.trim().isEmpty() || this.version == null
                || this.version.trim().isEmpty()) {
            return false;
        }
        String[] currentVersionArray = this.version.split("\\.");
        String[] specifiedVersionArray = versionToCompare.split("\\.");

        int smalestStringLength = Math.min(currentVersionArray.length, specifiedVersionArray.length);

        for (int currentVersionIndex = 0; currentVersionIndex < smalestStringLength; ++currentVersionIndex) {

            if (Integer.parseInt(currentVersionArray[currentVersionIndex]) < Integer
                    .parseInt(specifiedVersionArray[currentVersionIndex])) {
                return false;
            } else if (Integer.parseInt(currentVersionArray[currentVersionIndex]) > Integer
                    .parseInt(specifiedVersionArray[currentVersionIndex])) {
                return true;
            }
        }
        try {
            // Even if versionToCompare has more digits, it means versionToCompare is more recent
            return Integer.parseInt(currentVersionArray[smalestStringLength - 1]) != Integer
                    .parseInt(specifiedVersionArray[smalestStringLength - 1])
                    || currentVersionArray.length > specifiedVersionArray.length;
        } catch (NumberFormatException e) {
            return false;
        }
    }

    /**
     * This method is used to compare the current object version to a specified one It is assumed that the version is
     * like the maven one, eg: 2.0.1.5.6
     *
     * @param versionToCompare The version that will be used for comparison
     * @return True if the current object is equal to the specified version, False otherwise
     *
     */
    public boolean isTheSameVersion(String versionToCompare) {
        if (versionToCompare == null && this.version == null) {
            return true;
        } else if (versionToCompare == null || versionToCompare.trim().equals("") || this.version == null
                || this.version.trim().equals("")) {
            return false;
        }
        String[] currentVersionArray = this.version.split("\\.");
        String[] specifiedVersionArray = versionToCompare.split("\\.");

        if (currentVersionArray.length != specifiedVersionArray.length) {
            return false;
        }

        for (int currentVersionIndex = 0; currentVersionIndex < currentVersionArray.length; ++currentVersionIndex) {

            if (Integer.parseInt(currentVersionArray[currentVersionIndex]) != Integer
                    .parseInt(specifiedVersionArray[currentVersionIndex])) {
                return false;
            }
        }

        return true;
    }
}