/nightcrawler_swift

Like the X-Men nightcrawler this gem teleports your assets to a OpenStack Swift bucket/container

Primary LanguageRubyMIT LicenseMIT

Nightcrawler Swift Gem Version Code Climate Travis

Like the X-Men nightcrawler this gem teleports your assets to a OpenStack Swift bucket/container. It was designed to sync your assets with OpenStack Swift and allow some operations with your buckets/containers.

Installation

Add this line to your application's Gemfile:

gem 'nightcrawler_swift'

And then execute:

$ bundle

Or install it yourself as:

$ gem install nightcrawler_swift

Usage

With Rails

1) Configure your swift credentials and options

In config/application.rb or config/environments/*.rb

config.nightcrawler_swift.bucket = "rogue"
config.nightcrawler_swift.tenant_name = "nightcrawler"
config.nightcrawler_swift.username = "my_username1"
config.nightcrawler_swift.password = "my_password1"
config.nightcrawler_swift.auth_url = "https://auth.url.com:123/v2.0/tokens"

The password option can be left blank and be defined by the env variable NSWIFT_PASSWORD. The env variable will take precedence if the option was set.

Optional configurations:

config.nightcrawler_swift.max_age = 3600 # default: nil
config.nightcrawler_swift.timeout = 10 # in seconds, default: nil

# default: uses the admin_url returned by authentication
config.nightcrawler_swift.admin_url = "https://api.host.com/v1/AUTH_1234"

# default: uses the public_url returned by authentication
config.nightcrawler_swift.public_url = "http://asset.host.com/v1/AUTH_1234"

# default: 5, to disable set it to false
config.nightcrawler_swift.retries = 3

# in seconds, default: 30
config.nightcrawler_swift.max_retry_time = 64

# default: false. You could use OpenSSL::SSL::VERIFY_PEER
config.nightcrawler_swift.verify_ssl = true

# default: nil
config.nightcrawler_swift.ssl_client_cert =
  OpenSSL::X509::Certificate.new(File.read("cert.pem"))

# default: nil
config.nightcrawler_swift.ssl_client_key =
  OpenSSL::PKey::RSA.new(File.read("key.pem"), "passphrase, if any")

# default: nil
config.nightcrawler_swift.ssl_ca_file = "ca_certificate.pem"

#default: nil
config.nightcrawler_swift.ssl_version = "SSLv23"

By default it will use Rails.logger as logger, to change that use a different logger in configurations, like:

config.nightcrawler_swift.logger = Logger.new(STDOUT)
further explanation of configurations

max_age

It will be used to define Cache-Control:max-age= header.

retries

The number of times to retry the request before failing. To disable this feature set it to false.

max_retry_time

Maximum delay in seconds between each retry. The delay will start with 1s and will double for each retry until this value.

2) Profit!

$ rake nightcrawler_swift:rails:asset_sync

It will invoke rake assets:precompile and will copy your public directory to swift bucket/container. To sync the public directory without the asset precompilation use the task: nightcrawler_swift:rails:sync

Programatically

1) Configure your swift credentials and options

NightcrawlerSwift.configure({
  bucket: "rogue",
  tenant_name: "nightcrawler",
  username: "my_username1",
  password: "my_password1",
  auth_url: "https://auth.url.com:123/v2.0/tokens"
})

The password option can be left blank and be defined by the env variable NSWIFT_PASSWORD. The env variable will take precedence if the option was set.

Optional configurations:

max_age: 3600,
timeout: 10, # in seconds

# default: uses the admin_url returned by authentication
admin_url: "https://api.host.com/v1/AUTH_1234",

# default: uses the public_url returned by authentication
public_url: "http://asset.host.com/v1/AUTH_1234",

# default: 5, to disable set it to false
retries: 3,

# in seconds, default: 30
max_retry_time: 64

# default: false. You could use OpenSSL::SSL::VERIFY_PEER
verify_ssl: true,

# default: nil
ssl_client_cert:
  OpenSSL::X509::Certificate.new(File.read("cert.pem")),

# default: nil
ssl_client_key:
  OpenSSL::PKey::RSA.new(File.read("key.pem"), "passphrase, if any"),

# default: nil
ssl_ca_file: "ca_certificate.pem"

By default it will use Logger.new(STDOUT) as logger, to change that use:

NightcrawlerSwift.logger = Logger.new(StringIO.new)

2) Use method sync with the desired directory

NightcrawlerSwift.sync File.expand_path("./my-dir")

Command Line

The NightcrawlerSwift shell command (CLI) allows you to interact with your buckets/containers easily, it has the same commands of the gem. To see the help, use the cli without arguments or use the -h/--help switch.

$ nswift # or nswift -h

nswift will use the configurations stored at the file .nswiftrc located at your home directory. If you try to use any command without the file, it will create a sample configuration for you, but you can create your own.

The configuration is a json file, named .nswiftrc. You can include any configuration available to the gem (see the other usages example to know each option available). Follow the format:

{
  "bucket": "<bucket/container name>",
  "tenant_name": "<tenant name>",
  "username": "<username>",
  "password": "<password>",
  "auth_url": "<auth url, ex: https://auth.url.com:123/v2.0/tokens>"
}

The following commands are available through the cli:

$ nswift list
$ nswift upload <real_path> <swift_path> # nswift upload robots.txt assets/robots.txt

Upload also supports a custom max-age, to override the value defined in ".nswiftrc", example:

$ nswift upload <real_path> <swift_path> --max-age VALUE # nswift upload readme assets/readme.md --max-age 300
$ nswift download <swift_path> # nswift download assets/robots.txt > my-robots.txt
$ nswift delete <swift_path> # nswift delete assets/robots.txt
$ nswift url-for <swift_path> # nswift url-for assets/robots.txt
$ nswift metadata <swift_path>
# {
#   "date": "Tue, 31 Mar 2015 02:10:40 GMT",
#   "content_type": "text/css",
#   "content_length": "50013",
#   "last_modified": "Wed, 15 Oct 2014 13:38:56 GMT",
#   "etag": "e13839c545f32be23b942a41f3ea7724",
#   "x_timestamp": "1413380335.38118",
#   "cache_control": "public, max-age=604800",
#   "x_trans_id": "tx824d632ef9e54685a7563-005519f838"
# }

For any commands you could provide a different configuration file through the -c/--config switch, as:

$ nswift list -c /dir/my-nswift-rc

and a different bucket/container name through the -b/--bucket switch, as:

$ nwift list -b rogue

Commands

NightcrawlerSwift has some useful built-in commands. All commands require the configuration and will automatically connect/reconnect to keystone when necessary.

Upload

upload = NightcrawlerSwift::Upload.new
upload.execute "my_file_path.txt", File.open("../my_file_fullpath.txt", "r")
# true / false

This upload command was not designed to send very large files.

It will accept a custom max-age, overriding the configured value through NightcrawlerSwift.configure, example:

upload = NightcrawlerSwift::Upload.new
upload.execute "readme", File.open("readme.md", "r"), max_age: 300
# true / false

Download

download = NightcrawlerSwift::Download.new
download.execute "my_file_path.txt"
# File content

This download command was not designed to retrieve very large files

List

list = NightcrawlerSwift::List.new
list.execute
# [{"hash": "...", "name": "my_file_path.txt"}, {}, {}, ...]

This command supports the following parameters: limit, marker, end_marker, prefix, format, delimiter, path

Example:

list = NightcrawlerSwift::List.new
list.execute prefix: '/some/path'
# [{"hash": "...", "name": "/some/path/with/my_file_path.txt"}, {}, {}, ...]

Metadata

metadata = NightcrawlerSwift::Metadata.new
metadata.execute "my_file.css"
# {
#   :date=>"Tue, 31 Mar 2015 01:46:10 GMT",
#   :content_type=>"text/css",
#   :content_length=>"50013",
#   :last_modified=>"Wed, 15 Oct 2014 13:38:56 GMT",
#   :etag=>"e13839c545f32be23b942a41f3ea7724",
#   :x_timestamp=>"1413380335.38118",
#   :cache_control=>"public, max-age=604800",
#   :x_trans_id=>"tx92ca1becd1a74fa3ae1f2-005519fc62"
# }

# Consulting the bucket/container metadata
metadata.execute
# {
#   :date=>"Tue, 31 Mar 2015 01:41:25 GMT",
#   :content_type=>"application/xml; charset=utf-8",
#   :content_length=>"98171",
#   :x_container_object_count=>"374",
#   :x_storage_policy=>"default-3x",
#   :x_container_read=>".r:*",
#   :x_container_bytes_used=>"7171468",
#   :x_timestamp=>"1409750420.36261",
#   :x_trans_id=>"tx17d8c66ab746436b8b7b6-005519fb40"
# }

Delete

delete = NightcrawlerSwift::Delete.new
delete.execute "my_file_path.txt"
# true / false

Sync

sync = NightcrawlerSwift::Sync.new
sync.execute "/dir/to/synchronize"

Connection

To manually establish the connection with keystone, use:

NightcrawlerSwift.connection.connect!

To check if the connection is still valid, use:

NightcrawlerSwift.connection.connected?

To reconnect just use NightcrawlerSwift.connection.connect! again.

Options

After configure the NightcrawlerSwift you can access your configurations through the options method, like:

NightcrawlerSwift.options

The only difference is that you will access each configuration as a method instead of a hash style, like:

NightcrawlerSwift.configure tenant_name: "rogue"

# Can be used as:
NightcrawlerSwift.options.tenant_name # "rogue"

Contributing

  1. Fork it ( https://github.com/tulios/nightcrawler_swift/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request