backport

1.2.0last stable release 4 years ago
Complexity Score
Low
Open Issues
0
Dependent Projects
3
Weekly Downloadsglobal
934

License

  • MIT
    • Yesattribution
    • Permissivelinking
    • Permissivedistribution
    • Permissivemodification
    • Nopatent grant
    • Yesprivate use
    • Permissivesublicensing
    • Notrademark grant

Downloads

Readme

Backport

A pure Ruby library for event-driven IO.

This library is designed with portability as the highest priority, which is why it’s written in pure Ruby. Consider EventMachine if you need a solution that’s faster, more mature, and scalable.

Installation

Install the gem:

gem install backport

Or add it to your application’s Gemfile:

gem 'backport'

Usage

Examples

A simple echo server:

require 'backport'

module MyAdapter
  def opening
    puts "Opening a connection"
  end

  def closing
    puts "Closing a connection"
  end

  def receiving data
    write "Client sent: #{data}"
  end
end

Backport.run do
  Backport.prepare_tcp_server(host: 'localhost', port: 8000, adapter: MyAdapter)
end

An interval server that runs once per second:

require 'backport'

Backport.run do
  Backport.prepare_interval 1 do
    puts "tick"
  end
end

Using Adapters

Backport servers that handle client connections, such as TCP servers, use an adapter to provide an application interface to the client. Developers can provide their own adapter implementations in two ways: a Ruby module that will be used to extend a Backport::Adapter object, or a class that extends Backport::Adapter. In either case, the adapter should provide the following methods:

  • opening: A callback triggered when the client connection is accepted
  • closing: A callback triggered when the client connection is closed
  • receiving(data): A callback triggered when the server receives data from the client

Backport::Adapter also provides the following methods:

  • write(data): Send raw data to the client
  • write_line(data): Send a line of data to the client
  • close: Disconnect the client from the server
  • closed?: True if the connection is closed
  • remote: A hash of data about the client, e.g., the remote IP address

Dependencies

No runtime dependency information found for this package.

CVE IssuesActive
0
Scorecards Score
No Data
Test Coverage
No Data
Follows Semver
Yes
Github Stars
11
Dependenciestotal
3
DependenciesOutdated
1
DependenciesDeprecated
0
Threat Modelling
No
Repo Audits
No

Learn how to distribute backport in your own private RubyGems registry

gem install backport
Processing...
Done

8 Releases

RubyGems on Cloudsmith

Getting started with RubyGems on Cloudsmith is fast and easy.