org.springframework.integration.leader.DefaultCandidate.java Source code

Java tutorial

Introduction

Here is the source code for org.springframework.integration.leader.DefaultCandidate.java

Source

/*
 * Copyright 2014-2019 the original author or authors.
 *
 * 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
 *
 *      https://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 org.springframework.integration.leader;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * Simple {@link Candidate} for leadership.
 * This implementation simply logs when it is elected and when its leadership is revoked.
 *
 * @author Janne Valkealahti
 * @author Artem Bilan
 * @since 4.2
 */
public class DefaultCandidate extends AbstractCandidate {

    private final Log logger = LogFactory.getLog(getClass());

    private volatile Context leaderContext;

    /**
     * Instantiate a default candidate.
     */
    public DefaultCandidate() {
        super();
    }

    /**
     * Instantiate a default candidate.
     *
     * @param id the identifier
     * @param role the role
     */
    public DefaultCandidate(String id, String role) {
        super(id, role);
    }

    @Override
    public void onGranted(Context ctx) {
        if (this.logger.isInfoEnabled()) {
            this.logger.info(this + " has been granted leadership; context: " + ctx);
        }
        this.leaderContext = ctx;
    }

    @Override
    public void onRevoked(Context ctx) {
        if (this.logger.isInfoEnabled()) {
            this.logger.info(this + " leadership has been revoked: " + ctx);
        }
    }

    /**
     * Voluntarily yield leadership if held. If leader context is not
     * yet known this method does nothing. Leader context becomes available
     * only after {@link #onGranted(Context)} method is called by the
     * leader initiator.
     */
    public void yieldLeadership() {
        if (this.leaderContext != null) {
            this.leaderContext.yield();
        }
    }

    @Override
    public String toString() {
        return String.format("DefaultCandidate{role=%s, id=%s}", getRole(), getId());
    }

}