001/*
002 * Copyright 2012-2018 the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *      http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017package org.springframework.boot.actuate.autoconfigure.metrics.export.newrelic;
018
019import io.micrometer.core.instrument.Clock;
020import io.micrometer.core.ipc.http.HttpUrlConnectionSender;
021import io.micrometer.newrelic.NewRelicConfig;
022import io.micrometer.newrelic.NewRelicMeterRegistry;
023
024import org.springframework.boot.actuate.autoconfigure.metrics.CompositeMeterRegistryAutoConfiguration;
025import org.springframework.boot.actuate.autoconfigure.metrics.MetricsAutoConfiguration;
026import org.springframework.boot.actuate.autoconfigure.metrics.export.simple.SimpleMetricsExportAutoConfiguration;
027import org.springframework.boot.autoconfigure.AutoConfigureAfter;
028import org.springframework.boot.autoconfigure.AutoConfigureBefore;
029import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
030import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
031import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
032import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
033import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
034import org.springframework.boot.context.properties.EnableConfigurationProperties;
035import org.springframework.context.annotation.Bean;
036import org.springframework.context.annotation.Configuration;
037
038/**
039 * {@link EnableAutoConfiguration Auto-configuration} for exporting metrics to New Relic.
040 *
041 * @author Jon Schneider
042 * @author Andy Wilkinson
043 * @author Artsiom Yudovin
044 * @since 2.0.0
045 */
046@Configuration
047@AutoConfigureBefore({ CompositeMeterRegistryAutoConfiguration.class,
048                SimpleMetricsExportAutoConfiguration.class })
049@AutoConfigureAfter(MetricsAutoConfiguration.class)
050@ConditionalOnBean(Clock.class)
051@ConditionalOnClass(NewRelicMeterRegistry.class)
052@ConditionalOnProperty(prefix = "management.metrics.export.newrelic", name = "enabled", havingValue = "true", matchIfMissing = true)
053@EnableConfigurationProperties(NewRelicProperties.class)
054public class NewRelicMetricsExportAutoConfiguration {
055
056        private final NewRelicProperties properties;
057
058        public NewRelicMetricsExportAutoConfiguration(NewRelicProperties properties) {
059                this.properties = properties;
060        }
061
062        @Bean
063        @ConditionalOnMissingBean
064        public NewRelicConfig newRelicConfig() {
065                return new NewRelicPropertiesConfigAdapter(this.properties);
066        }
067
068        @Bean
069        @ConditionalOnMissingBean
070        public NewRelicMeterRegistry newRelicMeterRegistry(NewRelicConfig newRelicConfig,
071                        Clock clock) {
072                return NewRelicMeterRegistry.builder(newRelicConfig).clock(clock)
073                                .httpClient(
074                                                new HttpUrlConnectionSender(this.properties.getConnectTimeout(),
075                                                                this.properties.getReadTimeout()))
076                                .build();
077
078        }
079
080}