Skip to main content

CEL Expressions

expr expressions in canary checker use the Go Common Expression Language (CEL) See Language Definition

http-check-expr.yaml
apiVersion: canaries.flanksource.com/v1
kind: Canary
metadata:
name: http-check-expr
spec:
interval: 30
http:
- name: http pass response 200 status code
endpoint: https://httpbin.demo.aws.flanksource.com/status/200
test:
expr: "code in [200,201,301] and sslAge < Duration('7d')"

Collections

in

The membership test operator checks whether an element is a member of a collection, such as a list or a map. It's worth noting that the in operator doesn't check for value membership in maps, only key membership.

Syntax:

`a in b` Where `a` is the element you're checking for, and `b` is the collection.

Examples:

`"apple" in ["apple", "banana"]` // evaluates to `true`
`3 in [1, 2, 4]` // evaluates to `false`

size

The size function in CEL is used to determine the number of elements in a collection or the number of Unicode characters in a string.

Syntax:

    collection.size() or string.size()

Examples:

Getting the size of a list:
["apple", "banana", "cherry"].size() // Evaluates to 3

Determining the number of characters in a string:
"hello".size() // Evaluates to 5

has

The has macro checks for the presence of a field in a message. It's particularly useful for protobuf messages where fields can be absent rather than set to a default value. It's especially useful for distinguishing between a field being set to its default value and a field being unset. For instance, in a protobuf message, an unset integer field is indistinguishable from that field set to 0 without the has macro.

Syntax

x.has(y)

Where x is the message and y is the field you're checking for.

Examples:

If you have a message person with a potential field name, you can check for its presence with:

person.has(name)  // Evaluates to true if 'name' is present, false otherwise

addressBook.has(person.email) // Evaluates to true if 'email' field is present in 'person' within 'addressBook'

map

The map macro creates a new collection by applying a function to each entry of an existing collection. It's useful for transforming the elements of a list or the values of a map.

Syntax:

//For lists
list.map(e, <function>)

//For maps:
map.map(k, v, <function>)

Where:

  • list is the list you're transforming.
  • map is the map you're transforming.
  • e represents each element of the list.
  • k represents each key of the map.
  • v represents each value of the map.
  • <function> is the transformation function applied to each entry.

Examples:

// Transforming each element of a list by multiplying it by 2:
[1, 2, 3].map(e, e * 2) // Evaluates to [2, 4, 6]
// Transforming the values of a map by appending "!" to each value:
{"a": "apple", "b": "banana"}.map(k, v, v + "!") // Evaluates to {"a": "apple!", "b": "banana!"}
// Using both key and value for transformation in a map:
{"a": 1, "b": 2}.map(k, v, k + v) // Evaluates to {"a": "a1", "b": "b2"}

filter

The filter macro creates a new collection containing only the elements or entries of an existing collection that satisfy a given condition.

Syntax:

//For lists:
list.filter(e, <condition>)

//For maps:
map.filter(k, v, <condition>)

Where:

  • list is the list you're filtering.
  • map is the map you're filtering.
  • e represents each element of the list.
  • k represents each key of the map.
  • v represents each value of the map.
  • <condition> is the condition applied to each entry.

Examples:

// Filtering a list to include only numbers greater than 2:
[1, 2, 3, 4].filter(e, e > 2) // Evaluates to [3, 4]

// Filtering a map to include only entries with values greater than 1:
{"a": 1, "b": 2, "c": 3}.filter(k, v, v > 1) // Evaluates to {"b": 2, "c": 3}

all

The all macro checks if all elements of a collection, such as a list or a map, satisfy a given condition. It returns a boolean value based on the evaluation.

Syntax:

//For lists:
list.all(e, <condition>)

//For maps:
map.all(k, v, <condition>)

Where:

  • list is the list you're checking.
  • map is the map you're checking.
  • e represents each element of the list.
  • k represents each key of the map.
  • v represents each value of the map.
  • <condition> is the condition applied to each entry.

Examples:

// Checking if all elements of a list are greater than 0:
[1, 2, 3].all(e, e > 0) // Evaluates to true

// Checking if all values of a map are non-empty strings:
{"a": "apple", "b": "banana", "c": ""}.all(k, v, v != "") // Evaluates to false

// Using both key and value for condition in a map:
{"a": 1, "b": 2, "c": 3}.all(k, v, k != "a" || v > 1) // Evaluates to true

exists

The exists macro checks if there exists an element in a collection, such as a list or a map, that satisfies a given condition. It returns a boolean value based on the evaluation.

Syntax:

// For lists
list.exists(e, <condition>)

// For maps
map.exists(k, v, <condition>)

Where:

  • list is the list you're checking.
  • map is the map you're checking.
  • e represents each element of the list.
  • k represents each key of the map.
  • v represents each value of the map.
  • <condition> is the condition applied to each entry.

Examples:

//Checking if any element of a list is equal to 2:
[1, 2, 3].exists(e, e == 2) // Evaluates to true

//Checking if any value of a map is an empty string:
{"a": "apple", "b": "banana", "c": ""}.exists(k, v, v == "") // Evaluates to true

/Using both key and value for condition in a map:
{"a": 1, "b": 2, "c": 3}.exists(k, v, k == "a" && v == 1) // Evaluates to true

fold

The fold macro is used to combine all elements of a collection, such as a list or a map, using a binary function. It's a powerful tool for aggregating or reducing data.

Syntax:

//For lists:
list.fold(e, acc, <binary_function>)

//For maps:
map.fold(k, v, acc, <binary_function>)

Where:

  • list is the list you're folding.
  • map is the map you're folding.
  • e represents each element of the list.
  • k represents each key of the map.
  • v represents each value of the map.
  • acc is the accumulator, which holds the intermediate results.
  • <binary_function> is the function applied to each entry and the accumulator.

Examples:

// Computing the sum of all elements of a list:
[1, 2, 3].fold(e, acc, acc + e) // Evaluates to 6

// Concatenating all values of a map:
{"a": "apple", "b": "banana"}.fold(k, v, acc, acc + v) // Evaluates to "applebanana"

slice

Returns a new sub-list using the indexes provided.

<list>.slice(<int>, <int>) -> <list>

Examples:

[1,2,3,4].slice(1, 3) // return [2, 3]
[1,2,3,4].slice(2, 4) // return [3 ,4]

sets.contains

Returns whether the first list argument contains all elements in the second list argument. The list may contain elements of any type and standard CEL equality is used to determine whether a value exists in both lists. If the second list is empty, the result will always return true.

sets.contains(list(T), list(T)) -> bool

Examples:

sets.contains([], []) // true
sets.contains([], [1]) // false
sets.contains([1, 2, 3, 4], [2, 3]) // true
sets.contains([1, 2.0, 3u], [1.0, 2u, 3]) // true

sets.equivalent

Returns whether the first and second list are set equivalent. Lists are set equivalent if for every item in the first list, there is an element in the second which is equal. The lists may not be of the same size as they do not guarantee the elements within them are unique, so size does not factor into the computation.

sets.equivalent(list(T), list(T)) -> bool

Examples:

sets.equivalent([], []) // true
sets.equivalent([1], [1, 1]) // true
sets.equivalent([1], [1u, 1.0]) // true
sets.equivalent([1, 2, 3], [3u, 2.0, 1]) // true

sets.intersects

Returns whether the first list has at least one element whose value is equal to an element in the second list. If either list is empty, the result will be false.

sets.intersects(list(T), list(T)) -> bool

Examples:

sets.intersects([1], []) // false
sets.intersects([1], [1, 2]) // true
sets.intersects([[1], [2, 3]], [[1, 2], [2, 3.0]]) // true

Strings

matches

The matches function in CEL is used to determine if a string matches a given regular expression pattern. It returns a boolean value indicating whether the string conforms to the pattern.

Syntax:

string.matches(pattern)

Where:

  • string is the string you're checking.
  • pattern is the regular expression pattern you're matching against.

Examples:

// Checking if a string matches a simple pattern:
"apple".matches("^a.*e$") // Evaluates to true

// Validating an email format:
"example@email.com".matches("^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$") // Evaluates to true

// Checking for a pattern of digits:
"12345".matches("^\\d+$") // Evaluates to true

startsWith

The startsWith function in CEL is used to determine if a string starts with a specified substring.

Syntax:

string.startsWith(substring)

Examples:

// Checking if a string starts with a certain substring:
"hello".startsWith("he") // Evaluates to true

endsWith

The endsWith function in CEL is used to determine if a string ends with a specified substring.

Syntax:

string.endsWith(substring)

Examples:

// Checking if a string ends with a certain substring:
"hello".endsWith("lo") // Evaluates to true

contains

The contains function in CEL is used to check if a string contains a given substring.

Syntax:

string.contains(substring)

Examples:

//Checking if a string contains a certain substring:
"apple".contains("app") // Evaluates to true

size

The size function in CEL is used to determine the number of elements in a collection or the number of Unicode characters in a string.

Syntax:

collection.size() or string.size()

Examples:

// Getting the size of a list:
["apple", "banana", "cherry"].size() // Evaluates to 3

// Determining the number of characters in a string:
"hello".size() // Evaluates to 5

charAt

Returns the character at the given position. If the position is negative, or greater than the length of the string, the function will produce an error:

    <string>.charAt(<int>) -> <string>

Examples:

'hello'.charAt(4)  // return 'o'
'hello'.charAt(5) // return ''
'hello'.charAt(-1) // error

indexOf

Returns the integer index of the first occurrence of the search string. If the search string is not found the function returns -1.

The function also accepts an optional position from which to begin the substring search. If the substring is the empty string, the index where the search starts is returned (zero or custom).

    <string>.indexOf(<string>) -> <int>
<string>.indexOf(<string>, <int>) -> <int>

Examples:

'hello mellow'.indexOf('')         // returns 0
'hello mellow'.indexOf('ello') // returns 1
'hello mellow'.indexOf('jello') // returns -1
'hello mellow'.indexOf('', 2) // returns 2
'hello mellow'.indexOf('ello', 2) // returns 7
'hello mellow'.indexOf('ello', 20) // error

lastIndexOf

Returns the integer index of the last occurrence of the search string. If the search string is not found the function returns -1.

The function also accepts an optional position which represents the last index to be considered as the beginning of the substring match. If the substring is the empty string, the index where the search starts is returned (string length or custom).

    <string>.lastIndexOf(<string>) -> <int>
<string>.lastIndexOf(<string>, <int>) -> <int>

Examples:

'hello mellow'.lastIndexOf('')         // returns 12
'hello mellow'.lastIndexOf('ello') // returns 7
'hello mellow'.lastIndexOf('jello') // returns -1
'hello mellow'.lastIndexOf('ello', 6) // returns 1
'hello mellow'.lastIndexOf('ello', -1) // error

join

Returns a new string where the elements of string list are concatenated.

The function also accepts an optional separator which is placed between elements in the resulting string.

    <list<string>>.join() -> <string>
<list<string>>.join(<string>) -> <string>

Examples:

['hello', 'mellow'].join() // returns 'hellomellow'
['hello', 'mellow'].join(' ') // returns 'hello mellow'
[].join() // returns ''
[].join('/') // returns ''

quote

Takes the given string and makes it safe to print (without any formatting due to escape sequences). If any invalid UTF-8 characters are encountered, they are replaced with \uFFFD.

    strings.quote(<string>)

Examples:

strings.quote('single-quote with "double quote"') // returns '"single-quote with \"double quote\""'
strings.quote("two escape sequences \a\n") // returns '"two escape sequences \\a\\n"'

replace

Returns a new string based on the target, which replaces the occurrences of a search string with a replacement string if present. The function accepts an optional limit on the number of substring replacements to be made.

When the replacement limit is 0, the result is the original string. When the limit is a negative number, the function behaves the same as replace all.

<string>.replace(<string>, <string>) -> <string>
<string>.replace(<string>, <string>, <int>) -> <string>

Examples:

'hello hello'.replace('he', 'we')     // returns 'wello wello'
'hello hello'.replace('he', 'we', -1) // returns 'wello wello'
'hello hello'.replace('he', 'we', 1) // returns 'wello hello'
'hello hello'.replace('he', 'we', 0) // returns 'hello hello'

split

Returns a list of strings split from the input by the given separator. The function accepts an optional argument specifying a limit on the number of substrings produced by the split.

When the split limit is 0, the result is an empty list. When the limit is 1, the result is the target string to split. When the limit is a negative number, the function behaves the same as split all.

    <string>.split(<string>) -> <list<string>>
<string>.split(<string>, <int>) -> <list<string>>

Examples:

'hello hello hello'.split(' ')     // returns ['hello', 'hello', 'hello']
'hello hello hello'.split(' ', 0) // returns []
'hello hello hello'.split(' ', 1) // returns ['hello hello hello']
'hello hello hello'.split(' ', 2) // returns ['hello', 'hello hello']
'hello hello hello'.split(' ', -1) // returns ['hello', 'hello', 'hello']

substring

Returns the substring given a numeric range corresponding to character positions. Optionally may omit the trailing range for a substring from a given character position until the end of a string.

Character offsets are 0-based with an inclusive start range and exclusive end range. It is an error to specify an end range that is lower than the start range, or for either the start or end index to be negative or exceed the string length.

    <string>.substring(<int>) -> <string>
<string>.substring(<int>, <int>) -> <string>

Examples:

'tacocat'.substring(4)    // returns 'cat'
'tacocat'.substring(0, 4) // returns 'taco'
'tacocat'.substring(-1) // error
'tacocat'.substring(2, 1) // error

trim

Returns a new string which removes the leading and trailing whitespace in the target string. The trim function uses the Unicode definition of whitespace which does not include the zero-width spaces. See: https://en.wikipedia.org/wiki/Whitespace_character#Unicode

    <string>.trim() -> <string>

Examples:

'  \ttrim\n    '.trim() // returns 'trim'

TrimPrefix

The TrimPrefix function in CEL removes a given prefix from a string if the string starts with that prefix.

Syntax:

TrimPrefix(prefix, string)

Where:

  • prefix is the starting substring to remove.
  • string is the string from which the prefix will be removed.

Examples:

// Removing a prefix from a string:
TrimPrefix("Mr.", "Mr. Smith") // Evaluates to "Smith"

// Another example:
TrimPrefix("Astro", "Astronaut") // Evaluates to "naut"

// If the prefix is not present:
TrimPrefix("Dr.", "Mr. Smith") // Evaluates to "Mr. Smith"

TrimSuffix

The TrimSuffix function in CEL removes a given suffix from a string if the string ends with that suffix.

Syntax:

TrimSuffix(suffix, string)

Where:

  • suffix is the ending substring to remove.
  • string is the string from which the suffix will be removed.

Examples:

// Removing a suffix from a string:
TrimSuffix(".jpg", "image.jpg") // Evaluates to "image"


// If the suffix is not present:
TrimSuffix(".png", "image.jpg") // Evaluates to "image.jpg"

lowerAscii

Returns a new string where all ASCII characters are lower-cased.

This function does not perform Unicode case-mapping for characters outside the ASCII range.

     <string>.lowerAscii() -> <string>

Examples:

 'TacoCat'.lowerAscii()      // returns 'tacocat'
'TacoCÆt Xii'.lowerAscii() // returns 'tacocÆt xii'

upperAscii

Returns a new string where all ASCII characters are upper-cased.

This function does not perform Unicode case-mapping for characters outside the ASCII range.

    <string>.upperAscii() -> <string>

Examples:

 'TacoCat'.upperAscii()      // returns 'TACOCAT'
'TacoCÆt Xii'.upperAscii() // returns 'TACOCÆT XII'

reverse

Returns a new string whose characters are the same as the target string, only formatted in reverse order. This function relies on converting strings to rune arrays in order to reverse. It can be located in Version 3 of strings.

    <string>.reverse() -> <string>

Examples:

'gums'.reverse() // returns 'smug'
'John Smith'.reverse() // returns 'htimS nhoJ'

HumanDuration

The HumanDuration function in CEL converts a duration into a human-readable format.

Syntax:

HumanDuration(duration)

Where:

  • duration is the duration you want to convert.

Examples:

// Converting a duration into a human-readable format:
HumanDuration(3600) // Evaluates to "1 hour"

// Converting another duration:
HumanDuration(600) // Evaluates to "10 minutes"

// Converting a longer duration:
HumanDuration(86400) // Evaluates to "1 day"

HumanSize

The HumanSize function in CEL converts a size in bytes into a human-readable format.

Syntax:

HumanSize(size)

Where:

  • size is the size in bytes you want to convert.

Examples:

// Converting a size into a human-readable format:
HumanSize(1024) // Evaluates to "1 KiB"

// Converting another size:
HumanSize(1048576) // Evaluates to "1 MiB"

// Converting a larger size:
HumanSize(1073741824) // Evaluates to "1 GiB"

Semver

The Semver function in CEL parses a version string and returns a map containing the major, minor, patch, prerelease, metadata, and original version.

Syntax:

Semver(version)

Where:

  • version is the version string to parse.

Examples:

// Parsing a semantic version:
Semver("1.2.3-alpha+meta") // Evaluates to a map with major: "1", minor: "2", patch: "3", prerelease: "alpha", metadata: "meta", original: "1.2.3-alpha+meta"

Semver("2.3.4-beta+meta2") // Evaluates to a map with major: "2", minor: "3", patch: "4", prerelease: "beta", metadata: "meta2", original: "2.3.4-beta+meta2"

// Parsing a simple semantic version:
Semver("3.4.5") // Evaluates to a map with major: "3", minor: "4", patch: "5", prerelease: "", metadata: "", original: "3.4.5"

SemverCompare

The SemverCompare function in CEL compares two semantic version strings.

Syntax:

SemverCompare(version1, version2)

Where:

  • version1 is the first version string to compare.
  • version2 is the second version string to compare.

Examples:

// Comparing two semantic versions:
SemverCompare("1.2.3", "1.2.4") // Evaluates to false

// Comparing two identical versions:
SemverCompare("2.3.4", "2.3.4") // Evaluates to true

// Comparing with a prerelease version:
SemverCompare("3.4.5", "3.4.5-alpha") // Evaluates to false

ReplaceAll

The ReplaceAll function in CEL replaces all occurrences of a substring within a string with another substring.

Syntax:

ReplaceAll(old, new, string)

Where:

  • old is the substring to be replaced.
  • new is the substring to replace with.
  • string is the original string.

Examples:

// Replacing a substring:
ReplaceAll("apple", "orange", "I have an apple") // Evaluates to "I have an orange"

// Replacing another substring:
ReplaceAll("cat", "dog", "The cat sat on the mat") // Evaluates to "The dog sat on the mat"

// Replacing a substring with a number:
ReplaceAll("one", "1", "I have one apple") // Evaluates to "I have 1 apple"

Repeat

The Repeat function in CEL repeats a string for a given number of times.

Syntax:

Repeat(count, string)

Where:

  • count is the number of times the string should be repeated.
  • string is the string to repeat.

Examples:

// Repeating a string:
Repeat(3, "apple") // Evaluates to "appleappleapple"


Sort

The Sort function in CEL sorts a list of strings.

Syntax:

Sort(list)

Where:

  • list is the list of strings to sort.

Examples:

Sorting a list of strings:
Sort(["banana", "apple", "cherry"]) // Evaluates to ["apple", "banana", "cherry"]

Sorting another list:
Sort(["dog", "cat", "bird"]) // Evaluates to ["bird", "cat", "dog"]

Sorting a list with numbers:
Sort(["3", "1", "2"]) // Evaluates to ["1", "2", "3"]


Title

The Title function in CEL converts the first character of each word in a string to uppercase.

Syntax:

Title(string)

Where:

  • string is the string to convert.

Examples:

// Converting a string:
Title("hello world") // Evaluates to "Hello World"

// Working with mixed case:
Title("mIxEd CaSe") // Evaluates to "MIxED CASe"

Indent

The Indent function in CEL indents each line of a string by a specified number of spaces or a specified prefix.

Syntax:

Indent(width or prefix, string)

Where:

  • width or prefix is the number of spaces or the prefix string to add before each line.
  • string is the string to indent.

Examples:

// Indenting with spaces:
Indent(4, "Line1\nLine2") // Evaluates to " Line1\n Line2"

//Indenting with a prefix:
Indent("> ", "Line1\nLine2") // Evaluates to "> Line1\n> Line2"

// Indenting with a mixed prefix:
Indent("==", "Line1\nLine2") // Evaluates to "==Line1\n==Line2"

Slug

The Slug function in CEL converts a given string into a URL-friendly slug format.

Syntax:

Slug(string)

Where:

  • string is the input string to be converted.

Examples:

// Converting a string to a slug:
Slug("Hello World!") // Evaluates to "hello-world"

// Converting a string with special characters:
Slug("Hello, World!") // Evaluates to "hello-world"

// Converting a multi-word string:
Slug("Hello Beautiful World") // Evaluates to "hello-beautiful-world"

Quote

The Quote function in CEL adds double quotes around a given string.

Syntax:

Quote(string)

Examples:

//Quoting a simple string:
Quote("Hello World") // Evaluates to "\"Hello World\""

// Quoting a string with a number:
Quote("12345") // Evaluates to "\"12345\""

// Quoting an already quoted string:
Quote("\"Hello World\"") // Evaluates to "\"\"Hello World\"\""

ShellQuote

The ShellQuote function in CEL quotes a string such that it can be safely used as a token in a shell command.

Syntax:

ShellQuote(string)

Examples:

// Shell quoting a string:
ShellQuote("Hello World") // Evaluates to "'Hello World'"

// Shell quoting a string with special characters:
ShellQuote("Hello$World") // Evaluates to "'Hello$World'"

// Shell quoting a string with spaces and special characters:
ShellQuote("Hello World$123") // Evaluates to "'Hello World$123'"

Squote

The Squote function in CEL adds single quotes around a given string.

Syntax:

Squote(string)

Examples:

Single quoting a simple string:
Squote("Hello World") // Evaluates to "'Hello World'"

Single quoting a string with a number:
Squote("12345") // Evaluates to "'12345'"

Single quoting an already single quoted string:
Squote("'Hello World'") // Evaluates to "'''Hello World'''"

SnakeCase

The SnakeCase function in CEL converts a given string into snake_case format.

Syntax:

SnakeCase(string)

Where:

  • string is the input string to be converted.

Examples:

Converting a string to snake_case:
SnakeCase("Hello World") // Evaluates to "hello_world"

Converting a CamelCase string:
SnakeCase("HelloWorld") // Evaluates to "hello_world"

Converting a string with spaces and special characters:
SnakeCase("Hello Beautiful World!") // Evaluates to "hello_beautiful_world"

CamelCase

The CamelCase function in CEL converts a given string into CamelCase format.

Syntax:

CamelCase(string)

Where:

  • string is the input string to be converted.

Examples:

Converting a string to CamelCase:
CamelCase("hello world") // Evaluates to "HelloWorld"

Converting a snake_case string:
CamelCase("hello_world") // Evaluates to "HelloWorld"

Converting a string with spaces and special characters:
CamelCase("hello beautiful world!") // Evaluates to "HelloBeautifulWorld"

KebabCase

The KebabCase function in CEL converts a given string into kebab-case format.

Syntax:

KebabCase(string)

Where:

  • string is the input string to be converted.

Examples:

Converting a string to kebab-case:
KebabCase("Hello World") // Evaluates to "hello-world"

Converting a CamelCase string:
KebabCase("HelloWorld") // Evaluates to "hello-world"

Converting a string with spaces and special characters:
KebabCase("Hello Beautiful World!") // Evaluates to "hello-beautiful-world"

WordWrap

The WordWrap function in CEL wraps the input string at the specified width.

Syntax:

WordWrap(width, string)

Where:

  • width is the number of characters at which to wrap the string.
  • string is the input string to be wrapped.

Examples:

Wrapping a string at a specified width:
WordWrap(5, "Hello World") // Evaluates to "Hello\nWorld"

Wrapping a longer string:
WordWrap(10, "Hello Beautiful World") // Evaluates to "Hello\nBeautiful\nWorld"

Wrapping a string with special characters:
WordWrap(5, "Hello$World") // Evaluates to "Hello\n$World"

RuneCount

The RuneCount function in CEL counts the number of runes in a given string.

Syntax:

RuneCount(string)

Where:

  • string is the input string whose runes are to be counted.

Examples:

Counting runes in a string:
RuneCount("Hello World") // Evaluates to 11

Counting runes in a string with special characters:
RuneCount("Hello$World") // Evaluates to 11

Counting runes in an empty string:
RuneCount("") // Evaluates to 0

Dates

timestamp

The timestamp function in CEL is used to represent a point in time. It's typically used in conjunction with other functions to extract or manipulate time-related data.

Syntax:

timestamp("YYYY-MM-DDTHH:MM:SSZ")

Where:

  • The string inside the function represents the date and time.

Examples:

Creating a timestamp for January 1st, 2023:
timestamp("2023-01-01T00:00:00Z")

Creating another timestamp:
timestamp("2023-07-04T12:00:00Z")

getDate

The getDate function in CEL is used to extract the date part from a timestamp. It returns a string representation of the date.

Syntax:

timestamp.getDate()

Where:

  • timestamp is the timestamp value from which you're extracting the date.

Examples:

Extracting the date from a timestamp:
"2023-01-01T12:34:56Z".getDate() // Evaluates to "2023-01-01"

Getting the date from another timestamp:
"2023-07-04T00:00:00Z".getDate() // Evaluates to "2023-07-04"

get[DatePart]

FunctionDescriptionExample
{date>.getDayOfMonth()A integer value representing the day of the month, with the first day being 1.1 - 31
<date>.getDayOfWeek()eturns an integer value representing the day of the week, where Sunday is 0 and Saturday is 6.0 - 6
<date>.getDayOfYear()an integer value representing the day of the year, with January 1st being day 1.1 - 366
<date>.getDayOfMonth()the full year (4 digits for 4-digit years) of the specified timestamp.
<date>.getHours()the full year (4 digits for 4-digit years) of the specified timestamp.0- 23
<date>.getMilliseconds()0 -999
<date>.getMinutes()
<date>.getMonth()0 -11
<date>.getSeconds()0 - 590 - 59
<date>.getHours()

duration

The duration function in CEL creates a new duration from a string representation. The string format is an integer followed by a unit: s for seconds, m for minutes, h for hours, and d for days.

Syntax:

duration(stringRepresentation)

Examples:

Creating a duration of 5 hours:
duration("5h") // Represents a duration of 5 hours

Creating a duration of 30 minutes:
duration("30m") // Represents a duration of 30 minutes

Durations can also be crated using arithmetic:

FieldDescription
time.Unix(epoch)converts a UNIX time (seconds since the UNIX epoch) into a time.Time object
time.Nanosecondconverts to a time.Duration
time.Microsecond
time.Millisecond
time.Second
time.Minute
time.Hour

time.ZoneName

The time.ZoneName function in CEL returns the name of the local system's time zone. It doesn't require any parameters and is useful for retrieving the time zone information.

Syntax:

time.ZoneName()

Examples:

Retrieving the local time zone name:
time.ZoneName() // Might evaluate to "PST" if the local time zone is Pacific Standard Time

Another example of retrieving the time zone:
time.ZoneName() // Could evaluate to "EST" for Eastern Standard Time

Yet another example:
time.ZoneName() // Might evaluate to "UTC" for Coordinated Universal Time

time.ZoneOffset

The time.ZoneOffset function in CEL returns the offset of the local system's time zone in minutes. It helps in understanding the time difference between the local time zone and UTC.

Syntax:

time.ZoneOffset()

Examples:

Getting the time zone offset:
time.ZoneOffset() // Could evaluate to -480 for PST

Another example of getting the offset:
time.ZoneOffset() // Might evaluate to 0 for UTC

Yet another example:
time.ZoneOffset() // Could evaluate to 330 for IST (Indian Standard Time)

time.Parse

The time.Parse function in CEL is used to parse a given string into a time object based on a specified layout. It's handy for converting string representations of time into actual time objects.

Syntax:

time.Parse(layout, value)

Where:

  • layout is the time layout string.
  • value is the string representation of the time to be parsed.

Examples:

Parsing a time string with a specific format:
time.Parse("2006-01-02", "2023-09-26") // Evaluates to a time object representing September 26, 2023

Another example with a different format:
time.Parse("02-01-2006", "26-09-2023") // Evaluates to the same time object as above

Parsing a time with hour and minute information:
time.Parse("15:04 02-01-2006", "14:30 26-09-2023") // Includes time of day information

time.ParseLocal

The time.ParseLocal function in CEL parses a given string into a time object according to a specified layout and the local time zone. It's useful for working with local times.

Syntax:

time.ParseLocal(layout, value)

Where:

  • layout is the time layout string.
  • value is the string representation of the time to be parsed.

Examples:

Parsing a local time string:
time.ParseLocal("2006-01-02 15:04", "2023-09-26 14:30") // Evaluates to a local time object for 14:30 on September 26, 2023

Another example:
time.ParseLocal("02-01-2006", "26-09-2023") // Evaluates to a local time object for September 26, 2023

Parsing with a different time format:
time.ParseLocal("15:04 02-01-2006", "14:30 26-09-2023") // Includes time of day information in local time zone

time.ParseInLocation

The time.ParseInLocation function in CEL parses a string into a time object according to a specified layout and time zone. It provides more control over the time zone compared to time.ParseLocal.

Syntax:

time.ParseInLocation(layout, location, value)

Where:

  • layout is the time layout string.
  • location is the string name of the time zone.
  • value is the string representation of the time to be parsed.

Examples:

Parsing a time string for a specific time zone:
time.ParseInLocation("2006-01-02", "America/New_York", "2023-09-26") // Evaluates to a time object for EST/EDT

Another example for a different time zone:
time.ParseInLocation("02-01-2006", "Europe/London", "26-09-2023") // Evaluates to a time object for GMT/BST

Parsing with hour and minute for a specific zone:
time.ParseInLocation("15:04 02-01-2006", "Asia/Tokyo", "14:30 26-09-2023") // Evaluates to a time object for JST

time.Now

The time.Now function in CEL returns the current time. It's a straightforward way to retrieve the current date and time according to the system's local time zone.

Syntax:

time.Now()

Examples:

Getting the current time:
time.Now() // Evaluates to the current date and time

Another example of retrieving the current time:
time.Now() // Will always return the current moment's date and time

Yet another example:
time.Now() // Useful for timestamping or time-stamping events in real-time

time.ParseDuration

The time.ParseDuration function in CEL parses a string into a duration. It supports various units like "s" for seconds, "m" for minutes, "h" for hours, etc.

Syntax:

time.ParseDuration(duration)

Where:

  • duration is the string representation of the duration.

Examples:

Parsing a duration string:
time.ParseDuration("1h30m") // Evaluates to a duration of 1 hour and 30 minutes

Another example with a different format:
time.ParseDuration("15m30s") // Evaluates to a duration of 15 minutes and 30 seconds

Parsing a negative duration:
time.ParseDuration("-2h45m") // Evaluates to a duration of -2 hours and -45 minutes

time.Since

The time.Since function in CEL calculates the duration that has elapsed since a given time. It is commonly used to measure the time difference between a specified time and the current moment.

Syntax:

time.Since(pastTime)

Where:

  • pastTime is a time.Time object representing a past point in time.

Examples:

Calculating the time elapsed since a specific past time:
time.Since(time.Parse("2006-01-02", "2023-09-26")) // Evaluates to the duration since September 26, 2023

Another example with a different past time:
time.Since(time.Parse("15:04 02-01-2006", "14:30 26-09-2023")) // Evaluates to the duration since 14:30 on September 26, 2023

Using the `time.Now` function for a real-time duration:
time.Since(time.Now()) // Always evaluates to a very small duration, as it's the time since "now"

time.Until

The time.Until function in CEL calculates the duration remaining until a specified future time. It helps in determining the time left for an event or deadline.

Syntax:

time.Until(futureTime)

Where:

  • futureTime is a time.Time object representing a future point in time.

Examples:

Calculating the time remaining until a specific future time:
time.Until(time.Parse("2006-01-02", "2023-10-01")) // Evaluates to the duration until October 1, 2023

Another example with a different future time:
time.Until(time.Parse("15:04 02-01-2006", "16:00 30-09-2023")) // Evaluates to the duration until 16:00 on September 30, 2023

Using the `time.Now` function for a real-time duration:
time.Until(time.Now()) // Always evaluates to zero, as it's the time until "now"

Random

random.ASCII

The random.ASCII function in CEL generates a random ASCII string of a given length. The characters in the string are within the ASCII printable character range.

Syntax:

random.ASCII(count)

Where:

  • count is the length of the random ASCII string to be generated.

Examples:

Generating a 5-character random ASCII string:
random.ASCII(5) // Might evaluate to "A7!2k"

Creating a 10-character random ASCII string:
random.ASCII(10) // Might evaluate to "3e$7^2Go1"

Producing a 15-character random ASCII string:
random.ASCII(15) // Might evaluate to "7g$!3H8^2Kl0p9"

random.Alpha

The random.Alpha function in CEL generates a random alphabetic string containing uppercase and lowercase letters, with a specified length.

Syntax:

random.Alpha(count)

Where:

  • count is the length of the random alphabetic string to be generated.

Examples:

Generating a 5-character random alphabetic string:
random.Alpha(5) // Might evaluate to "aBcDe"

Creating a 10-character random alphabetic string:
random.Alpha(10) // Might evaluate to "FgHiJkLmNo"

Producing a 15-character random alphabetic string:
random.Alpha(15) // Might evaluate to "pQrStUvWxYzAbCdEf"

random.AlphaNum

The random.AlphaNum function in CEL generates a random alphanumeric string containing both letters and digits, with a specified length.

Syntax:

random.AlphaNum(count)

Where:

  • count is the length of the random alphanumeric string to be generated.

Examples:

Generating a 5-character random alphanumeric string:
random.AlphaNum(5) // Might evaluate to "a1B2c"

Creating a 10-character random alphanumeric string:
random.AlphaNum(10) // Might evaluate to "3D4e5F6g7H"

Producing a 15-character random alphanumeric string:
random.AlphaNum(15) // Might evaluate to "8i9J0k1L2m3N4o5"

random.String

The random.String function in CEL generates a random string based on provided character sets or bounds, with a specified length.

Syntax:

random.String(count, characterSetOrBounds)

Where:

  • count is the length of the random string to be generated.
  • characterSetOrBounds can be a character set string or lower and upper bounds for character codes.

Examples:

Generating a 5-character random string from a character set:
random.String(5, "abc123") // Might evaluate to "1a2b3"

Creating a 10-character random string within character code bounds:
random.String(10, 65, 90) // Might evaluate to random uppercase letters

Producing a 15-character random string from a regex character class:
random.String(15, "[[:alnum:]]") // Might evaluate to a mix of letters and digits

random.Item

The random.Item function in CEL selects a random item from a given list of items.

Syntax:

random.Item(list)

Where:

  • list is an array or list from which a random item is selected.

Examples:

Selecting a random item from a list of fruits:
random.Item(["apple", "banana", "cherry"]) // Might evaluate to "banana"

Choosing a random number from a list:
random.Item([1, 2, 3, 4, 5]) // Might evaluate to 3

Picking a random word from a list:
random.Item(["hello", "world", "foo", "bar"]) // Might evaluate to "foo"

random.Number

The random.Number function in CEL generates a random integer within a specified range.

Syntax:

random.Number(min, max)

Where:

  • min is the minimum value of the range (inclusive).
  • max is the maximum value of the range (inclusive).

Examples:

Generating a random number between 1 and 10:
random.Number(1, 10) // Might evaluate to 7

Creating a random number between 50 and 100:
random.Number(50, 100) // Might evaluate to 89

Producing a random number between 0 and 1000:
random.Number(0, 1000) // Might evaluate to 456

random.Float

The random.Float function in CEL generates a random floating-point number within a specified range.

Syntax:

random.Float(min, max)

Where:

  • min is the minimum value of the range (inclusive).
  • max is the maximum value of the range (inclusive).

Examples:

Generating a random float between 0 and 1:
random.Float(0, 1) // Might evaluate to 0.572

Creating a random float between 5 and 10:
random.Float(5, 10) // Might evaluate to 7.283

Producing a random float between -1 and 1:
random.Float(-1, 1) // Might evaluate to -0.456

base64

base64.Encode

The base64.Encode function in CEL is used to encode input data into a Base64 string. The function can accept various types of input, including strings, byte slices, and types that can be converted to a byte slice.

Syntax:

base64.Encode(data)

Where:

  • data is the input you're encoding. It can be a string, byte slice, or any type that can be converted to a byte slice.

Examples:

Encoding a simple string:
base64.Encode("hello") // Expected Output: "aGVsbG8="

Encoding a number (which will first be converted to a string):
base64.Encode(12345) // Expected Output: "MTIzNDU="

Encoding a byte slice representation of a string:
base64.Encode([104, 101, 108, 108, 111]) // Expected Output: "aGVsbG8="

base64.Decode

The base64.Decode function in CEL is used to decode a Base64 encoded string back to its original form. The function returns the decoded string.

Syntax:

base64.Decode(encodedData)

Where:

  • encodedData is the Base64 encoded string you're decoding.

Examples:

Decoding a Base64 encoded string:
base64.Decode("aGVsbG8=") // Expected Output: "hello"

Decoding another example:
base64.Decode("MTIzNDU=") // Expected Output: "12345"

Decoding an encoded special character:
base64.Decode("4pyT") // Expected Output: "✓"

conv.Default

The conv.Default function in CEL is used to return the input value if it is true; otherwise, it returns the default value.

Syntax:

conv.Default(default, input)

Examples:

Using a truthy input value:
conv.Default("default", "input") // Evaluates to "input"

Using a falsy input value:
conv.Default("default", "") // Evaluates to "default"

Using a non-string input value:
conv.Default("default", 123) // Evaluates to 123

conv.Dict

The conv.Dict function in CEL is used to create a dictionary or map from the provided key-value pairs.

Syntax:

conv.Dict(key1, value1, key2, value2, ...)

Examples:

    //Creating a dictionary with string keys and values:
conv.Dict("apple", "fruit", "carrot", "vegetable") // Evaluates to {"apple": "fruit", "carrot": "vegetable"}

//Creating a mixed dictionary:
conv.Dict("name", "Alice", "age", 30) // Evaluates to {"name": "Alice", "age": 30}

//Creating a dictionary with nested values:
conv.Dict("user", conv.Dict("name", "Alice", "age", 30), "active", true) // Evaluates to {"user": {"name": "Alice", "age": 30}, "active": true}

crypto

SHA1

The crypto.SHA1 function in CEL is used to compute the SHA-1 hash of the input data. Note that SHA-1 is considered insecure for cryptographic purposes.

Syntax:

crypto.SHA1(data)

Where:

  • data is the input data to be hashed.

Examples:

Hashing a simple string:
crypto.SHA1("hello") // Might evaluate to "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c"

Hashing a number represented as a string:
crypto.SHA1("12345") // Might evaluate to "8cb2237d0679ca88db6464eac60da96345513964"

Hashing special characters:
crypto.SHA1("!@#") // Might evaluate to "8f9b6cb1cf7d70f23c16c9b9d4894d7f3b8fe15d"

SHA256

The crypto.SHA256 function in CEL calculates the SHA-256 hash of the provided input data, offering a balance between security and performance.

Syntax:

crypto.SHA256(data)

Where:

  • data is the input data to be hashed.

Examples:

Hashing a simple string:
crypto.SHA256("hello") // Might evaluate to "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824"

Hashing a number represented as a string:
crypto.SHA256("12345") // Might evaluate to "d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2d2"

Hashing special characters:
crypto.SHA256("!@#") // Might evaluate to "d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8d8"

SHA384

The crypto.SHA384 function in CEL is used for computing the SHA-384 hash of the input data, which is a truncated version of SHA-512 and provides enhanced security.

Syntax:

crypto.SHA384(data)

Where:

  • data is the input data to be hashed.

Examples:

Hashing a simple string:
crypto.SHA384("hello") // Might evaluate to a long hash string

Hashing a number represented as a string:
crypto.SHA384("12345") // Might evaluate to another long hash string

Hashing special characters:
crypto.SHA384("!@#") // Might evaluate to yet another long hash string

SHA512

The crypto.SHA512 function in CEL calculates the SHA-512 hash of the given input data. It's commonly used for data integrity verification and password storage.

Syntax:

crypto.SHA512(data)

Where:

  • data is the input data to be hashed.

Examples:

Hashing a simple string:
crypto.SHA512("hello") // Might evaluate to a very long hash string

Hashing a number represented as a string:
crypto.SHA512("12345") // Might evaluate to another very long hash string

Hashing special characters:
crypto.SHA512("!@#") // Might evaluate to yet another very long hash string




data.ToTOML

The data.ToTOML function converts a map or an array into a TOML formatted string.

Syntax:

data.ToTOML(data)

Where:

  • data is the map or array to be converted.

Examples:

Converting a map to a TOML string:
data.ToTOML({"name": "Alice", "age": 30}) // Evaluates to "name = \"Alice\"\nage = 30"

Handling an array (TOML arrays must be of the same type):
data.ToTOML({"people": ["Alice", "Bob"]}) // Evaluates to "people = [\"Alice\", \"Bob\"]"

An empty map:
data.ToTOML({}) // Evaluates to an empty string

Kubernetes

IsHealthy

The IsHealthy function in CEL is used to determine if a Kubernetes resource is healthy. It returns a boolean value indicating the health status of the resource.

Syntax:

IsHealthy(resource)

Where:

  • resource is the Kubernetes resource you're checking.

Examples:

Checking if a pod is healthy:
IsHealthy(pod) // Evaluates to true if the pod is healthy

Verifying the health of a service:
IsHealthy(service) // Evaluates to false if the service is not healthy

Assessing the health of a deployment:
IsHealthy(deployment) // Evaluates to true if the deployment is healthy

GetStatus

The GetStatus function in CEL retrieves the status of a Kubernetes resource as a string. It provides detailed information about the current state of the resource.

Syntax:

GetStatus(resource)

Where:

  • resource is the Kubernetes resource whose status you're retrieving.

Examples:

Retrieving the status of a pod:
GetStatus(pod) // Evaluates to "Running" if the pod is running

Getting the status of a service:
GetStatus(service) // Evaluates to "Active" if the service is active

Checking the status of a deployment:
GetStatus(deployment) // Evaluates to "Deployed" if the deployment is successful

GetHealth

The GetHealth function in CEL retrieves the health status of a Kubernetes resource as a map. The map contains key-value pairs providing detailed information about the resource's health.

Syntax:

GetHealth(resource)

Where:

  • resource is the Kubernetes resource whose health information you're retrieving.

Examples:

Retrieving the health information of a pod:
GetHealth(pod) // Evaluates to a map with keys and values indicating the pod's health

Getting the health information of a service:
GetHealth(service) // Evaluates to a map with keys and values indicating the service's health

Checking the health information of a deployment:
GetHealth(deployment) // Evaluates to a map with keys and values indicating the deployment's health

Math

Greatest

Returns the greatest valued number present in the arguments to the macro.

Greatest is a variable argument count macro which must take at least one argument. Simple numeric and list literals are supported as valid argument types; however, other literals will be flagged as errors during macro expansion. If the argument expression does not resolve to a numeric or list(numeric) type during type-checking, or during runtime then an error will be produced. If a list argument is empty, this too will produce an error.

    math.greatest(<arg>, ...) -> <double|int|uint>

Examples:

math.greatest(1)      // 1
math.greatest(1u, 2u) // 2u
math.greatest(-42.0, -21.5, -100.0) // -21.5
math.greatest([-42.0, -21.5, -100.0]) // -21.5
math.greatest(numbers) // numbers must be list(numeric)

math.greatest() // parse error
math.greatest('string') // parse error
math.greatest(a, b) // check-time error if a or b is non-numeric
math.greatest(dyn('string')) // runtime error

least

Returns the least valued number present in the arguments to the macro.

Least is a variable argument count macro which must take at least one argument. Simple numeric and list literals are supported as valid argument types; however, other literals will be flagged as errors during macro expansion. If the argument expression does not resolve to a numeric or list(numeric) type during type-checking, or during runtime then an error will be produced. If a list argument is empty, this too will produce an error.

    math.least(<arg>, ...) -> <double|int|uint>

Examples:

math.least(1)      // 1
math.least(1u, 2u) // 1u
math.least(-42.0, -21.5, -100.0) // -100.0
math.least([-42.0, -21.5, -100.0]) // -100.0
math.least(numbers) // numbers must be list(numeric)

math.least() // parse error
math.least('string') // parse error
math.least(a, b) // check-time error if a or b is non-numeric
math.least(dyn('string')) // runtime error

math.IsInt

The math.IsInt function in CEL checks if the given input is an integer. It returns a boolean value indicating whether the input is an integer or not.

Syntax:

math.IsInt(value)

Where:

  • value is the input value you're checking.

Examples:

Checking if a number is an integer:
math.IsInt(5) // Evaluates to true

Checking a float value:
math.IsInt(5.5) // Evaluates to false

Checking a string that represents an integer:
math.IsInt("5") // Evaluates to true

math.IsFloat

The math.IsFloat function determines if the provided value is a floating-point number. It returns a boolean indicating the result.

Syntax:

math.IsFloat(value)

Where:

  • value is the input being evaluated.

Examples:

Evaluating a floating-point number:
math.IsFloat(3.14) // Evaluates to true

Evaluating an integer:
math.IsFloat(7) // Evaluates to false

Evaluating a string representing a float:
math.IsFloat("3.14") // Evaluates to true

math.IsNum

The math.IsNum function checks if the provided value is a number (either integer or float). It returns a boolean value.

Syntax:

math.IsNum(value)

Where:

  • value is the input to check.

Examples:

Checking an integer:
math.IsNum(42) // Evaluates to true

Checking a float:
math.IsNum(3.14) // Evaluates to true

Checking a non-number string:
math.IsNum("hello") // Evaluates to false

math.Abs

The math.Abs function returns the absolute value of the given number. It supports both integers and floats.

Syntax:

math.Abs(number)

Where:

  • number is the input value.

Examples:

Getting the absolute value of a negative integer:
math.Abs(-5) // Evaluates to 5

Getting the absolute value of a float:
math.Abs(-3.14) // Evaluates to 3.14

Using a positive integer:
math.Abs(7) // Evaluates to 7

math.Pow

The math.Pow function calculates the power of the first number raised to the second number. It supports both integers and floats.

Syntax:

math.Pow(base, exponent)

Where:

  • base is the base number.
  • exponent is the exponent to which the base is raised.

Examples:

Calculating the power of integers:
math.Pow(2, 3) // Evaluates to 8

Calculating the power of floats:
math.Pow(2.5, 3.5) // Evaluates to approximately 24.705

Using a negative exponent:
math.Pow(2, -3) // Evaluates to 0.125

math.Seq

The math.Seq function generates a sequence of integers from the start value to the end value, incrementing by the step value.

Syntax:

math.Seq(start, end, step)

Where:

  • start is the starting value of the sequence.
  • end is the ending value of the sequence.
  • step is the increment step.

Examples:

Generating a sequence from 1 to 5:
math.Seq(1, 5, 1) // Evaluates to [1, 2, 3, 4, 5]

Generating a sequence with a step of 2:
math.Seq(1, 5, 2) // Evaluates to [1, 3, 5]

Generating a descending sequence:
math.Seq(5, 1, -1) // Evaluates to [5, 4, 3, 2, 1]

max

The math.Max function returns the maximum value among the provided numbers. It supports both integers and floats.

Syntax:

math.Max(a, b, ...)

Where:

  • a is the first number.
  • b is the second number.
  • ... represents additional numbers.

Examples:

Finding the maximum of integers:
math.Max(1, 2, 3) // Evaluates to 3

Finding the maximum of floats:
math.Max(1.2, 2.3, 3.1) // Evaluates to 3.1

Finding the maximum in a mixed list:
math.Max(1, 2.5, 3) // Evaluates to 3

min

The math.Min function returns the minimum value among the provided numbers. It supports both integers and floats.

Syntax:

math.Min(a, b, ...)

Where:

  • a is the first number.
  • b is the second number.
  • ... represents additional numbers.

Examples:

Finding the minimum of integers:
math.Min(1, 2, 3) // Evaluates to 1

Finding the minimum of floats:
math.Min(1.2, 2.3, 0.1) // Evaluates to 0.1

Finding the minimum in a mixed list:
math.Min(1, 2.5, 0) // Evaluates to 0

math.Ceil

The math.Ceil function returns the smallest integer greater than or equal to the provided float.

Syntax:

math.Ceil(value)

Where:

  • value is the floating-point number.

Examples:

Rounding up a positive float:
math.Ceil(2.3) // Evaluates to 3

Rounding up a negative float:
math.Ceil(-2.3) // Evaluates to -2

Using an integer:
math.Ceil(5) // Evaluates to 5

math.Floor

The math.Floor function returns the largest integer less than or equal to the provided float.

Syntax:

math.Floor(value)

Where:

  • value is the floating-point number.

Examples:

Rounding down a positive float:
math.Floor(2.7) // Evaluates to 2

Rounding down a negative float:
math.Floor(-2.7) // Evaluates to -3

Using an integer:
math.Floor(5) // Evaluates to 5

math.Round

The math.Round function rounds the provided float to the nearest integer.

Syntax:

math.Round(value)

Where:

  • value is the floating-point number.

Examples:

Rounding a positive float:
math.Round(2.5) // Evaluates to 3

Rounding a negative float:
math.Round(-2.5) // Evaluates to -3

Using an integer:
math.Round(5) // Evaluates to 5

Regexp

regexp.Find

The regexp.Find function in CEL is used to find the first occurrence of a pattern within a string. It returns the matched substring or an error if the pattern is invalid.

Syntax:

regexp.Find(pattern, input)

Where:

  • pattern is the regular expression pattern you're looking for.
  • input is the string you're searching within.

Examples:

Finding a pattern within a string:
regexp.Find("llo", "hello") // Evaluates to "llo"

Searching for digits within a string:
regexp.Find("\\d+", "abc123def") // Evaluates to "123"

Pattern not found in the string:
regexp.Find("xyz", "hello") // Evaluates to ""

regexp.FindAll

The regexp.FindAll function in CEL retrieves all occurrences of a pattern within a string, up to a specified count. It returns a list of matched substrings or an error if the pattern is invalid.

Syntax:

regexp.FindAll(pattern, count, input)

Where:

  • pattern is the regular expression pattern to find.
  • count is the maximum number of occurrences to return.
  • input is the string to search within.

Examples:

Finding all occurrences of a pattern:
regexp.FindAll("a.", -1, "banana") // Evaluates to ["ba", "na", "na"]

Limiting the number of matches:
regexp.FindAll("\\d", 2, "12345") // Evaluates to ["1", "2"]

Pattern not found:
regexp.FindAll("z", -1, "hello") // Evaluates to []

regexp.Match

The regexp.Match function in CEL checks if a string matches a given regular expression pattern. It returns a boolean value indicating the match status.

Syntax:

regexp.Match(pattern, input)

Where:

  • pattern is the regular expression pattern to match.
  • input is the string to check.

Examples:

Checking if a string matches a pattern:
regexp.Match("^h.llo", "hello") // Evaluates to true

Pattern does not match the string:
regexp.Match("^b", "apple") // Evaluates to false

Matching digits in a string:
regexp.Match("\\d+", "abc123") // Evaluates to true

regexp.QuoteMeta

The regexp.QuoteMeta function in CEL quotes all regular expression metacharacters inside a string. It returns the quoted string.

Syntax:

regexp.QuoteMeta(input)

Where:

  • input is the string containing metacharacters to be quoted.

Examples:

Quoting metacharacters in a string:
regexp.QuoteMeta("a.b") // Evaluates to "a\\.b"

String without metacharacters:
regexp.QuoteMeta("abc") // Evaluates to "abc"

Quoting a complex pattern:
regexp.QuoteMeta("[a-z].*") // Evaluates to "\\[a\\-z\\]\\.\\*"

regexp.Replace

The regexp.Replace function in CEL replaces occurrences of a pattern within a string with a specified replacement string. It returns the modified string.

Syntax:

regexp.Replace(pattern, replacement, input)

Where:

  • pattern is the regular expression pattern to replace.
  • replacement is the string to replace the pattern with.
  • input is the original string.

Examples:

Replacing a pattern in a string:
regexp.Replace("a.", "x", "banana") // Evaluates to "bxnxna"

Pattern not found:
regexp.Replace("z", "x", "apple") // Evaluates to "apple"

Replacing digits:
regexp.Replace("\\d+", "num", "abc123") // Evaluates to "abcnum"

regexp.ReplaceLiteral

The regexp.ReplaceLiteral function in CEL replaces occurrences of a pattern within a string with a specified replacement string, without interpreting the pattern as a regular expression. It returns the modified string or an error if the pattern is invalid.

Syntax:

regexp.ReplaceLiteral(pattern, replacement, input)

Where:

  • pattern is the substring to replace.
  • replacement is the string to replace the pattern with.
  • input is the original string.

Examples:

Replacing a substring:
regexp.ReplaceLiteral("apple", "orange", "apple pie") // Evaluates to "orange pie"

Substring not found:
regexp.ReplaceLiteral("z", "x", "apple") // Evaluates to "apple"

Replacing a pattern without regex interpretation:
regexp.ReplaceLiteral("a.", "x", "a.b c.d") // Evaluates to "x.b c.d"

regexp.Split

The regexp.Split function in CEL splits a string into a slice of substrings separated by a pattern. It returns the slice of strings or an error if the pattern is invalid.

Syntax:

regexp.Split(pattern, count, input)

Where:

  • pattern is the regular expression pattern that separates the substrings.
  • count is the maximum number of splits. Use -1 for no limit.
  • input is the string to split.

Examples:

Splitting a string by a pattern:
regexp.Split("a.", -1, "banana") // Evaluates to ["", "n", "n"]

Limiting the number of splits:
regexp.Split("\\s", 2, "apple pie is delicious") // Evaluates to ["apple", "pie is delicious"]

Pattern not found:
regexp.Split("z", -1, "hello") // Evaluates to ["hello"]