aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/org/onap/pnfsimulator/simulator/keywords/Keyword.java
blob: 1bb1332e828b37f3048f033449e4492e9f2652f1 (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
/*
 * ============LICENSE_START=======================================================
 * PNF-REGISTRATION-HANDLER
 * ================================================================================
 * Copyright (C) 2018 Nokia. 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.pnfsimulator.simulator.keywords;

import io.vavr.Function1;
import io.vavr.Function2;

import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.stream.Collectors;

import lombok.Getter;

@Getter
public class Keyword {

    protected static final String LETTERS_REGEX = "([a-zA-Z]+)";
    protected static final String NONLETTERS_REGEX = "([^a-zA-Z]+)";

    protected static final Function1<String, String> OPTIONAL =
        regex -> regex + "?";

    private final String name;
    private final List<String> meaningfulParts;

    public static final Function2<Keyword, String, Boolean> IS_MATCHING_KEYWORD_NAME = (keyword, key) ->
        keyword != null && keyword.getName() != null && keyword.getName().equals(key);

    /**
     * Returns list of independent parts inside the keyword. Current implementation assumes that customer can join keywords with integer values, so
     * keyword is decomposed to parts then some parts of the keyword is skipped because of replacement process.
     *
     * @param matcher    - Matcher to check find independent groups inside the keyword
     * @param skipGroups Informs this method about which groups should be consider as part of the replacement process
     * @return list of independent parts inside the keywords
     */
    static List<String> extractPartsFrom(Matcher matcher, List<Integer> skipGroups) {
        List<String> parts = new ArrayList<>();
        for (int i = 1; i <= matcher.groupCount(); i++) {
            if (matcher.group(i) != null && !skipGroups.contains(i)) {
                parts.add(matcher.group(i));
            }
        }
        return parts;
    }

    Keyword(String name, List<String> meaningfulParts) {
        this.name = name;
        this.meaningfulParts = meaningfulParts;
    }

    public String substituteKeyword(String substitution) {
        return meaningfulParts.stream()
            .map(part -> part.equals(name) ? substitution : part)
            .collect(Collectors.joining());
    }

}