All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.opsmatters.newrelic.api.services.SyntheticsAlertConditionService Maven / Gradle / Ivy

/*
 * Copyright 2018 Gerald Curley
 *
 * 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 com.opsmatters.newrelic.api.services;

import java.util.Collection;
import com.google.common.base.Optional;
import com.opsmatters.newrelic.api.NewRelicClient;
import com.opsmatters.newrelic.api.model.alerts.conditions.SyntheticsAlertCondition;
import com.opsmatters.newrelic.util.QueryParameterList;

/**
 * The set of operations used for Synthetics alert conditions.
 * 
 * @author Gerald Curley (opsmatters)
 */
public class SyntheticsAlertConditionService extends BaseFluent
{
    /**
     * Constructor that takes a http context and API client.
     * @param httpContext The set of HTTP operations
     * @param client The client used to invoke the New Relic operations
     */
    public SyntheticsAlertConditionService(HttpContext httpContext, NewRelicClient client)
    {
        super(httpContext, client);
    }

    /**
     * Returns the set of alert conditions for the given policy id.
     * @param policyId The id of the alert policy to return the conditions for
     * @return The set of alert conditions
     */
    public Collection list(long policyId)
    {
        QueryParameterList queryParams = new QueryParameterList();
        queryParams.add("policy_id", new Long(policyId));
        return HTTP.GET("/v2/alerts_synthetics_conditions.json", null, queryParams, SYNTHETICS_ALERT_CONDITIONS).get();
    }

    /**
     * Returns the Synthetics alert condition with the given id.
     * 

* This is needed because the API does not contain an operation to get a condition using the id directly. * @param policyId The id of the policy the condition belongs to * @param conditionId The id of the Synthetics alert condition to return * @return The alert condition */ public Optional show(long policyId, long conditionId) { Optional ret = Optional.absent(); Collection conditions = list(policyId); for(SyntheticsAlertCondition condition : conditions) { if(condition.getId() == conditionId) ret = Optional.of(condition); } return ret; } /** * Creates the given Synthetics alert condition. * @param policyId The id of the policy to add the alert condition to * @param condition The alert condition to create * @return The alert condition that was created */ public Optional create(long policyId, SyntheticsAlertCondition condition) { return HTTP.POST(String.format("/v2/alerts_synthetics_conditions/policies/%d.json", policyId), condition, SYNTHETICS_ALERT_CONDITION); } /** * Updates the given Synthetics alert condition. * @param condition The alert condition to update * @return The alert condition that was updated */ public Optional update(SyntheticsAlertCondition condition) { return HTTP.PUT(String.format("/v2/alerts_synthetics_conditions/%d.json", condition.getId()), condition, SYNTHETICS_ALERT_CONDITION); } /** * Deletes the Synthetics alert condition with the given id. * @param conditionId The id of the alert condition to delete * @return This object */ public SyntheticsAlertConditionService delete(long conditionId) { HTTP.DELETE(String.format("/v2/alerts_synthetics_conditions/%d.json", conditionId)); return this; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy