The project is in a healthy, maintained state
The remote_translation_loader gem allows you to fetch YAML translation files from remote sources and dynamically load them into your Rails application’s I18n translations without writing them to local files.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 1.14.5
~> 3.13.0

Runtime

~> 5.0
= 0.3.0
 Project Readme

RemoteTranslationLoader

RemoteTranslationLoader is a Ruby gem designed to dynamically fetch and load translation files (YAML format) into your Ruby or Ruby on Rails application. It supports multiple sources such as HTTP URLs, local files, and AWS S3, allowing you to seamlessly integrate external translations.


Features

  • Fetch translations from multiple sources:
    • HTTP URLs
    • Local files
    • AWS S3 buckets
  • Supports deep merging of translations with existing I18n backend.
  • Namespace support for isolating translations.
  • Dry-run mode to simulate translation loading.
  • Rake tasks for easy integration with Rails applications.
  • CLI tool for manual loading.

Installation

Add this line to your application's Gemfile:

gem 'remote_translation_loader'

And then execute:

bundle install

Or install it directly:

gem install remote_translation_loader

Usage

Basic Usage

1. HTTP Fetching

require 'remote_translation_loader'

urls = ['https://example.com/en.yml', 'https://example.com/fr.yml']
loader = RemoteTranslationLoader::Loader.new(urls)
loader.fetch_and_load

2. Local File Fetching

require 'remote_translation_loader'

files = ['/path/to/local/en.yml', '/path/to/local/fr.yml']
loader = RemoteTranslationLoader::Loader.new(files, fetcher: RemoteTranslationLoader::Fetchers::FileFetcher.new)
loader.fetch_and_load

3. AWS S3 Fetching

require 'remote_translation_loader'

bucket = 'your-s3-bucket'
s3_fetcher = RemoteTranslationLoader::Fetchers::S3Fetcher.new(bucket, region: 'us-east-1')
keys = ['translations/en.yml', 'translations/fr.yml']

loader = RemoteTranslationLoader::Loader.new(keys, fetcher: s3_fetcher)
loader.fetch_and_load

Advanced Options

Namespace Support

Add a namespace to group translations under a specific key:

loader.fetch_and_load(namespace: 'remote')
# Translations will be grouped under the `remote` key, e.g., `remote.en.some_key`

Dry-Run Mode

Simulate the loading process without modifying the I18n backend:

loader.fetch_and_load(dry_run: true)
# Outputs fetched translations to the console without loading them

CLI Usage

Install the gem globally and use the CLI tool:

remote_translation_loader https://example.com/en.yml /path/to/local/fr.yml
  • The CLI fetches and loads the specified translations.
  • Add the executable to your $PATH for easier access.

Rails Integration

1. Rake Task

Use the provided Rake task to fetch translations in a Rails application:

Add this to your Rakefile:

require 'remote_translation_loader'
load 'remote_translation_loader/tasks/remote_translation_loader.rake'

Run the task:

rake translations:load[https://example.com/en.yml,/path/to/local/fr.yml]

2. Automatic Loading

Add an initializer to load translations on application startup:

config/initializers/remote_translation_loader.rb

require 'remote_translation_loader'

urls = ['https://example.com/en.yml', '/path/to/local/fr.yml']
loader = RemoteTranslationLoader::Loader.new(urls)
loader.fetch_and_load(namespace: 'remote')

Contributing

We welcome contributions! Follow these steps:

  1. Fork the repository.
  2. Create your feature branch:
    git checkout -b feature/my-new-feature
  3. Commit your changes:
    git commit -m 'Add some feature'
  4. Push the branch:
    git push origin feature/my-new-feature
  5. Create a pull request.

Development

To work on the gem locally:

  1. Clone the repository:
    git clone https://github.com/gklsan/remote_translation_loader.git
    cd remote_translation_loader
  2. Install dependencies:
    bundle install
  3. Run tests:
    rspec

License

This gem is released under the MIT License. See the LICENSE file for details.


Acknowledgments

A big thanks to the open-source community for the inspiration and support. Special mention to contributors who helped shape this gem!


For questions, bug reports, or feature requests, feel free to open an issue. 🚀