/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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. */ package org.apache.nifi.controller.reporting; import org.apache.nifi.attribute.expression.language.PreparedQuery; import org.apache.nifi.attribute.expression.language.Query; import org.apache.nifi.attribute.expression.language.StandardPropertyValue; import org.apache.nifi.cluster.protocol.NodeIdentifier; import org.apache.nifi.components.PropertyDescriptor; import org.apache.nifi.components.PropertyValue; import org.apache.nifi.components.state.StateManager; import org.apache.nifi.connectable.Connectable; import org.apache.nifi.controller.ControllerService; import org.apache.nifi.controller.ControllerServiceLookup; import org.apache.nifi.controller.FlowController; import org.apache.nifi.controller.service.ControllerServiceProvider; import org.apache.nifi.events.BulletinFactory; import org.apache.nifi.groups.ProcessGroup; import org.apache.nifi.registry.VariableRegistry; import org.apache.nifi.reporting.Bulletin; import org.apache.nifi.reporting.BulletinRepository; import org.apache.nifi.reporting.EventAccess; import org.apache.nifi.reporting.ReportingContext; import org.apache.nifi.reporting.ReportingTask; import org.apache.nifi.reporting.Severity; import java.util.Collections; import java.util.HashMap; import java.util.Map; import java.util.Set; public class StandardReportingContext implements ReportingContext, ControllerServiceLookup { private final FlowController flowController; private final EventAccess eventAccess; private final ReportingTask reportingTask; private final BulletinRepository bulletinRepository; private final ControllerServiceProvider serviceProvider; private final Map<PropertyDescriptor, String> properties; private final Map<PropertyDescriptor, PreparedQuery> preparedQueries; private final VariableRegistry variableRegistry; public StandardReportingContext(final FlowController flowController, final BulletinRepository bulletinRepository, final Map<PropertyDescriptor, String> properties, final ControllerServiceProvider serviceProvider, final ReportingTask reportingTask, final VariableRegistry variableRegistry) { this.flowController = flowController; this.eventAccess = flowController; this.bulletinRepository = bulletinRepository; this.properties = Collections.unmodifiableMap(properties); this.serviceProvider = serviceProvider; this.reportingTask = reportingTask; this.variableRegistry = variableRegistry; preparedQueries = new HashMap<>(); for (final Map.Entry<PropertyDescriptor, String> entry : properties.entrySet()) { final PropertyDescriptor desc = entry.getKey(); String value = entry.getValue(); if (value == null) { value = desc.getDefaultValue(); } final PreparedQuery pq = Query.prepare(value); preparedQueries.put(desc, pq); } } @Override public EventAccess getEventAccess() { return eventAccess; } @Override public BulletinRepository getBulletinRepository() { return bulletinRepository; } @Override public Bulletin createBulletin(final String category, final Severity severity, final String message) { return BulletinFactory.createBulletin(category, severity.name(), message); } @Override public Bulletin createBulletin(final String componentId, final String category, final Severity severity, final String message) { final ProcessGroup rootGroup = flowController.getGroup(flowController.getRootGroupId()); final Connectable connectable = rootGroup.findLocalConnectable(componentId); if (connectable == null) { throw new IllegalStateException("Cannot create Component-Level Bulletin because no component can be found with ID " + componentId); } return BulletinFactory.createBulletin(connectable, category, severity.name(), message); } @Override public Map<PropertyDescriptor, String> getProperties() { return Collections.unmodifiableMap(properties); } @Override public PropertyValue getProperty(final PropertyDescriptor property) { final String configuredValue = properties.get(property); return new StandardPropertyValue(configuredValue == null ? property.getDefaultValue() : configuredValue, this, preparedQueries.get(property), variableRegistry); } @Override public ControllerService getControllerService(final String serviceIdentifier) { return serviceProvider.getControllerService(serviceIdentifier); } @Override public Set<String> getControllerServiceIdentifiers(final Class<? extends ControllerService> serviceType) { return serviceProvider.getControllerServiceIdentifiers(serviceType, null); } @Override public boolean isControllerServiceEnabled(final ControllerService service) { return serviceProvider.isControllerServiceEnabled(service); } @Override public boolean isControllerServiceEnabled(final String serviceIdentifier) { return serviceProvider.isControllerServiceEnabled(serviceIdentifier); } @Override public boolean isControllerServiceEnabling(final String serviceIdentifier) { return serviceProvider.isControllerServiceEnabling(serviceIdentifier); } @Override public ControllerServiceLookup getControllerServiceLookup() { return this; } @Override public String getControllerServiceName(final String serviceIdentifier) { return serviceProvider.getControllerServiceName(serviceIdentifier); } @Override public StateManager getStateManager() { return flowController.getStateManagerProvider().getStateManager(reportingTask.getIdentifier()); } @Override public boolean isClustered() { return flowController.isConfiguredForClustering(); } @Override public String getClusterNodeIdentifier() { final NodeIdentifier nodeId = flowController.getNodeId(); return nodeId == null ? null : nodeId.getId(); } }