Skip to content

samanmohamadi/solidus_digital

 
 

Repository files navigation

Compatibility Build Status License Gitter

Solidus Digital

This is a spree extension to enable downloadable products (ebooks, MP3s, videos, etc).

This fork adds authorization and authentication capabilities, preference to disable links expiration and per user attachments.

In the Versionfile you can see which solidus_digital branch supports which Spree version. The master branch is not considered stable and corresponds to the spree master branch.

This documentation is not complete and possibly out of date in some cases. There are features that have been implemented that are not documented here, please look at the source for complete documentation.

The idea is simple. You attach a file to a Product (or a Variant of this Product) and when people buy it, they will receive a link via email where they can download it once. There are a few assumptions that solidus_digital (currently) makes and it's important to be aware of them.

  • The table structure of spree_core is not touched. Spree digital lives parallel to spree_core and does change the existing database, except adding two new tables.
  • The download links will be sent via email in the order confirmation (or "resend" from the admin section). The links do not appear in the order "overview" that the customer sees. Adding download buttons to OrdersController#show is easy, check out this gist.
  • Once the order is checked-out, the download links will immediately be sent (i.e. in the order confirmation). You'll have to modify the system to support 'delayed' payments (like a billable account).
  • You should create a ShippingMethod based on the Digital Delivery calculator type. The default cost for digital delivery is 0, but you can define a flat rate (creating a per-item digital delivery fee would be possible as well). Checkout the source code for the Digital Delivery calculator for more information.
  • One may buy several items of the same digital product in one cart. The customer will simply receive several links by doing so. This allows customer's to legally purchase multiple copies of the same product and maybe give one away to a friend.
  • You can set how many times (clicks) the users downloads will work. You can also set how long the users links will work (expiration). For more information, check out the preferences object
  • The file views/order_mailer/confirm_email.text.erb needs to be customized by you. If you are looking for HTML emails, this branch of spree-html-email supports solidus_digital.
  • A purchased product can be downloaded even if you disable the product immediately. You would have to remove the attached file in your admin section to prevent people from downloading purchased products.
  • File are uploaded to RAILS_ROOT/private. Make sure it's symlinked in case you're using Capistrano. If you want to change the upload path, check out this gist.
  • You must add a views/spree/digitals/unauthorized.html.erb file to customize an error message to the user if they exceed the download / days limit
  • We use send_file to send the files on download. See below for instructions on how to push file downloading off to nginx.

Added in this version:

  • New preference to disable digital links expiration. It defaults to true (links expire within 24 hours and 3 clicks). To disable links expiration, add in config/spree.rb
SolidusDigital::Config.tap do |config|
  config.expirable_links = false
end
  • New preference to require user authentication for downloads (based on Devise). It defaults to true (authentication required). To disable required authentication:
SolidusDigital::Config.tap do |config|
  config.authentication_required = false
end
  • Added user_id column in digital_links to enable Cancan authorization per user. New preference to require user authorization for downloads. It defaults to true (authorization required). To disable required authorization:
SolidusDigital::Config.tap do |config|
  config.authorization_required = false
end
  • New preference per_user_attachment to perform a unique attachment copy for users. It defaults to true. To disable per user attachment:
SolidusDigital::Config.tap do |config|
  config.per_user_attachment = false
end

Additionally you can provide a proc to perform some processing before creating each user copy (for example, stamping, watermark, and so on) It accepts three parameters: input_file, output_file and the digital link self object

SolidusDigital::Config.tap do |config|
  config.per_user_attachment_process = Proc.new do |input_file, output_file, digital_link|
    # pdf processing
  end
end

Quickstart

Add this line to the Gemfile in your Spree project:

# Depending on your Spree version, you may use another branch
gem 'solidus_digital', github: 'samanmohamadi/solidus_digital', branch: 'master'

The following terminal commands will copy the migration files to the corresponding directory in your Rails application and apply the migrations to your database.

bundle exec rails g solidus_digital:install
bundle exec rake db:migrate

Then set any preferences in the web interface.

Shipping Configuration

You should create a ShippingMethod based on the Digital Delivery calculator type. It will be detected by solidus_digital. Otherwise your customer will be forced to choose something like "UPS" even if they purchase only downloadable products.

Improving File Downloading: send_file + nginx

Without customization, all file downloading will route through the rails stack. This means that if you have two workers, and two customers are downloading files, your server is maxed out and will be unresponsive until the downloads have finished.

Luckily there is an easy way around this: pass off file downloading to nginx (or apache, etc). Take a look at this article for a good explanation.

# in your app's source
# config/environments/production.rb

# Specifies the header that your server uses for sending files
# config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
# on your server
# e.g. /etc/nginx/sites-available/spree-secure
upstream unicorn_spree_secure {
  server unix:/data/spree/shared/sockets/unicorn.sock fail_timeout=0;
}
server {
  listen 443;
  ...

  location / {
    proxy_set_header X_FORWARDED_PROTO https;
    ...
    proxy_set_header X-Sendfile-Type  X-Accel-Redirect;
    proxy_set_header X-Accel-Mapping  /data/spree/shared/uploaded-files/digitals/=/digitals/;
    ...
  }

  location /digitals/ {
    internal;
    root /data/spree/shared/uploaded-files/;
  }
  ...
}

References:

Development

Table Diagram

Testing

rake test_app
rake rspec

Contributors

See https://github.com/halo/solidus_digital/graphs/contributors

License

MIT © 2011-2015 halo, see LICENSE

About

A Spree extension to enable downloadable products

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 75.2%
  • HTML 23.7%
  • Other 1.1%