Project

notebook

0.0
No commit activity in last 3 years
No release in over 3 years
A simple Ruby file uploader library
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.10
>= 0
~> 10.0
>= 0
 Project Readme

Notebook

Build Status

Notebook is a Ruby file attachment library, that has easy integration with Rails and ActiveRecord.

Installation

Add this line to your application's Gemfile:

gem 'notebook'

And then execute:

$ bundle

Or install it yourself as:

$ gem install notebook

Rails Quickstart

Models

Rails 4

class User < ActiveRecord::Base
  notebook_attachment :profile_picture
end

Edit and New Views

<%= form_for @user, url: users_path, html: { multipart: true } do |form| %>
  <%= form.file_field :avatar %>
<% end %>

Controller

Rails 4

def create
  @user = User.create(user_params)
end

private
def user_params
  params.require(:user).permit(:avatar)
end

Show View

<%= image_tag @user.avatar.url %>

Deleting an Attachment

Set the attribute to nil and save.

@user.avatar = nil
@user.save

Configuration

To use a different storage location than /public, create a config/initializers/notebook.rb, and then set the following:

Notebook.public_directory = 'hi'

To store your upload files in a different place than the filesystem, create a config/initializers/notebook.rb, then set the following:

# these are the two out of the box storage adapters
# to use one from another source, just place the constant of a
compliant adapter here.
Notebook.adapter = Notebook::StorageAdapters::Filesystem
Notebook.adapter = Notebook::StorageAdapters::S3

Plain Old Ruby

It's awesome you want to use plain Ruby without Rails with Notebook!

First off, you need to read in a file, and create a new Notebook::Attachment object, like so:

file = File.read("avatar.jpg")
attachment = Notebook::Attachment.new(file)

The last and final step is to just upload it!

attachment.upload

# get the url of the newly persisted file
attachment.url

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/moss-rb/notebook. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

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