Skip to content

Latest commit

 

History

History
104 lines (67 loc) · 5.71 KB

README.md

File metadata and controls

104 lines (67 loc) · 5.71 KB

Fr8 Logo

Fr8 Ruby SDK and Terminals

These Ruby-based Fr8 Terminals work with the Fr8 ecosystem. Fr8 is an open source cloud based integration platform (iPaaS). Fr8 makes it easy to hook SaaS services together and build applications without writing code. It can implement business and personal workflows, running on full automatic or upon request.

Fr8 Terminals communicate with Fr8 Hubs using RESTful endpoints, Http, and JSON. The SDK portion of this repository provides tools to make it easier for Terminals to be created and to keep things DRY. For example, there are object mapper classes that allow Ruby developers to avoid having to personally deal with the serialization and deserialization of Ruby objects into JSON.

The Ruby SDK services are in an early stage of development. (To get a sense of the roadmap, you may want to look at the more mature .NET SDK) More specifically, right now the framework is inside the lib folder. Our next step is to separate the framework code and put it in a standalone gem that will be server framework agnostic; and then separately create a rails starter project / gem with proper initializers that can generate boilerplate controllers.

Currently, this repository contains a single Terminal, the Fr8 Trello Terminal. This Terminal exposes useful Trello services to Fr8 Plans via a set of Activities.

Join the discussion here in the Issues list and in the #fr8dev-ruby channel on the public Fr8 Slack Team.

Developing a Fr8 Terminal

  1. You only need to clone this repo if you want to build or modify Fr8 Terminals written in Ruby. Before doing so, make sure you're familiar with Fr8 as an end user by building Fr8 Plans at the main Fr8 website.

  2. Read the development guides, especially the Terminal Development Guide.

  3. Clone this repo.

  4. Choose a development approach. The Fr8 service at fr8.co uses Heroku to deploy production and dev Ruby Terminals.

Ruby Code uses https://github.com/bbatsov/ruby-style-guide as its style guide, checked by Rubocop.

Installation

  • Rails gem install rails
  • Bundler gem install bundler --version '1.11.2' (v 1.11.2 is the one currently being used by Heroku)
  • Install GEMs with Bundler bundle
  • Initiate the DB rake db:create

Requirements

OSX

  • RVM \curl -sSL https://get.rvm.io | bash -s stable --ruby
  • Homebrew /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
  • PostgreSQL brew install postgresql

Current SDK Status

Supported Features:

  • Core DTOs for performing activity discovering, external authentication, configuration, activation, deactivation and running;
  • Serializers and deserializers for core DTOs;
  • Core controls:
    • Configuration
    • DropDownList
    • TextSource
    • TextBox
  • Core manifests:
    • OperationalStateCM
    • StandardConfigurationControlsCM
    • StandardPayloadDataCM
    • StandardFr8TerminalCM
  • Core Terminal-to-Hub communication mechanisms:
    • HMAC authentication support
    • External authentication support
    • Container payload retrieving

SDK Development Roadmap

Development plan for nearest future:

  • Separate lib/fr8 into a separate repository and transform it into a gem
  • Add support for generating boilerplate controllers for terminals using Rails
  • Add support for Sinatra and Hanami frameworks

SDK Features

SDK Modules

  • Fr8::Controls

    Package contains controls classes and their serializers/deserializers.

  • Fr8::Data

    Package contains core DTO classes and their serializers/deserializers.

  • Fr8::Manifests

    Package contains core Crate Manifest (CM) classes and their serializers/deserializers.

  • Fr8::Terminal

    Package contains TerminalHandler and ActivityStore classes. TerminalHandler should be instantiated once for whole terminal application. User usually should not instantiate ActivityStore class manually, as it is instantiated by default by TerminalHandler. More examples on TerminalHandler and ActivityStore are listed below in "Twitter terminal sample" section.

  • Fr8::Utility

    Package contains classes and functions for SDK internal use.

SDK Classes

  • Fr8::Hub

    Package contains utility classes to provide Terminal-To-Hub communication. Usually user should not instantiate these classes manually, instances of these classes are provided to configure and run activy handlers.

Trello Terminal Sample

We're providing Trello Terminal sample Rails app to show how to use Fr8 Ruby SDK to build a Fr8 Terminal.

All of the Terminal specific code and logic is contained inside of the following files: -- config/routes.rb - Defines a minimum required set of routes for any Fr8 Terminal: /discover, /activities/configure, activities/run, /authentication/request_url, and /authentication/token; as well as / that renders a simple HTML page with our Terminal introduction (standard practice among Fr8 Terminal Developers). -- app/controllers/terminal_controller.rb - Processes all of the endpoints defined in config/routes.rb as well as a terminal configuration. -- lib/fr8/terminal/terminal_handler.rb - Defines logic for all of the endpoints processed by TerminalController as well as internal helpers for deserializing data sent by the Hub.