FarmBot/Farmbot-Web-App

View on GitHub
app/mutations/points/tool_removal_check.rb

Summary

Maintainability
A
0 mins
Test Coverage
module Points
  # Logic for tool removal was complicated enough to warrant its own
  # mutation object.
  class ToolRemovalCheck < Mutations::Command
    IN_USE = "Tool in use by the following sequences: %s"

    required do
      model :point, class: Point
      # Does nil `next_tool_id` mean "I have nothing to say"?
      # Or does it mean: "I want to clear something out"?
      boolean :attempting_change
      integer :next_tool_id, nils: true, empty_is_nil: true
    end

    def validate
      nope! if still_in_use?
    end

    def execute
      true
    end

    private

    def is_removal_attempt
      (attempting_change && # Wants to make a change
       (next_tool_id === nil) && # Wants to remove tool_id
       point.tool_id)            # Currently has a tool_id
    end

    def still_in_use?
      is_removal_attempt && deps.any?
    end

    def nope!
      add_error :in_use, :in_use, (IN_USE % [deps.join(", ")])
    end

    def deps
      @deps ||= InUseTool.where(tool_id: point.tool_id).pluck(:sequence_name)
    end
  end
end