Class: DeeplAPI::DeepL
- Inherits:
-
Object
- Object
- DeeplAPI::DeepL
- Defined in:
- lib/deepl_api.rb
Overview
The main API entry point representing a DeepL developer account with an associated API key.
Use this to create a new DeepL API client instance where multiple function calls can be performed. A valid ‘api_key` is required.
Should you ever need to use more than one DeepL account in our program, then you can create one instance for each account / API key.
##Error Handling
These methods may throw exceptions from DeeplAPI::Errors and ‘Net::HTTP`.
Instance Method Summary collapse
-
#initialize(api_key:) ⇒ DeepL
constructor
Create an instance by providing a valid API key.
-
#source_languages ⇒ Object
Retrieve all currently available source languages.
-
#target_languages ⇒ Object
Retrieve all currently available target languages.
-
#translate(source_language: nil, target_language:, split_sentences: nil, preserve_formatting: true, formality: Formality::DEFAULT, texts:) ⇒ Object
Translate one or more text chunks at once.
-
#usage_information ⇒ Object
Retrieve information about API usage & limits.
Constructor Details
#initialize(api_key:) ⇒ DeepL
Create an instance by providing a valid API key.
55 56 57 58 59 60 61 |
# File 'lib/deepl_api.rb', line 55 def initialize(api_key:) @api_key = api_key.to_s @api_base_url = @api_key[-3, 3].eql?(":fx") ? "https://api-free.deepl.com/v2" : "https://api.deepl.com/v2" return unless @api_key.empty? raise DeeplAPI::Errors::DeeplAuthorizationError, "No API key provided." end |
Instance Method Details
#source_languages ⇒ Object
Retrieve all currently available source languages.
See also the [vendor documentation](www.deepl.com/docs-api/other-functions/listing-supported-languages/).
Returns a dictionary like: ‘=> “German”, …`
82 83 84 |
# File 'lib/deepl_api.rb', line 82 def source_languages languages(type: "source") end |
#target_languages ⇒ Object
Retrieve all currently available target languages.
See also the [vendor documentation](www.deepl.com/docs-api/other-functions/listing-supported-languages/).
Returns a dictionary like: ‘=> “German”, …`
91 92 93 |
# File 'lib/deepl_api.rb', line 91 def target_languages languages(type: "target") end |
#translate(source_language: nil, target_language:, split_sentences: nil, preserve_formatting: true, formality: Formality::DEFAULT, texts:) ⇒ Object
Translate one or more text chunks at once. You can pass in optional translation options if you need non-default behaviour.
Please see the parameter documentation and the [vendor documentation](www.deepl.com/docs-api/translating-text/) for details.
Returns a list of dictionaries for the translated content:
“‘ruby [
{
"detected_source_language" => "DE",
"text" => "Yes. No.",
},
...
] “‘
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 |
# File 'lib/deepl_api.rb', line 114 def translate( source_language: nil, target_language:, split_sentences: nil, preserve_formatting: true, formality: Formality::DEFAULT, texts: ) # rubocop:enable Metrics/ParameterLists, Style/KeywordParametersOrder payload = { target_lang: target_language, text: texts } payload[:source_lang] = source_language unless source_language.nil? payload[:split_sentences] = split_sentences unless split_sentences.nil? payload[:preserve_formatting] = preserve_formatting unless preserve_formatting.nil? payload[:formality] = formality unless formality.nil? data = api_call(url: "/translate", payload: payload) raise DeeplAPI::Errors::DeeplDeserializationError unless data.include?("translations") data["translations"] end |
#usage_information ⇒ Object
Retrieve information about API usage & limits. This can also be used to verify an API key without consuming translation contingent.
Returns a DeeplAPI::UsageInformation object.
See also the [vendor documentation](www.deepl.com/docs-api/other-functions/monitoring-usage/).
69 70 71 72 73 74 75 |
# File 'lib/deepl_api.rb', line 69 def usage_information data = api_call(url: "/usage") UsageInformation.new( character_count: data["character_count"], character_limit: data["character_limit"] ) end |