Project

riparian

0.0
No commit activity in last 3 years
No release in over 3 years
Basically just a handful of models to make handling workflows and asynchronous server-side tasks a little easier.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 1.0.0
~> 1.6.2
>= 0

Runtime

 Project Readme

Riparian

Riparian is a partial workflow system built with Delayed Job and Paperclip. It consists of Flow Tasks, which are tasks to be performed by Delayed Job, and Flow Task Resources, which constitute input and output data of the tasks. Flow Task Resources can have an attached file, or a polymorphic relationship to an ActiveRecord resource.

To make your own tasks, subclass FlowTask and implement the run method. Tasks will be executed whenever Delayed Job gets to them.

If you need to alter Paperclip's path and url settings, you can add a riparian.yml file to your config folder with the following settings:

flow_task_resource_file_path: paperclip/interpolation/string
flow_task_resource_file_url: paperclip/interpolation/string

Similarly you can set the max and min file sizes in bytes for file attachments:

flow_task_resource_file_size_greater_than: 1 # Default: 1 byte
flow_task_resource_file_size_less_than: 1024 # Default: 10 megabytes

Example

# generate controller, helper, and migration
rails generate riparian

# subclass FlowTask
class MyTask < FlowTask
  def run
    open(inputs.first.file.path) do |f|
      txt = f.read
      txt.gsub! 'foo', 'bar'
      Tempfile.open('bar') do |tf|
        tf.write(txt)
        outputs.create(:file => tf)
      end
    end
  end
end

Start POSTing stuff to /flow_tasks!