No release in over 3 years
Low commit activity in last 3 years
Ruby module to provide a strict, boilerplate interface for service classes.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 2.0
~> 12.0
~> 3.0

Runtime

 Project Readme

ServiceInterface

A Ruby module that can be included into service classes that provides a strict, boilerplate interface, taking care of defining a class-level execute method, instantiating the service and invoking the instance-level execute method, and defining and setting the arguments (and default values) of the service (both required and optional).

Usage

Add the gem to your Gemfile:

gem 'service_interface', '~> 1.0'

Then create a service class, include the interface, and define the arguments, like so:

class TestService
  include ServiceInterface

  arguments :word, count: 5, suffix: nil

  def execute
    (Array.new(@count, @word) << @suffix).compact.join(', ')
  end
end

Then invoke the class like so:

TestService.execute(word: 'Ruby', suffix: 'Yay!')
=> 'Ruby, Ruby, Ruby, Ruby, Ruby, Yay!'

The equivalent code, written without ServiceInterface, would look something like this:

class TestService
  def self.execute(word:, count: 5, suffix: nil)
    new(
      word: word,
      count: count,
      suffix: suffix
    ).send(:execute)
  end

  def initialize(word:, count:, suffix:)
    @word = word
    @count = count
    @suffix = suffix
  end

  private

  def execute
    (Array.new(@count, @word) << @suffix).compact.join(', ')
  end
end

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/GlenCrawford/service_interface.

License

The gem is available as open source under the terms of the MIT License.