Skip to content

princekarlo/ruby-semaphore

Repository files navigation

Semaphore

This gem provides a simple and intuitive Ruby API wrapper for interacting with the Semaphore API. With this gem, you can easily send messages, manage accounts, and perform other operations using the Semaphore API.

Usage

Quickstart

For a quick test you can pass your token directly to a new client:

semaphore = Semaphore::Client.new(api_key: '[API KEY]', sender_name: '[SENDER NAME]')

# Sending a message
semaphore.messages(
  parameters: {
    message: '[YOUR MESSAGE]',
    number: '[NUMBER]'
  }
)

# Sending a Bulk Message
semaphore.messages(
  parameters: {
    message: '[YOUR MESSAGE]',
    number: '[NUMBER], [NUMBER], [NUMBER], [NUMBER]' # Comma separated
  }
)

# Sending an OTP
semaphore.otp(
  parameters: {
    message: 'Thanks for registering. Your OTP Code is {otp}.',
    number: '[NUMBER]',
    code: 1234
  }
)

Using Config

To enhance your setup, you can configure the gem with your API keys in a more secure manner, such as in an semaphore.rb initializer file. This approach prevents hardcoding secrets directly into your codebase. Instead, consider using a gem like dotenv to safely pass the keys into your environments.

# config/initializers/semaphore.rb

Semaphore.configure do |config|
  config.api_key = ENV.fetch("SEMAPHORE_API_KEY")
  config.sender_name = ENV.fetch("SEMAPHORE_SENDERNAME")
end

After configuring the API key, you can simply create a new client:

Semaphore::Client.new.messages(
  parameters: {
    message: '[YOUR MESSAGE]',
    number: '[NUMBER]'
  }
)

Installation

Add this line to your application's Gemfile:

gem "ruby-semaphore"

And then execute:

$ bundle

Or install it yourself as:

$ gem install ruby-semaphore

Contributing

Contributions are welcome! Please follow the guidelines outlined in the CONTRIBUTING.md file.

License

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