/* * Copyright (c) 2014 Hewlett-Packard Development Company, L.P. * * 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. */ package monasca.api.resource; import static monasca.api.app.validation.Validation.DEFAULT_ADMIN_ROLE; import com.google.common.base.Splitter; import com.google.common.base.Strings; import com.codahale.metrics.annotation.Timed; import org.joda.time.DateTime; import java.util.List; import java.util.Map; import javax.inject.Inject; import javax.ws.rs.DefaultValue; import javax.ws.rs.GET; import javax.ws.rs.HeaderParam; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.core.Context; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.UriInfo; import monasca.api.app.validation.MetricNameValidation; import monasca.api.ApiConfig; import monasca.api.app.validation.Validation; import monasca.api.domain.model.statistic.StatisticRepo; import monasca.api.infrastructure.persistence.PersistUtils; // import monasca.common.util.stats.Statistics; /** * Statistics resource implementation. */ @Path("/v2.0/metrics/statistics") public class StatisticResource { private static final Splitter COMMA_SPLITTER = Splitter.on(',').omitEmptyStrings().trimResults(); private final String admin_role; private final StatisticRepo repo; private final PersistUtils persistUtils; @Inject public StatisticResource(ApiConfig config, StatisticRepo repo, PersistUtils persistUtils) { this.admin_role = (config.middleware == null || config.middleware.adminRole == null) ? DEFAULT_ADMIN_ROLE : config.middleware.adminRole; this.repo = repo; this.persistUtils = persistUtils; } @GET @Timed @Produces(MediaType.APPLICATION_JSON) public Object get( @Context UriInfo uriInfo, @HeaderParam("X-Tenant-Id") String tenantId, @HeaderParam("X-Roles") String roles, @QueryParam("name") String name, @QueryParam("dimensions") String dimensionsStr, @QueryParam("start_time") String startTimeStr, @QueryParam("end_time") String endTimeStr, @QueryParam("statistics") String statisticsStr, @DefaultValue("300") @QueryParam("period") String periodStr, @QueryParam("offset") String offset, @QueryParam("limit") String limit, @QueryParam("tenant_id") String crossTenantId, @QueryParam("merge_metrics") String mergeMetricsFlag) throws Exception { // Validate query parameters Validation.validateNotNullOrEmpty(name, "name"); DateTime startTime = Validation.parseAndValidateDate(startTimeStr, "start_time", true); DateTime endTime = Validation.parseAndValidateDate(endTimeStr, "end_time", false); Validation.validateTimes(startTime, endTime); Validation.validateNotNullOrEmpty(statisticsStr, "statistics"); int period = Validation.parseAndValidateNumber(periodStr, "period"); List statistics = Validation.parseValidateAndNormalizeStatistics(COMMA_SPLITTER.split(statisticsStr)); Map dimensions = Strings.isNullOrEmpty(dimensionsStr) ? null : Validation .parseAndValidateDimensions(dimensionsStr); MetricNameValidation.validate(name, true); Boolean mergeMetricsFlagBool = Validation.validateAndParseMergeMetricsFlag(mergeMetricsFlag); String queryTenantId = Validation.getQueryProject(roles, crossTenantId, tenantId, admin_role); return Links.paginateStatistics(this.persistUtils.getLimit(limit), repo.find(queryTenantId, name, dimensions, startTime, endTime, statistics, period, offset, this.persistUtils.getLimit(limit), mergeMetricsFlagBool), uriInfo); } }