# Crowdin::API A Ruby interface to the Crowdin API. For more about the Crowdin API see . > **WARNING**: This is a development version: It contains the latest changes, but may also have severe known issues, including crashes and data loss situations. In fact, it may not work at all. ## Installation Add this line to your application's Gemfile: ``` gem 'crowdin-api' ``` And then execute: ``` $ bundle ``` Or install it yourself as: ``` $ gem install crowdin-api ``` ## Usage Start by creating a connection to Crowdin with your credentials: Please note that almost all API calls require the `Project Identifier` and `Project API Key`. ```ruby require 'crowdin-api' require 'logger' crowdin = Crowdin::API.new(api_key: API_KEY, project_id: PROJECT_ID) crowdin.log = Logger.new $stderr ``` As well there are several API methods (`get_projects`, `create_project`) that require `User API Key` instead of regular `Project API Key`. ```ruby crowdin = Crowdin::API.new(account_key: ACCOUNT_KEY) ``` Now you can make requests to the api. ### Add File Add new file to Crowdin project. Documentation: . First parameter is array of files that should be added to Crowdin project. Every file is hash: * `:dest` - file name with path in Crowdin project (required) * `:source` - file that should be added (required) * `:title` - string that defines title for uploaded file (optional) * `:export_pattern` - string that defines name of resulted file (optional) **NOTE!** 20 files max are allowed to upload per one time file transfer. ```ruby crowdin.add_file( files = [ { dest: '/directory/array.xml', source: 'array.xml', export_pattern: '/values-%two_letters_code%/%original_file_name%' }, { dest: 'strings.xml', source: 'strings.xml', title: 'Texts in Application' } ], type: 'android') ``` ### Update File Upload fresh version of your localization file. Documentation First parameter is array of files that should be updated in Crowdin project. Every file is hash: * `:dest` - file name with path in Crowdin project (required) * `:source` - uploaded file (required) * `:title` - title for uploaded file (optional) * `:export_pattern` - string that defines name of resulted file (optional) **NOTE!** 20 files max are allowed to upload per one time file transfer. ```ruby crowdin.update_file( files = [ { :dest => '/directory/array.xml', :source => 'array.xml', :export_pattern => '/values-%two_letters_code%/%original_file_name%'}, { :dest => 'strings.xml', :source => 'strings.xml' } ]) ``` ### Delete File Remove file from Crowdin project. Documentation ```ruby crowdin.delete_file('strings.xml') ``` ### Create Directory Create a new directory in Crowdin project. Documentation: ```ruby crowdin.add_directory('dirname') ``` ### Delete Directory Remove directory with nested files from Crowdin project. Documentation: ```ruby crowdin.delete_directory('dirname') ``` ### Change Directory Rename or change directory attributes. Documentation: First parameter `name` - full directory path that should be modified (e.g. /MainPage/AboutUs) (required) Optional params: * `:new_name` - new directory name * `:title` - new directory title to be displayed in Crowdin UI * `:export_pattern` - new direcrory export pattern. Is used to create directory name and path in resulted translations bundle. When renaming directory the path can not be changed (it means `new_name` parameter can not contain path, name only). ```ruby crowdin.change_directory('/MainPage/AboutUs', new_name: 'AboutCompany') ``` ### Upload Translations Upload existing translations to your Crowdin project. Documentation: First parameter is array of translated files that should be added to Crowdin project. Every file is hash: * `:dest` - file names in Crowdin (required) * `:source` - uploaded translation (required) Second parameter is target language. With a single call it's possible to upload translations for several files but only into one of the languages. Check [complete list of Crowdin language codes](https://crowdin.com/page/api/language-codes) that can be used. Optional params: * `:import_duplicates` - defines whether to add translation if there is the same translation previously added (default: false) * `:import_eq_suggestions` - defines whether to add translation if it is equal to source string at Crowdin (default: false) * `:auto_approve_imported` - mark uploaded translations as approved (default: false) **NOTE!** 20 files max are allowed to upload per one time file transfer. ```ruby crowdin.upload_translation( files = [ { :dest => 'strings.xml', :source => 'strings_uk.xml' }, { :dest => 'array.xml', :source => 'array_uk.xml' } ], language = 'uk', params = {:import_duplicates => true} ) ``` ### Download Translations Download last exported translation package (one target language or all languages as one zip file). Documentation: First parameter is the language of translation you need or download `all` of them at once. ```ruby crowdin.download_translation('ru', :output => '/path/to/download/ru_RU.zip') ``` ### Translation Status Track overall translation and proofreading progress of each target language. Documentation: ```ruby crowdin.translations_status ``` ### Project Info Shows project details and meta information (last translations date, currently uploaded files, target languages etc..). Documentation: ```ruby crowdin.project_info ``` ### Export Translations Build ZIP archive with the latest translations. **Note!** This method can be invoked only once per 30 minutes (there is no such restriction for organization plans). Also API call will be ignored if there were no changes in the project since previous export. You can see whether ZIP archive with latest translations was actually build by status attribute (`built` or `skipped`) returned in response. Documentation: ```ruby crowdin.export_translations ``` ### Account Projects Get Crowdin Project details. **Important:** This API method requires `Account API Key`. This key can not be found on your profile pages. Documentation: ```ruby crowdin = Crowdin::API.new(account_key: ACCOUNT_KEY) crowdin.get_projects(login = 'YourCrowdinAccount') ``` ### Create Project Create Crowdin project. **Important:** This API method requires `Account API Key`. This key can not be found on your profile pages. Documentation: ### Edit Project Documentation: ### Delete Project Documentation: ### Download Glossary Documentation: ### Upload Glossary Documentation: ### Download TM Documentation: ### Upload TM Documentation: ### Supported Languages Documentation: ## Supported Rubies Tested with the following Ruby versions: - MRI 2.2.1 - JRuby 9.0.0.0.pre2 ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Added some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create new Pull Request ## License and Author Author: Anton Maminov (anton.maminov@gmail.com) Copyright: 2012-2015 [crowdin.com](https://crowdin.com/) This library is distributed under the MIT license. Please see the LICENSE file.