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

org.elasticsearch.common.component.Lifecycle Maven / Gradle / Ivy

/*
 * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
 * or more contributor license agreements. Licensed under the Elastic License
 * 2.0 and the Server Side Public License, v 1; you may not use this file except
 * in compliance with, at your election, the Elastic License 2.0 or the Server
 * Side Public License, v 1.
 */

package org.elasticsearch.common.component;

/**
 * Lifecycle state. Allows the following transitions:
 * 
    *
  • INITIALIZED -> STARTED, STOPPED, CLOSED
  • *
  • STARTED -> STOPPED
  • *
  • STOPPED -> STARTED, CLOSED
  • *
  • CLOSED ->
  • *
*

* Also allows to stay in the same state. For example, when calling stop on a component, the * following logic can be applied: *

 * public void stop() {
 *  if (lifecycleState.moveToStopped() == false) {
 *      return;
 *  }
 * // continue with stop logic
 * }
 * 
*

* NOTE: The Lifecycle class is thread-safe. It is also possible to prevent concurrent state transitions * by locking on the Lifecycle object itself. This is typically useful when chaining multiple transitions. *

* Note, closed is only allowed to be called when stopped, so make sure to stop the component first. * Here is how the logic can be applied. A lock of the {@code lifecycleState} object is taken so that * another thread cannot move the state from {@code STOPPED} to {@code STARTED} before it has moved to * {@code CLOSED}. *

 * public void close() {
 *  synchronized (lifecycleState) {
 *      if (lifecycleState.started()) {
 *          stop();
 *      }
 *      if (lifecycleState.moveToClosed() == false) {
 *          return;
 *      }
 *  }
 *  // perform close logic here
 * }
 * 
*/ public class Lifecycle { public enum State { INITIALIZED, STOPPED, STARTED, CLOSED } private volatile State state = State.INITIALIZED; public State state() { return this.state; } /** * Returns {@code true} if the state is initialized. */ public boolean initialized() { return state == State.INITIALIZED; } /** * Returns {@code true} if the state is started. */ public boolean started() { return state == State.STARTED; } /** * Returns {@code true} if the state is stopped. */ public boolean stopped() { return state == State.STOPPED; } /** * Returns {@code true} if the state is closed. */ public boolean closed() { return state == State.CLOSED; } public boolean stoppedOrClosed() { Lifecycle.State state = this.state; return state == State.STOPPED || state == State.CLOSED; } public boolean canMoveToStarted() throws IllegalStateException { State localState = this.state; if (localState == State.INITIALIZED || localState == State.STOPPED) { return true; } if (localState == State.STARTED) { return false; } if (localState == State.CLOSED) { throw new IllegalStateException("Can't move to started state when closed"); } throw new IllegalStateException("Can't move to started with unknown state"); } public synchronized boolean moveToStarted() throws IllegalStateException { State localState = this.state; if (localState == State.INITIALIZED || localState == State.STOPPED) { state = State.STARTED; return true; } if (localState == State.STARTED) { return false; } if (localState == State.CLOSED) { throw new IllegalStateException("Can't move to started state when closed"); } throw new IllegalStateException("Can't move to started with unknown state"); } public boolean canMoveToStopped() throws IllegalStateException { State localState = state; if (localState == State.STARTED) { return true; } if (localState == State.INITIALIZED || localState == State.STOPPED) { return false; } if (localState == State.CLOSED) { throw new IllegalStateException("Can't move to stopped state when closed"); } throw new IllegalStateException("Can't move to stopped with unknown state"); } public synchronized boolean moveToStopped() throws IllegalStateException { State localState = state; if (localState == State.STARTED) { state = State.STOPPED; return true; } if (localState == State.INITIALIZED || localState == State.STOPPED) { return false; } if (localState == State.CLOSED) { throw new IllegalStateException("Can't move to stopped state when closed"); } throw new IllegalStateException("Can't move to stopped with unknown state"); } public boolean canMoveToClosed() throws IllegalStateException { State localState = state; if (localState == State.CLOSED) { return false; } if (localState == State.STARTED) { throw new IllegalStateException("Can't move to closed before moving to stopped mode"); } return true; } public synchronized boolean moveToClosed() throws IllegalStateException { State localState = state; if (localState == State.CLOSED) { return false; } if (localState == State.STARTED) { throw new IllegalStateException("Can't move to closed before moving to stopped mode"); } state = State.CLOSED; return true; } @Override public String toString() { return state.toString(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy