2 * Copyright (c) 2010-2023 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
7 * This program and the accompanying materials are made available under the
8 * terms of the Eclipse Public License 2.0 which is available at
9 * http://www.eclipse.org/legal/epl-2.0
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.pulseaudio.internal.handler;
15 import java.util.ArrayList;
16 import java.util.Arrays;
17 import java.util.List;
18 import java.util.regex.Pattern;
19 import java.util.regex.PatternSyntaxException;
20 import java.util.stream.Collectors;
22 import org.eclipse.jdt.annotation.NonNullByDefault;
23 import org.eclipse.jdt.annotation.Nullable;
26 * All informations needed to precisely identify a device
28 * @author Gwendal Roulleau - Initial contribution
32 public class DeviceIdentifier {
34 private String nameOrDescription;
35 private List<Pattern> additionalFilters = new ArrayList<>();
37 public DeviceIdentifier(String nameOrDescription, @Nullable String additionalFilters)
38 throws PatternSyntaxException {
40 this.nameOrDescription = nameOrDescription;
41 if (additionalFilters != null && !additionalFilters.isEmpty()) {
42 Arrays.asList(additionalFilters.split("###")).stream()
43 .forEach(ad -> this.additionalFilters.add(Pattern.compile(ad)));
47 public String getNameOrDescription() {
48 return nameOrDescription;
51 public List<Pattern> getAdditionalFilters() {
52 return additionalFilters;
56 public String toString() {
57 List<Pattern> additionalFiltersFinal = additionalFilters;
58 String additionalPatternToString = additionalFiltersFinal.stream().map(Pattern::pattern)
59 .collect(Collectors.joining("###"));
60 return "DeviceIdentifier [nameOrDescription=" + nameOrDescription + ", additionalFilter="
61 + additionalPatternToString + "]";