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

com.dasasian.chok.client.IndexDeployFuture Maven / Gradle / Ivy

/**
 * Copyright (C) 2014 Dasasian ([email protected])
 *
 * 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.dasasian.chok.client;

import com.dasasian.chok.protocol.ConnectedComponent;
import com.dasasian.chok.protocol.InteractionProtocol;
import com.dasasian.chok.protocol.metadata.IndexMetaData;
import com.dasasian.chok.util.ZkConfiguration.PathDef;
import org.I0Itec.zkclient.IZkDataListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class IndexDeployFuture implements IIndexDeployFuture, IZkDataListener, ConnectedComponent, AutoCloseable {

    private static final Logger LOG = LoggerFactory.getLogger(IndexDeployFuture.class);

    private final InteractionProtocol protocol;
    private final String indexName;
    private volatile boolean registered;

    public IndexDeployFuture(InteractionProtocol protocol, String indexName) {
        this.protocol = protocol;
        this.indexName = indexName;
        this.protocol.registerComponent(this);
        this.protocol.registerDataListener(this, PathDef.INDICES_METADATA, indexName, this);
        registered = true;
    }

    public synchronized IndexState getState() {
        if (!registered) {
            return IndexState.DEPLOYED;
        }

        IndexMetaData indexMD = protocol.getIndexMD(indexName);
        if (indexMD == null) {
            return IndexState.DEPLOYING;
        } else if (indexMD.hasDeployError()) {
            return IndexState.ERROR;
        }
        close();
        return IndexState.DEPLOYED;
    }

    public void close() {
        if (registered) {
            registered = false;
            protocol.unregisterComponent(this);
        }
    }

    private boolean isDeploymentRunning() {
        return getState() == IndexState.DEPLOYING;
    }

    public synchronized IndexState joinDeployment() throws InterruptedException {
        while (isDeploymentRunning()) {
            wait(3000);
        }
        return getState();
    }

    public synchronized IndexState joinDeployment(long maxTime) throws InterruptedException {
        long startJoin = System.currentTimeMillis();
        while (isDeploymentRunning()) {
            wait(maxTime);
            maxTime = maxTime - (System.currentTimeMillis() - startJoin);
            if (maxTime <= 0) {
                break;
            }
        }
        return getState();
    }

    @Override
    public synchronized void handleDataChange(String dataPath, Object data) {
        wakeSleeper();
    }

    public synchronized void handleDataDeleted(String dataPath) {
        registered = false;
        protocol.unregisterComponent(this);
        wakeSleeper();
    }

    private synchronized void wakeSleeper() {
        notifyAll();
    }

    @Override
    public void reconnect() {
        // sg: we just want to make sure we get the very latest state of the
        // index, since we might missed a event. With zookeeper 3.x we should still
        // have subscribed notifications and don't need to re-subscribe
        LOG.warn("Reconnecting IndexDeployFuture");
        wakeSleeper();
    }

    @Override
    public void disconnect() {
        // nothing
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy