# Available Ruby methods
Workato implements a subset of Ruby's public instance methods within its SDK framework. This document lists the Ruby methods that are available when building your connectors. You can request to add additional methods to this list using the Workato feedback widget (opens new window).
PERSONAL REUSABLE METHODS
You can declare personal reusable methods to use in any block when using Workato SDK.
# at
Creates a new time object with the given argument.
See at (opens new window) method definition.
# abs
Returns the absolute value of a number.
# account_property
Returns the value for a specific account property in the user's workspace.
client_secret = account_property('hubspot_webhook_client_secret')
Note that you can only invoke this method from the following lambdas within the connection
hash:
authorization_url
token_url
acquire
base_uri
Also, other lambdas within actions
, triggers
, methods
, object_definitions
, and pick_lists
.
# aes_cbc_encrypt
AES encryption with CBC mode. Accepts 128, 192, and 256-bit keys.
key128 = workato.pbkdf2_hmac_sha1("password", workato.random_bytes(8))
workato.aes_cbc_encrypt("text_to_encrypt", key128)
# aes_cbc_decrypt
AES decryption with CBC mode. Accepts 128, 192, and 256-bit keys.
workato.aes_cbc_decrypt("text_to_decrypt", key128)
# aes_gcm_encrypt
Returns an AES encrypted string and auth tag using GCM mode. The initialization vector (IV) key size must be 12 bytes. Accepts 128, 192, and 256-bit keys.
# Generate a salt for key derivation
salt = workato.random_bytes(8)
# Derive a key using PBKDF2 with HMAC-SHA1
key128 = workato.pbkdf2_hmac_sha1("password", salt)
# Initialize an IV (initialization vector)
iv = "init_vector0"
# Encrypt the text
encrypted_data = workato.aes_gcm_encrypt("text_to_encrypt", key128, iv) # [0x3040ffe9e51d4a929605fe0a262eea, 0x0f7e0a05eb25512c03ffafca43418a12]
You can also provide auth_data
, which accepts a string value:
auth_data = "my_auth_data"
# Generate a salt for key derivation
salt = workato.random_bytes(8)
# Derive a key using PBKDF2 with HMAC-SHA1
key128 = workato.pbkdf2_hmac_sha1("password", salt)
# Initialize an IV (initialization vector)
iv = "init_vector0"
# Encrypt the text
encrypted_data = workato.aes_gcm_encrypt("text_to_encrypt", key128, iv, auth_data) # [0x3040ffe9e51d4a929605fe0a262eea, 0x0f7e0a05eb25512c03ffafca43418a12]
The result is an array in the form [encrypted_string, auth_tag]
. Use the .first
and .last
formulas to retrieve these values individually.
# aes_gcm_decrypt
Returns an AES decrypted string using GCM mode. The initialization vector (IV) key size must be 12 bytes. Accepts 128, 192, and 256-bit keys.
decrypted_string = workato.aes_gcm_decrypt(encrypted_string, key128, auth_tag, iv) # 0x746578745f746f5f656e6372797074
If you encrypted with auth_data
, you must include it in the formula:
decrypted_string = workato.aes_gcm_decrypt(encrypted_string, key128, auth_tag, iv, auth_data) # 0x746578745f746f5f656e6372797074
The output is a raw byte sequence in hexadecimal format. You can append the .as_utf8
formula to decode it into a UTF-8 string:
decrypted_string = workato.aes_gcm_decrypt(encrypted_string, key128, auth_tag, iv, auth_data).as_utf8 # "text_to_encrypt"
# after_error_response
Can be chained with an HTTP request to rescue a failed request. See Error handling.
# after_response
Can be chained with an HTTP request to utilize the response's headers, and so on. See Error handling.
# ago
Go back in time. Returns timestamp.
2.days.ago #2017-01-15T12:30:00.000000-07:00 if time now is 2017-01-17T12:30:00.000000-07:00
30.minutes.ago #2017-01-15T12:30:00.000000-07:00 if time now is 2017-01-15T13:00:00.000000-07:00
30.seconds.ago #2017-01-15T12:30:00.000000-07:00 if time now is 2017-01-15T12:30:30.000000-07:00
See ago (opens new window) method definition.
# all?
Passes each element of the collection to the given block. The method returns true if the block never returns false or nil.
%w[ant bear cat].all? { |word| word.length >= 3 } #=> true
See all? method definition.
# as_string
Decode byte sequence as a string in the given encoding.
"0J/RgNC40LLQtdGC\n".decode_base64.as_string('utf-8')
# as_utf8
Decode byte sequence as a UTF-8 string.
"0J/RgNC40LLQtdGC\n".decode_base64.as_utf8
# aws.generate_signature
Generates an AWS V4 Signature for AWS services and returns a hash that contains the URL and signature for you to formulate the request.
aws.generate_signature(
connection: connection,
service: "s3",
region: connection["aws_region"],
host: "s3.dualstack.#{connection['aws_region']}.amazonaws.com",
method: "GET",
path: "/demo",
params: {
"list-type": 2,
"max-keys": 1000
}.compact,
headers: {
Test: "hello!"
},
payload: {
hello: "world"
}.to_json
)
See AWS authentication.
# blank?
Returns true if value is null or an empty string, otherwise false.
# binary?
Returns true if value is a binary array.
# beginning_of_hour
Returns timestamp for top-of-the-hour for given timestamp.
"2017-06-01T16:56:00.000000-07:00".to_time.beginning_of_hour #2017-06-01T16:00:00.000000 +0000
# beginning_of_day
Returns timestamp for midnight for given timestamp.
"2017-06-08T22:30:10.000000-07:00".to_time.beginning_of_day #2017-06-08T00:00:00.000000 +0000
# beginning_of_week
Returns timestamp for midnight at the start of the week (Mon) for the given timestamp.
"2017-08-18T00:00:00.000000-07:00".to_time.beginning_of_week #2017-08-14T00:00:00.000000 +0000
# beginning_of_month
Returns timestamp for midnight for the start of the month for the given timestamp.
"2017-01-30T22:35:00.000000-07:00".to_time.beginning_of_month #2017-01-01T00:00:00.000000 +0000
# beginning_of_year
Returns timestamp for midnight for the start of the year for a given timestamp.
"2017-01-30T22:35:00.000000 -07:00".to_time.beginning_of_year #2017-01-01T00:00:00.000000 +0000
# bytes
Returns an array of bytes for a given string.
"Hello".bytes # ["72","101","108","108","111"]
# bytesize
Returns the length of a given string in bytes.
"Hello".bytesize # 5
# byteslice
Returns a substring of specified bytes instead of length. In some cases, non-ASCII characters (for example, Japanese and Chinese characters) may use multiple bytes.
"abc漢字".byeslice(0,4) # "abc漢"
See byteslice (opens new window) method definition.
# capitalize
Capitalizes the first character of the string.
# case_sensitive_headers
Can be chained with HTTP methods to introduce headers that are case-sensitive. By default, Workato does not respect case sensitivity for headers, as per RFC specification.
get("https://www.example.com").case_sensitive_headers("HeLlo": "world")
# checkpoint!
Similar to reinvoke_after
, the checkpoint!
method is used with file stream consuming actions. When invoked, Workato checks the duration of the action's execution. If it exceeds 120 seconds, Workato refreshes the action level timeout with a slight delay to ensure fair processing.
This allows you to transfer files that exceed the current 180-second timeout limit.
# chunk
Enumerates over the items, chunking them together based on the return value of the block.
See chunk (opens new window) method definition.
# chunk_while
Creates an enumerator for each chunked element. The beginnings of chunks are defined by the block.
See chunk_while (opens new window) method definition.
# collect
Returns a new array with the results of running block once for every element in enum.
See collect (opens new window) method definition.
# collect_concat
Returns a new array with the concatenated results of running block once for every element in enum.
See collect_concat (opens new window) method definition.
# compact
Returns a hash with non nil values.
See compact (opens new window) method definition.
# count
Returns the number of elements in an array that match the given value.
["apple", "orange", "apple", "banana", "apple"].count("apple")
For more details, refer to the count (opens new window) method definition.
# csv.parse
Allows you to parse a CSV string into a JSON array that makes it easy to display as data pills.
workato.csv.parse("blue;1\nwhite;2\n", headers: "color;count", col_sep: ";")
Takes seven arguments:
string
The first position of the method which represents the CSV string to parse.
headers
Either
true
(First row of actual CSV will be used as headers),array
ofstring
(corresponding to each column header) orstring
(Artificial first row of the CSV with appropriate column separator).col_sep
The column separator in the CSV. Defaults to
,
.row_sep
The row separator in the CSV. Defaults to
\n
.quote_char
The quoting character in the CSV. Defaults to double quotes
"
.skip_blanks
Boolean that indicates whether blank lines in the string input should be ignored. Defaults to false.
skip_first_line
Boolean that indicates if we should skip the first line. Useful when
headers
is true.
Limits: File size must be less than 30 MB and CSV lines fewer than 65K.
# csv.generate
Allows you to generate a CSV string from a JSON array so you can send it to a downstream system as a file.
workato.csv.generate(headers: ["color", "amount"], col_sep: ";") do |csv|
csv << [:blue, 1]
csv << [:white, 2]
end
Takes five arguments:
headers
Either
true
(First row of actual CSV will be used as headers),array
ofstring
(corresponding to each column header) orstring
(Artificial first row of the CSV with appropriate column separator).col_sep
The column separator in the CSV. Defaults to
,
.row_sep
The row separator in the CSV. Defaults to
\n
.quote_char
The quoting character in the CSV. Defaults to double quotes
"
.force_quotes
Boolean that determines whether each output field should be quoted.
Finally, one lambda that allows you to append individual rows to this CSV as an array of strings.
# cycle
Cycles through an array for a specified number of times and calls a block for each element.
See cycle (opens new window) method definition.
# decode_base64
Decode using Base64 algorithm.
# decode_hex
Decode hexadecimal into binary string.
# decode_url
URL decode a string. This formula uses CGI.unescape
to URL decoding.
# decode_urlsafe_base64
Decode using URL-safe modification of Base64 algorithm.
# decrypt
Decrypt the encrypted string using AES-256-CBC algorithm. Input should be in RNCryptor V3 format.
This method returns a byte array instead of a string. You can convert the decrypt method output to a string by appending the .as_string()
or .as_utf8
function to your formula.
# deep_merge
Merges a hash with another hash, including nested child hashes.
See deep_merge (opens new window) method definition.
# delete_at
Delete elements in an array.
See delete_at (opens new window) method definition.
# detect
Passes each element in an array to a block. Returns the first element that satisfies a block.
See detect (opens new window) method definition.
# dig
Retrieves the value object corresponding to the index passed in.
The dig
method is often used to strip away layers in nested arrays/hashes. For example, we use the dig
method often when dealing with XML data formats.
See dig (opens new window) method definition.
# drop
Drops first N elements from an Enumerator and returns the rest of the elements in an array.
[1, 2, 3, 4, 5, 0].drop(3) #=> [4, 5, 0]
See drop (opens new window) method definition.
# drop_while
Drops elements up to, but not including, the first element of an array for which the block returns nil or false.
See drop_while (opens new window) method definition.
# dst?
Returns true if the time is within Daylight Savings Time for the specified time zone.
# each
Basic iterator.
[1, 2, 3].each { |i| puts i }
# each_byte
Passes each byte in a given string to the given block, or returns an enumerator if no block is given.
See each_byte (opens new window) method definition.
# each_char
Passes each character in a given string to the given block. Returns an enumerator if no block is given.
See each_char (opens new window) method definition.
# each_cons
Iterates the given block for each array of consecutive N elements. If no block is given, returns an enumerator.
See each_cons (opens new window) method definition.
# each_entry
Iterates over an array and returns each element in the block.
See each_entry (opens new window) method definition.
# each_slice
Iterates the given block for each slice of N elements. If no block is given, returns an enumerator.
See each_slice (opens new window) method definition.
# each_with_index
Iterator returned with an index.
[1, 2, 3].each_with_index { |item, index| puts "#{index}:#{item}" }
See each_with_index (opens new window) method definition.
# each_with_object
Iterator returned with an object which you can define.
[%w(foo bar)].each_with_object({}) { |str, hsh| hsh[str] = str.upcase }
# => {'foo' => 'FOO', 'bar' => 'BAR'}
See each_with_object (opens new window) method definition.
# encode_hex
Converts binary string to its hex representation.
"0J/RgNC40LLQtdGC\n".decode_base64.encode_hex
# encode_sha256
Encode using SHA256 algorithm. The output is a binary string. Use encode_hex
to convert to a hex representation.
"hello".encode_sha256 #=> 0x2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824
"hello".encode_sha256.encode_hex #=> 2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824
# encode_sha512
Encode using SHA512 algorithm. The output is a binary string. Use encode_hex
to convert to a hex representation.
"hello".encode_sha512 #=> 0x9b71d224bd62f3785d96d46ad3ea3d73319bfbc2890caadae2dff72519673ca72323c3d99ba5c11d7c7acc6e14b8c5da0c4663475c2e5c3adef46f73bcdec043
"hello".encode_sha512.encode_hex #=> 9b71d224bd62f3785d96d46ad3ea3d73319bfbc2890caadae2dff72519673ca72323c3d99ba5c11d7c7acc6e14b8c5da0c4663475c2e5c3adef46f73bcdec043
# encode_base64
Encode using Base64 algorithm.
# encode_url
URL encode a string.
'Hello World'.encode_url # 'Hello%20World'
# encode_urlsafe_base64
Encode using URL-safe modification of Base64 algorithm.
# encode_www_form
Join hash into URL-encoded string of parameters.
{"apple" => "red green", "2" => "3"}.encode_www_form #"apple=red+green&2=3"
# ends_of_month
Returns a new date/time representing the end of the month.
"2017-08-18T00:00:00".to_time.end_of_month #2017-08-31 23:59:59 +0000
# ends_with?
Returns true if string ends with a specific pattern. False otherwise.
"Hello!".ends_with?("!") #true
# entries
Returns an array containing the items in enum.
(1..7).entries #=> [1, 2, 3, 4, 5, 6, 7]
{ 'a'=>1, 'b'=>2, 'c'=>3 }.entries #=> [["a", 1], ["b", 2], ["c", 3]]
See entries (opens new window) method definition.
# error
Raise a job error with a user-defined error body.
error("Unable to find Account with ID: 123")
# even?
Returns true if integer is an even number.
See even? (opens new window) method definition.
# except
Returns a hash that includes everything except given keys.
{ name: "Jake", last_name: "Paul", age: "22" }.except(:name, :last_name) # { :age => "22" }
See except (opens new window) method definition.
# exclude?
Returns true if field does not contain a value. Case sensitive.
"Partner account".exclude?("Partner") #false
See exclude (opens new window) method definition.
# execution_context
RESTRICTED METHOD AVAILABILITY
This method is available only to connectors built within Embedded partner workspaces. It returns a hash containing the context of the recipe and job from which this action or trigger is invoked. In situations where there is no applicable context — for example, the job handle when the request is sent in a trigger — the key's value is null.
The following table summarizes the lambdas: execution_context
return values:
Key | recipe_id | job_handle |
---|---|---|
execute | Yes | Yes |
methods (For each method called within execute) | Yes | Yes |
apply (For requests sent in the execute lambda) | Yes | Yes |
poll | Yes | No |
methods (For each method called within poll) | Yes | No |
apply (For requests sent in the poll lambda) | Yes | No |
object_definitions (For each fields method defined) | No | No |
pick_lists (For each pick_list method defined) | No | No |
methods (For each method called within pick_lists or object_definitions) | No | No |
You can reference the execution context using the execution_context
method.
execution_context #=> { :recipe_id => "1234" }
execution_context[:recipe_id] #=> "1234"
execution_context[:job_handle] #=> "j-12fsfdsakn1"
# fetch
Returns a value from the hash for the given key.
See fetch (opens new window) method definition.
# find_all
Returns an array containing all elements of a hash or array that satisfy the condition denoted in the block.
Foo = { :abc => 1, :bad => [1,2] }
Foo.find_all { |i| i[0] == :abc } # [[:abc, 1]]
See find_all (opens new window) method definition.
# find_index
Compares each element in an array to a given block and returns the index for the first match.
(1..100).find_index { |i| i % 5 == 0 and i % 7 == 0 } #=> 34
See find_index (opens new window) method definition.
# first
Returns the first item in a list. Can also be used to return the first n items in a list.
See first (opens new window) method definition.
# flatten
Flatten multi-dimensional array to simple array.
[[1, 2, 3],[4,5,6]].flatten #[1, 2, 3, 4, 5, 6]
See flatten (opens new window) method definition.
# flat_map
Returns a new array with the concatenated results of running block once for every element in enum.
[[1, 2], [3, 4]].flat_map { |e| e + [100] } #=> [1, 2, 100, 3, 4, 100]
See flat_map (opens new window) method definition.
# follow_redirection
By default, we follow most 3XX redirect HTTP codes. In some cases, you may need to apply this to follow the redirect for any response code.
action_with_follow_redirection: {
execute: lambda do |_connection, _input|
get('https://run.mocky.io/v3/41abc094-6b10-41a9-8201-b15146258b12').follow_redirection.after_response do |code, body, headers|
{
code: code,
body: body,
headers: headers
}
end
end
}
# format_json
Convert request to JSON format and expect response body in JSON format.
# format_map
Create an array of strings by formatting each row of given array.
[[{name: 'Jake', age: 23}].format_map('Name: %{name}, Age: %{age}') #['Name: Jake, Age: 23']
[[22, 45], [33, 88]].format_map('Id: %s, Count: %s') #['Id: 22, Count: 45', 'Id: 33, Count: 88']
See format_map (opens new window) method definition.
# format_xml
Convert request to XML format and expect response body in XML format.
Takes three arguments:
root_element_name
Adds a root element tag to your outgoing XML payload.
namespaces
Adds additional tags to your payload for namespaces.
strip_response_namespaces
Strips namespaces from XML responses.
# from_now
Go forward in time. Returns timestamp of the moment that the formula was executed, with the specified time period added in Pacific Time (UTC-8/UTC-7).
4.months.from_now #2017-05-23T14:40:07.338328-07:00
2.days.from_now #2017-01-05T14:40:07.338328-07:00
30.minutes.from_now
12.seconds.from_now
# from_xml
Converts XML string to hash.
"<?xml version="1.0" encoding="UTF-8"?> <hash><foo type="integer"></foo></hash>".from_xml # { "hash": [ "foo": [ { "@type": "integer", "content!": "1" } ] ] }
# grep
Searches through an enumerator for every element that satisfies your condition.
See grep (opens new window) method definition.
# grep_v
Searches through an enumerator for every element that does not satisfy your condition.
See grep_v (opens new window) method definition.
# group_by
Group arrays into sets.
See group_by (opens new window) method definition.
# gsub
Substitute a pattern with value. Case sensitive.
"Jean Marie".gsub(/J/, "M") #"Mean Marie"
See gsub (opens new window) method definition.
# has_key?
Returns true if the given key is present in hash.
See has_key? (opens new window) method definition.
# headers
Add headers to a request.
.headers(Authorization: "Bearer HTB674HJK1")
# hmac_md5
Creates HMAC_MD5 signature.
"username:password:nonce".hmac_md5("key")
# hmac_sha1
Creates HMAC_SHA1 signature.
"username:password:nonce".hmac_sha1("key")
# hmac_sha256
Creates HMAC_SHA256 signature.
"username:password:nonce".hmac_sha256("key")
# hmac_sha512
Creates HMAC_SHA512 signature.
"username:password:nonce".hmac_sha512("key")
# ignore_redirection
Allows you to stop a request from being redirected immediately. Commonly used in cases where your requests are redirected to a secondary site like AWS S3 to download a file. You will need to strip any authentication used in the apply: key using "current_url".
action_with_ignore_redirection: {
execute: lambda do |_connection, _input|
get('https://run.mocky.io/v3/41abc094-6b10-41a9-8201-b15146258b12').ignore_redirection.after_response do |code, body, headers|
{
code: code,
body: body,
headers: headers
}
end
end
},
# ignored
Ignore a comma-separate list of fields.
object_definition["user"].ignored("id", "created_at")
# include?
Returns true if field contains a value. False otherwise.
See include? (opens new window) method definition.
# inject
Combine elements in an array using an operation.
See inject (opens new window) method definition.
# insert
Insert elements into an array.
See insert (opens new window) method definition.
# in_time_zone
Converts the time to given time zone.
"2017-09-06T18:30:15.671720-05:00".to_time.in_time_zone("America/Los_Angeles") #"2017-09-06T16:30:15.671720-07:00"
# is_a?
Returns true if class is the class of obj, or if class is one of the superclasses of obj or modules included in obj.
Workato currently supports the following classes:
- Array
- Hash
- Time
- String
- Integer
- Float
See is_a? (opens new window) method definition.
# is_true?
Converts a value to boolean and returns true if value is truthy.
# is_not_true?
Converts a value to boolean and returns true if value is not truthy.
# iso8601
Convert a date/date-time variable to ISO8601 format.
# join
Join array elements into a string.
See join (opens new window) method definition.
# jwt_decode
Decodes a JSON web token (JWT) using one of the following algorithms:
- RS256
- RS384
- RS512
- HS256
- HS384
- HS512
- ES256
- ES384
- ES512
workato.jwt_decode( "eyJhbGciO...", "PEM key", \'RS256\') # => {"payload" => {"sub"=>"123", "name"=>"John", ...}, "header" => {"typ"=>"JWT", "alg"=>"RS256"}}
workato.jwt_decode( "eyJhbGciO...", "PEM key", \'RS512\') # => {"payload" => {"sub"=>"123", "name"=>"John", ...}, "header" => {"typ"=>"JWT", "alg"=>"RS512"}}
workato.jwt_decode( "eyJhbGciO...", "my$ecretK3y", \'HS256\') # => {"payload" => {"sub"=>"123", "name"=>"John", ...}, "header" => {"typ"=>"JWT", "alg"=>"HS256"}}
# jwt_encode
Creates a JSON web token (JWT) using one of the following algorithms:
- RS256
- RS384
- RS512
- HS256
- HS384
- HS512
- ES256
- ES384
- ES512
Adds other named parameters to the header, such as kid
in the following example:
workato.jwt_encode({ name: "John Doe" }, "PEM key", 'RS256') # => "eyJhbGciO..."
workato.jwt_encode({ name: "John Doe" }, "PEM key", 'RS512', kid: "24668") #=> "eyJ0eXAiO..."
workato.jwt_encode({ name: "John Doe" }, "my$ecretK3y", 'HS256', kid: "24668") #=> "eyJ0eXAiO..."
workato.jwt_encode({ name: "John Doe" }, "my$ecretK3y", 'HS256') #=> "eyJ0eXAiO..."
workato.jwt_encode({ name: "John Doe" }, "ECDSA Key", 'ES256') #=> "eyJhbGciOiJ..."
# last
Returns the last item in a list. Can also be used to return the last n items in a list.
See last (opens new window) method definition.
# ljust
Aligns strings to the left and pads with whitespace or specified pattern until string is the required length.
" test".ljust(10, "*") # " test*****"
See ljust (opens new window) method definition.
# lookup
Lookup a record from your lookup tables defined in Workato.
lookup('States list', 'State code': 'AZ')['State name'] #"Arizona"
See lookup (opens new window) method definition.
# lstrip
Remove white space from the beginning of string.
" Test ".lstrip #"Test "
See lstrip (opens new window) method definition.
# map
Returns a new array after invoking block on each element.
# md5_hexdigest
Creates message digest using the MD5 Message-Digest Algorithm.
"hello".md5_hexdigest #5d41402abc4b2a76b9719d911017c592
# match?
Returns true if a string contains a pattern. Case sensitive.
"Jean Marie".match?(/Marie/) #true
# max_by
Returns the object in enum that gives the maximum value from the given block.
%w(albatross dog horse).max_by { |x| x.length } # albatross
# member?
Alias of include?
See member? (opens new window) method definition.
# merge
Returns a new hash containing merged contents.
See merge (opens new window) method definition.
# minmax
Returns a two element array which contains the minimum and the maximum value in the enumerable.
a = %w(albatross dog horse)
a.minmax #=> ["albatross", "horse"]
a.minmax { |a, b| a.length <=> b.length }
#=> ["dog", "albatross"]
See minmax (opens new window) method definition.
# minmax_by
Returns a two element array containing the objects in enum that correspond to the minimum and maximum values respectively from the given block.
a = %w(albatross dog horse)
a.minmax_by { |x| x.length } #=> ["dog", "albatross"]
See minmax_by (opens new window) method definition.
# min_by
Returns the object in enum that gives the minimum value from the given block
a = %w(albatross dog horse)
a.min_by { |x| x.length } #=> "dog"
See min_by (opens new window) method definition.
# net.lookup
Lookups specified DNS records for a given host.
workato.net.lookup("www.google.com", "A") # => [{"address": "172.253.122.106"}, {"address":"172.253.122.103"}]
Takes two arguments:
name
The resource name such as the domain or host.
Record Type
Only supports "SRV" or "A" DNS record types
# next
Returns the next object in the enumerator, and move the internal position forward.
This is often used in config_fields where you can use next
as a way to add a guard clause that checks inputs before the lambda function is executed.
object_definitions: {
document: {
fields: lambda do |connection, config_fields, object_definitions|
next [] if config_fields.blank?
get("https://www.webmerge.me/api/documents/#{config_fields["document_id"]}/fields").map {
|field| field.slice("name")
}
end
}
}
See next (opens new window) method definition.
# none?
Passes each element of the collection to the given block. The method returns true if the block never returns true for all elements.
%w{ant bear cat}.none? { |word| word.length == 5 } #=> true
See none? (opens new window) method definition.
# now
Returns timestamp of the moment that the formula was executed in Pacific Time (UTC-8/UTC-7).
now #2017-01-23T14:04:53.365908-08:00
now + 2.days #2017-01-25T14:04:53.365908-08:00
# odd?
Returns true if integer is an odd number. See odd? (opens new window) method definition.
# one?
Passes each element of the collection to the given block. The method returns true if the block returns true exactly once.
[ nil, true, false ].one? #=> true
See one? (opens new window) method definition.
# only
White list a comma-separate of fields.
object_definition["user"].only("id", "name")
# ordinalize
Turns a number into an ordinal string used to denote the position in an ordered sequence such as first, second, third, fourth.
"1".ordinalize # "First"
# pack
Packs contents of an array into a binary sequence.
See pack (opens new window) method definition.
# parallel
Accepts an array of requests and allows you to execute them in multiple threads.
batches = (0..200).map do |batch|
post(url).headers(headers).request_body(payload)
end
results = parallel(batches, threads: 20)
See Multi-threaded actions for more information.
# parameterize
Replaces special characters in a string.
"öüâ".parameterize #"oua"
# params
Add parameter to a request.
.params(api_key: "HTB674HJK1")
# parse_json
Works the same way as json.parse.
See parse_json (opens new window) method definition.
# parse_yaml
Parse a YAML string. Supports true, false, nil, numbers, strings, arrays, hashes.
workato.parse_yaml("---\nfoo: bar") # => { "foo" => "bar" }
# payload
Add payload to a request.
.payload(id: "345")
# pbkdf2_hmac_sha1
Create keys of varying bit lengths using a password and a salt. Uses HMAC Sha1.
key128 = workato.pbkdf2_hmac_sha1("password", workato.random_bytes(8))
key192 = workato.pbkdf2_hmac_sha1("password", workato.random_bytes(8), 1000, 24)
key256 = workato.pbkdf2_hmac_sha1("password", workato.random_bytes(8), 1000, 32)
# pluck
Select one or more attributes from an array of objects.
[
{"id": 1, "name": "David"},
{"id": 2, "name": "Peter"}
].pluck("id")
Returns [1, 2]
.
# pluralize
Returns the plural form of the word in the string.
See pluralize (opens new window) method definition.
# pop
Removes the last element from self and returns it, or nil if the array is empty.
If a number n is given, returns an array of the last n elements (or less) and removes it from array.
a = [ "a", "b", "c", "d" ]
a.pop #=> "d"
a.pop(2) #=> ["b", "c"]
a #=> ["a"]
See pop (opens new window) method definition.
# presence
Returns the value if present. Otherwise returns nil.
nil.presence #nil
"".presence #nil
0.presence #0
See presence (opens new window) method definition.
# present?
Returns true if the field has a value. False otherwise.
nil.present? #false
"".present? #false
0.present? #true
See present? (opens new window) method definition.
# puts
Ruby version of console.log
or stdout
. Not the same as the put
method.
Any output using the puts
method shows up in the console log when testing in the code editor. Use this to aid in your debugging.
# rand
Random number between 0 and 1.
# random_bytes
Generates a specified number of random bytes.
workato.random_bytes(8)
# reduce
Combines all elements of enum by applying a binary operation, specified by a block or a symbol that names a method or operator.
(5..10).reduce { |sum, n| sum + n } # 45
See reduce (opens new window) method definition.
# reinvoke_after
Used in multistep actions that work with asynchronous APIs. Calling this method causes the job to pause for a specific interval before reinvoking the original execute
lambda it is called in. Accepts seconds
to denote how long the job should pause for, and continue
which allows the job to be reinvoked with additional context.
reinvoke_after(
seconds: step_time,
continue: {
current_step: current_step + 1,
jobid: response['jobReference']['jobId']
}
)
See Multistep actions for more information.
# reject
Selectively returns elements for which the block returns false. Similar but opposite of select.
See reject (opens new window) method definition.
# render_yaml
Render an object into a YAML string.
workato.render_yaml({ "foo" => "bar" }) # => "---\nfoo: bar\n"
# response_format_json
Expect response in JSON format.
# response_format_raw
Expect response in raw format. This can be chained after HTTP actions that expect binary data (such as PDFs and images) as responses.
# response_format_xml
Expect response in XML format. Takes 1 argument.
- strip_response_namespaces
- Strips namespaces from XML responses.
# request_format_json
Convert request to JSON format.
# request_format_multipart_form
Convert request to multipart_form format.
# request_format_raw
Convert request to raw format.
# request_format_www_form_urlencoded
Convert request to URL-encoded format.
# request_format_xml
Convert request to XML format.
Takes two arguments:
root_element_name
Adds a root element tag to your outgoing XML payload.
namespaces
Adds additional tags to your payload for namespaces
# required
Make a comma-separate list of fields required.
object_definition["user"].required("id", "created_at")
# reverse
Reverse string or array.
# reverse_each
Builds a temporary array and traverses that array in reverse order.
See reverse_each (opens new window) method definition.
# rjust
Aligns string to right and pads with whitespace or pattern until string is specified length.
"test".rjust(5) #" test"
"test".rjust(10, "*!") #"*!*!* test"
See rjust (opens new window) method definition.
# round
Round the number by regular rounding rules.
11.99.round #12
11.555.round(2) #11.56
See round (opens new window) method definition.
# rsa_sha256
Creates a RS256 signature (SHA256 hash signed with an RSA key)
input['StringToSign'].rsa_sha256(rsa_private_key).base64
# rsa_sha512
Creates a RS512 signature (SHA512 hash signed with an RSA key).
input['StringToSign'].rsa_sha512(rsa_private_key).base64
# rstrip
Remove white space from the end of string.
" Test ".rstrip #" Test"
See rstrip (opens new window) method definition.
# scan
Scans the string for a matching pattern.
"Thu, 01/23/2014".scan(/\d+/).join("-") #01-23-2014
See scan (opens new window) method definition.
# scrub
If the string is invalid byte sequence then replace invalid bytes with given replacement character, else returns self.
"abc\u3042\x81".scrub("*") # "abc\u3042*"
See scrub (opens new window) method definition.
# select
Selectively returns elements for which the block returns true.
See select (opens new window) method definition.
# SHA1
Encrypts a given string using the SHA1 encryption algorithm.
"abcdef".sha1.encode_base64 # "H4rBDyPFtbwRZ72oS4M+XAV6d9I="
See SHA1 (opens new window) method definition.
# singularize
The reverse of pluralize
. Returns the singular form of a word in a string.
'posts'.singularize # => "post"
See singularize (opens new window) method definition.
# slice
Returns a substring of a given string, as defined by start indexes and length.
"Jean Marie\.slice(0,3) #"Jea"
See slice (opens new window) method definition.
# slice_after
Slices an array after a specific value.
["a", "b", "c"].slice_after("b").to_a # [["a", "b"], ["c"]]
See slice_after (opens new window) method definition.
# slice_before
Slices an array before a specific value.
["a", "b", "c"].slice_before("b").to_a # [["a"], ["b", "c"]]
See slice_before (opens new window) method definition.
# slice_when
Creates an enumerator for each chunked elements.
[1,2,4,9,10,11].slice_when { |i,j| i+1 != j}.to_a # [[1, 2], [4], [9, 10, 11]]
See slice_when (opens new window) method definition.
# smart_join
Join array to string. Removes empty and nil values. Trims the white space before joining.
[nil, " ", " Hello ", " World "].smart_join(" ") #Hello World
See smart_join method definition.
# sort
Sort function returning new sorted array.
See sort (opens new window) method definition.
# sort_by
Sort function returning self.
See sort_by (opens new window) method definition.
# split
Split string into an array by using defined pattern as delimiter.
"Split string".split() #["Split", "string"]
"Split string".split("t") #["Spli", " s", "ring"]
See split (opens new window) method definition.
# stream.out
Used in file stream producing actions that work with any of Workato's file streaming enabled connectors. Calling this method allows you to specify a streaming
callback that is invoked when a downstream action downloads the file.
workato.stream.out("download_file", { file_id: file_id })
See file streaming for more information.
# stream.in
Used in file stream consuming actions that work with any of Workato's file streaming enabled connectors. Calling this method allows you to specify a code block that can utilize a file stream to upload a file in chunks.
This method takes three arguments:
- the first positional argument being the file contents from a previous action
from
which is used to override the default offset of0
. This will be used in implementing multi-step streamingframe_size
which is used to override the size requested from a stream producer.
workato.stream.in(input["file"], from: previous_offset, frame_size: required_frame_size) do |chunk, starting_byte_range, ending_byte_range, eof, next_starting_byte_range|
put("/file/#{input['file_id']}").
headers("Content-Range": "byte #{starting_byte_range}-#{ending_byte_range}/*").
request_body(chunk).
presence
end
See file streaming for more information.
# strip
Strip white spaces from the beginning and the end of string.
" This is an example ".strip #"This is an example"
See strip (opens new window) method definition.
# strip_tags
Strip html tags from the string.
"<html><body>Double bubble</body></html>".strip_tags #"Double bubble"
# strftime
Format date or time using %-placeholders.
# sub
Substitute the first occurrence of a pattern with value.
"Mean Marie".sub(/M/, "J") #"Jean Marie"
"Hello".sub(/[aeiou]/, "\*") #"H*llo"
# suspend
This method is used in Wait for resume actions. These actions work with external systems that can send an API request when a long running process is complete. Calling this method suspends the job until Workato receives a corresponding request to its developer API, or until the specified suspension time expires.
suspend(
continue: {
"state" => "suspended",
"url" => input['url']
},
expires_at: 10.minutes.from_now
)
continue
: This hash is passed to thebefore_suspend
,before_resume
, andbefore_timeout_resume
lambdas.expires_at
: This is the time in PST that the job waits for a request to resume. After this time, the job continues with atimeout
call. The maximum timeout is 60 days.
# take
Returns first N elements from an array.
[1, 2, 3, 4, 5, 0].take(3) #=> [1, 2, 3]
See take (opens new window) method definition.
# take_while
Passes elements to the block until the block returns nil or false, then stops iterating and returns an array of all prior elements.
[1, 2, 3, 4, 5, 0].take_while { |i| i < 3 } #=> [1, 2]
See take_while (opens new window) method definition.
# tap
Yields x to the block, and then returns x.
The tap
method is often used for transformation. For example, we can use the tap
method to transform a webhook's payload. Consider the following example:
{
"id" => {"value" => 1},
"name" => {"value" => 2}
}
If a webhook payload is delivered in this format, you can use tap
to transform it into a more user friendly JSON.
webhook_notification: lambda do |input, payload|
payload.tap do |output|
output.each { |k, v| output[k] = v["value"] }
end
end
The final JSON will look as follows: {"id"=>1, "name"=>2}
See tap (opens new window) method definition.
# tls_client_cert
Allows you to dictate the TLS keys, TLS client, and intermediate certificates to be used in the request. Can be used by chaining it in a single request or used generally in the apply block.
get("https://www.exampleapi.com").
tls_client_cert(
certificate: connection['ssl_client_cert'],
key: connection['ssl_client_key'],
passphrase: connection['ssl_key_passphrase'],
intermediates: connection['client_intermediate_certs'] # pass array if there are multiple intermediate certs
)
apply: lambda do |connection|
tls_client_cert(
certificate: connection['ssl_client_cert'],
key: connection['ssl_client_key'],
passphrase: connection['ssl_key_passphrase'],
intermediates: connection['client_intermediate_certs'] # pass array if there are multiple intermediate certs
)
end
# tls_server_certs
Allows you to dictate the TLS server certificates we should accept during the SSL handshake process. This is useful for self-signed or untrusted root CA certificates. Can be used by chaining it in a single request or used generally in the apply block.
get("https://www.exampleapi.com").
tls_server_certs(
certificates: [connection['server_ca_cert']], #additional intermediate server certificates can be given.
strict: false # Set to true to only allow requests from the given server CA cert.
)
apply: lambda do |connection|
tls_server_certs(
certificates: [connection['server_ca_cert']], #additional intermediate server certificates can be given.
strict: false # Set to true to only allow requests from the given server CA cert.
)
end
# to_currency
Convert to currency string.
1234567890.50.to_currency # $1,234,567,890.50
# to_currency_code
Convert alpha-2/3 country code or country name to ISO4217 currency code.
"India".to_currency_code #INR
# to_currency_name
Convert alpha-2/3 country code or country name to ISO4217 currency name.
"India".to_currency_name #Rupees
# to_currency_symbol
Convert alpha-2/3 country code or country name to ISO4217 currency symbol.
"India".to_currency_symbol # ₨
# to_country_alpha2
Convert alpha-3 country code or country name to alpha2 country code.
"India".to_country_alpha2 #IN
"IND".to_country_alpha2 #IN
# to_country_alpha3
Convert alpha-2 country code or country name to alpha3 country code.
"Australia".to_country_alpha2 #AUS
"AU".to_country_alpha2 #AUS
# to_country_name
Convert alpha-2/3 country code or country name to ISO3166 country name.
"GB".to_country_name #United Kingdom
"GBR".to_country_name #United Kingdom
# to_country_number
Convert alpha-2/3 country code or country name to ISO3166 country numeric code.
"India".to_country_number #356
# to_date
Convert string or timestamp to date. Can be formatted.
"12/24/2014 10:30 PM".to_date(format: "MM/DD/YYYY")
# to_f
Convert to float. Numbers are rounded up or down according to regular rounding rules.
45.to_f #45.0
# to_hex
Converts binary string to its hex representation.
# to_i
Convert to integer. Decimals are always rounded down.
45.67.to_i #45
# to_json
Converts hash or array into JSON string.
{"a" => "c d", "2" => "3"}.to_json #"{"a":"c d","2":"3"}"
# to_phone
Convert string or number to a formatted phone number.
5551234.to_phone # 555-1234
1235551234.to_phone(area_code: true) # (123) 555-1234
1235551234.to_phone(delimiter: " ") # 123 555 1234
1235551234.to_phone(country_code: 1) # +1-123-555-1234
# to_param
Returns a string representation for use as a URL query string.
{name: 'Jake', age: '22'}.to_param #name=Jake&age=22
# to_s
Convert to string.
45.67.to_s #"45.67"
# to_state_code
Convert state name to code.
"California".to_state_code #CA
# to_state_name
Convert state code to name.
"CA".to_state_name #"CALIFORNIA"
# to_time
Convert string or date to timestamp.
"2014-11-21".to_time #2014-11-21 00:00:00 +0000
# to_xml
Converts hash or array into XML string.
{"name" => "Ken"}.to_xml(root: "user") # <user><name>Ken</name></user>
# today
Date today. Returns the date of the moment that the formula was executed, in Pacific time (UTC-8/UTC-7).
today #2016-07-13
today + 2.days #2016-07-15
# transliterate
Replaces non-ASCII characters with an ASCII approximation, or if none exists, a replacement character which defaults to '?'.
'Chloé'.transliterate #Chloe
# upcase
Convert string to upper case.
"Convert to UPCASE".upcase #"CONVERT TO UPCASE"
# uniq
Return unique items in an array.
[1.0, 1.5, 1.0].uniq #[1.0, 1.5]
# unpack
Decodes a string into an array.
See unpack (opens new window) method definition.
# utc
Convert Time to UTC timezone.
See utc (opens new window) method definition.
# uuid
Creates a UUID. Useful when sending strings that are unique in a request.
workato.uuid #c52d735a-aee4-4d44-ba1e-bcfa3734f553 => "eyJhbGciO..."
# wday
Returns day of the week where 1 is Monday.
# where
Filter array by given condition.
# while
While loop statement.
See ruby_loops (opens new window) method definition.
# wrap
Wraps its argument in an array unless it is already an array
The wrap method is often used in the execute block of the while loop statement.
execute: lambda do |connection, input|
{
accounts: Array.wrap(get("/accounts", input)["records"])
}
end
This ensures that the accounts
variable is always an array in spite of whatever return. At Workato, we often use this to guard against unexpected returns from the various APIs we work with.
See wrap (opens new window) method definition.
# yday
Returns day of the year.
"2016-07-19 10:45:30".to_time.yday #201
# yweek
Returns week of the year.
"2016-07-19 10:45:30".to_time.yweek #29
# zip
Used as a method called by arrays. Converts any arguments to arrays, then merges elements of self with corresponding elements from each argument.
See zip (opens new window) method definition.
Last updated: 12/20/2024, 6:05:23 PM