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

com.palantir.atlasdb.coordination.CoordinationResource Maven / Gradle / Ivy

There is a newer version: 0.1152.0
Show newest version
/*
 * (c) Copyright 2018 Palantir Technologies Inc. All rights reserved.
 *
 * 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.palantir.atlasdb.coordination;

import com.palantir.atlasdb.internalschema.InternalSchemaMetadata;
import com.palantir.processors.AutoDelegate;
import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

@AutoDelegate
@Path("/coordination")
public interface CoordinationResource {
    @POST
    @Path("/get-transactions-schema-version")
    @Produces(MediaType.APPLICATION_JSON)
    @Consumes(MediaType.APPLICATION_JSON)
    int getTransactionsSchemaVersion(long timestamp);

    @POST
    @Path("/try-install-transactions-schema-version")
    @Produces(MediaType.APPLICATION_JSON)
    @Consumes(MediaType.APPLICATION_JSON)
    boolean tryInstallNewTransactionsSchemaVersion(int newVersion);

    /**
     * Force install a new version of the transactions schema. After this method returns, the provided
     * transactions schema version should be installed, and timestamps brought forward to the point where the
     * provided version will actively be used in transactions.
     *
     * @param newVersion new schema verison to install
     */
    @POST
    @Path("/force-install-transactions-schema-version")
    @Consumes(MediaType.APPLICATION_JSON)
    void forceInstallNewTransactionsSchemaVersion(int newVersion);

    @POST
    @Path("/transaction")
    @Produces(MediaType.APPLICATION_JSON)
    boolean doTransactionAndReportOutcome();

    /**
     * After this method returns, the state of the {@link CoordinationService} that is backing this
     * {@link CoordinationResource} should be reset. The latest value of the
     * {@link InternalSchemaMetadata#timestampToTransactionsTableSchemaVersion()} should be
     * {@link com.palantir.atlasdb.transaction.impl.TransactionConstants#TRANSACTIONS_TABLE_SCHEMA_VERSION},
     * and that version of the transaction schema should already be in effect, with no pending installs.
     *
     * @return a fresh timestamp after the reset has been executed
     */
    @POST
    @Path("/reset-state")
    @Produces(MediaType.APPLICATION_JSON)
    long resetStateAndGetFreshTimestamp();

    @POST
    @Path("/write-unsafe")
    @Produces(MediaType.APPLICATION_JSON)
    void writeToKvsUnsafe(long timestamp);

    @Path("/fresh-timestamp")
    @POST // POST because we can't allow caching
    @Produces(MediaType.APPLICATION_JSON)
    long getFreshTimestamp();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy