com.netflix.priam.resources.CassandraConfigResource.java Source code

Java tutorial

Introduction

Here is the source code for com.netflix.priam.resources.CassandraConfigResource.java

Source

/**
 * Copyright 2013 Netflix, Inc.
 *
 * 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.netflix.priam.resources;

import com.google.inject.Inject;
import com.netflix.priam.PriamServer;
import com.netflix.priam.identity.DoubleRing;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import java.io.IOException;
import java.util.List;

/**
 * This servlet will provide the configuration API service as and when Cassandra
 * requests for it.
 */
@Path("/v1/cassconfig")
@Produces(MediaType.TEXT_PLAIN)
public class CassandraConfigResource {
    private static final Logger logger = LoggerFactory.getLogger(CassandraConfigResource.class);

    private final PriamServer priamServer;
    private final DoubleRing doubleRing;

    @Inject
    public CassandraConfigResource(PriamServer server, DoubleRing doubleRing) {
        this.priamServer = server;
        this.doubleRing = doubleRing;
    }

    @GET
    @Path("/get_seeds")
    public Response getSeeds() {
        try {
            final List<String> seeds = priamServer.getInstanceIdentity().getSeeds();
            if (CollectionUtils.isNotEmpty(seeds)) {
                return Response.ok(StringUtils.join(seeds, ',')).build();
            }
            logger.error("Cannot find the Seeds {}", seeds);
        } catch (Exception e) {
            logger.error("Error while executing get_seeds", e);
            return Response.serverError().build();
        }
        return Response.status(500).build();
    }

    @GET
    @Path("/get_token")
    public Response getToken() {
        try {
            if (StringUtils.isNotBlank(priamServer.getInstanceIdentity().getInstance().getToken())) {
                return Response.ok(priamServer.getInstanceIdentity().getInstance().getToken()).build();
            }
            logger.error("Cannot find token for this instance.");
        } catch (Exception e) {
            // TODO: can this ever happen? if so, what conditions would cause an exception here?
            logger.error("Error while executing get_token", e);
            return Response.serverError().build();
        }
        return Response.status(500).build();
    }

    @GET
    @Path("/is_replace_token")
    public Response isReplaceToken() {
        try {
            return Response.ok(String.valueOf(priamServer.getInstanceIdentity().isReplace())).build();
        } catch (Exception e) {
            // TODO: can this ever happen? if so, what conditions would cause an exception here?
            logger.error("Error while executing is_replace_token", e);
            return Response.serverError().build();
        }
    }

    @GET
    @Path("/get_replaced_ip")
    public Response getReplacedIp() {
        try {
            return Response.ok(priamServer.getInstanceIdentity().getReplacedIp()).build();
        } catch (Exception e) {
            logger.error("Error while executing get_replaced_ip", e);
            return Response.serverError().build();
        }
    }

    /**
     * Updates the Priam instance registry (SimpleDB) with the token currently in use by Cassandra.
     */
    @POST
    @Path("/update_token")
    public Response updateToken() {
        try {
            priamServer.getInstanceIdentity().updateToken();
            return Response.ok(priamServer.getInstanceIdentity().getInstance().getToken()).build();
        } catch (Exception e) {
            logger.error("Error while executing update_token", e);
            return Response.serverError().build();
        }
    }

    @GET
    @Path("/double_ring")
    public Response doubleRing() throws IOException, ClassNotFoundException {
        try {
            doubleRing.backup();
            doubleRing.doubleSlots();
        } catch (Throwable th) {
            logger.error("Error in doubling the ring...", th);
            doubleRing.restore();
            // rethrow
            throw new RuntimeException(th);
        }
        return Response.status(200).build();
    }
}