Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Issue #435: Add the possibility to use the same connector with different connector variables #467

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
package org.sentrysoftware.metricshub.agent.config;

/*-
* ╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲
* MetricsHub Agent
* ჻჻჻჻჻჻
* Copyright 2023 - 2024 Sentry Software
* ჻჻჻჻჻჻
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* ╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱
*/

import static com.fasterxml.jackson.annotation.Nulls.SKIP;

import com.fasterxml.jackson.annotation.JsonSetter;
import java.util.HashMap;
import java.util.Map;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Builder.Default;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
* Configures additional connectors with variables, the connector ID to use, and a force flag.
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class AdditionalConnector {

/**
* The connector Id of the additional connector instance.
*/
private String uses;

/**
* A map representing the variables for the additional connector.
* The keys are the names of the variables, and the values are the values assigned to those variables.
*/
@Default
@JsonSetter(nulls = SKIP)
private Map<String, String> variables = new HashMap<>();

/**
* A flag indicating whether this connector is forced.
*/
@Default
@JsonSetter(nulls = SKIP)
private boolean force = true;

/**
* Setter that removes variables with null values.
*
* @param variables Map of variables to set.
*/
@JsonSetter
public void setVariables(Map<String, String> variables) {
this.variables = variables;
if (variables != null) {
variables.entrySet().removeIf(entry -> entry.getValue() == null);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,11 @@
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonSetter;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.TreeMap;
import java.util.stream.Collectors;
Expand All @@ -38,7 +40,6 @@
import lombok.Data;
import lombok.NoArgsConstructor;
import org.sentrysoftware.metricshub.agent.deserialization.AttributesDeserializer;
import org.sentrysoftware.metricshub.agent.deserialization.ConnectorVariablesDeserializer;
import org.sentrysoftware.metricshub.agent.deserialization.ExtensionProtocolsDeserializer;
import org.sentrysoftware.metricshub.agent.deserialization.MonitorJobsDeserializer;
import org.sentrysoftware.metricshub.engine.configuration.ConnectorVariables;
Expand Down Expand Up @@ -92,11 +93,6 @@ public class ResourceConfig {
@JsonDeserialize(using = ExtensionProtocolsDeserializer.class)
private Map<String, IConfiguration> protocols = new HashMap<>();

@Default
@JsonSetter(nulls = SKIP)
@JsonDeserialize(using = ConnectorVariablesDeserializer.class)
private Map<String, ConnectorVariables> variables = new TreeMap<>(String.CASE_INSENSITIVE_ORDER);

@Default
@JsonSetter(nulls = SKIP)
private Set<String> connectors = new HashSet<>();
Expand All @@ -106,6 +102,10 @@ public class ResourceConfig {
@Default
private Map<String, MonitorJob> monitors = new HashMap<>();

@Default
@JsonSetter(nulls = SKIP)
private Map<String, AdditionalConnector> additionalConnectors = new TreeMap<>(String.CASE_INSENSITIVE_ORDER);

@JsonIgnore
private Connector connector;

Expand Down Expand Up @@ -142,10 +142,32 @@ public ResourceConfig copy() {
.protocols(
protocols.entrySet().stream().collect(Collectors.toMap(Map.Entry::getKey, entry -> entry.getValue().copy()))
)
.variables(variables)
.additionalConnectors(additionalConnectors)
.connectors(connectors)
.connector(connector)
.stateSetCompression(stateSetCompression)
.build();
}

/**
* Retrieves the set of connector variables where map keys are connectorIds and values are connectorVariables.
* @return the map of connectorIds and their variables values.
*/
public Map<String, ConnectorVariables> getConnectorVariables() {
return Optional
.ofNullable(additionalConnectors)
.map(map ->
map
.entrySet()
.stream()
.filter(entry -> entry.getValue() != null && entry.getValue().getVariables() != null) // Filter out null values
.collect(
Collectors.toMap(
Map.Entry::getKey,
entry -> new ConnectorVariables(new HashMap<>(entry.getValue().getVariables())) // Create new object with copied map
)
)
)
.orElseGet(Collections::emptyMap); // Return an empty map if additionalConnectors is null
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package org.sentrysoftware.metricshub.agent.connector;

/*-
* ╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲
* MetricsHub Agent
* ჻჻჻჻჻჻
* Copyright 2023 - 2024 Sentry Software
* ჻჻჻჻჻჻
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* ╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱
*/

import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.sentrysoftware.metricshub.engine.connector.model.Connector;

/**
* Represents the result of parsing additional connectors, containing a map of connectors
* and a set of forced connector IDs.
*/
@Builder
@Data
@NoArgsConstructor
public class AdditionalConnectorsParsingResult {

/**
* The map containing the parsed additional custom connectors.
*/
final Map<String, Connector> customConnectorsMap = new TreeMap<>(String.CASE_INSENSITIVE_ORDER);

/**
* A set of connector IDs to add into the host connectors set.
*/
final Set<String> hostConnectors = new HashSet<>();
}
Loading