Module: Ably::Modules::UsesStateMachine

Extended by:
Forwardable
Included in:
Realtime::Channel, Realtime::Connection, Realtime::Models::NilChannel, Realtime::Presence
Defined in:
lib/ably/modules/uses_state_machine.rb

Overview

Mixing module that assists with Statemans State Machine state transitions and maintaining state of this object's #state.

Expects:

- @state_machine is set to the StateMachine
- StateEmitter is included in the object

Defined Under Namespace

Modules: ClassMethods

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#previous_stateSTATE? (readonly)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns The previous state for this connection.

Returns:

  • (STATE, nil)

    The previous state for this connection



40
41
42
43
44
# File 'lib/ably/modules/uses_state_machine.rb', line 40

def previous_state
  if state_machine.previous_state
    STATE(state_machine.previous_state)
  end
end

#state_historyArray<Hash> (readonly)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns All previous states including the current state in date ascending order with Hash properties :state, :metadata, :transitioned_at.

Returns:

  • (Array<Hash>)

    All previous states including the current state in date ascending order with Hash properties :state, :metadata, :transitioned_at



49
50
51
52
53
54
55
56
57
# File 'lib/ably/modules/uses_state_machine.rb', line 49

def state_history
  state_machine.history.map do |transition|
    {
      state:           STATE(transition.to_state),
      metadata:        transition.,
      transitioned_at: transition.created_at
    }
  end
end

Instance Method Details

#synchronize_state_with_statemachine(*args) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Provides an internal method for this object's state to match the StateMachine's current state. The current object's state will be changed to the StateMachine state and will emit an event



32
33
34
35
# File 'lib/ably/modules/uses_state_machine.rb', line 32

def synchronize_state_with_statemachine(*args)
  log_state_machine_state_change
  change_state state_machine.current_state, state_machine.last_transition.
end

#transition_state_machine(new_state, emit_params = {}) ⇒ Boolean

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Call #transition_to on the StateMachine

Returns:

  • (Boolean)

    true if new_state can be transitioned to by state machine



16
17
18
# File 'lib/ably/modules/uses_state_machine.rb', line 16

def transition_state_machine(new_state, emit_params = {})
  state_machine.transition_state(new_state, emit_object(new_state, emit_params))
end

#transition_state_machine!(new_state, emit_params = {}) ⇒ void

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

This method returns an undefined value.

Call #transition_to! on the StateMachine An exception wil be raised if new_state cannot be transitioned to by state machine



25
26
27
# File 'lib/ably/modules/uses_state_machine.rb', line 25

def transition_state_machine!(new_state, emit_params = {})
  state_machine.transition_to!(new_state, emit_object(new_state, emit_params))
end