Domain Specific Types
Table of Contents
Introduction to Fly Objects
The main domain type is the object type. A FLY object is a heterogeneous collection of basic and/or domain types elements.
Essentially a FLY object is a mixture between an array and map data structure, which stores data in key/value pair.
The value of an element can be accessed in two different ways: by position (like arrays) or by key (like maps). When a new value is assigned to a given key/position a new element is created, otherwise the new value replaces the previous one.
Moreover, all FLY domain specific type are an instance of the object type, which means are build in similar fashion, specifying the object type using the parameter keyword type = “object_type”
.
Object Domain Types
Let’s see which are all the domain specific types provided by FLY
Environments
The Environment type represents an abstraction of a execution environment. It provides the ability to interact with a cloud provider or a SMP system. Different environments are treated in the same way by FLY, leaving the details relating to the specific use of each execution environment to the FLY compiler.
Environments are declared as an object using several parameters that characterize a back-end.
SMP
The SMP backend is the local machine execution environment, and can be used to execute functions on the local machine.
var Smp = [type="smp", nthread=4]
- nthread parameter is the number of threads used by the local stack to execute the FLY program, it must be an integer greater then 2.
Azure
The Azure backend offer the transparent communication with the Microsoft Azure Cloud, specifing the following parameters.
var Azure = [type="azure", client_id="<client>", tenant_id="<tenant>", secret_key="<secret>", subscription_id="<subscription>", region="<region>", language="<language>", nthread=3, seconds=1]
- client_id: the Azure Client ID
- tenant_id: the Azure Tenant ID
- secret_key: the secret key of Azure services
- subscription_id: the subscription ID of Azure services
- region: the Azure region you want to use
- language: the programming language to use (see the introduction chapter)
- nthread: the number of threads you want to use on AWS backend
- seconds: the time for each execution limit of the backend
AWS
The AWS backend offer the transparent communication with the AWS Cloud, specifing the following parameters.
var Aws = [type="aws", profile="<profile>", access_id_key="<id>", secret_access_key="<secret>", region="<region>", language="<language>", nthread=4, memory=256, seconds=1]
- profile: the AWS profile name
- access_id_key: the secret ID key of AWS services
- secret_access_key: the secret key of AWS services
- region: the region you want to use
- language: the programming language to use (see the introduction chapter)
- nthread: the number of threads you want to use on AWS backend
- memory: the memory limit of the backend
- seconds: the time for each execution limit of the backend
Also, FLY provides a testing beckend with type = "aws-debug"
which simulates AWS Cloud on the local machine. Obiously, the parameter declaration doesn’t change.
var Test = [type="aws-debug", profile="<profile>", ...]
Good Programming Note
As a note for developers, each envirnoment variable should be delcared with an uppercase identificator.
Channels
Channel type is a domain type that enables the synchronization and communication between FLY functions and/or the main program, defined by the type = “channel”
.
A new channel is defined on an environment, and can be used for the communication between functions executing on the same back-end or from the main program to a back-end and viceversa.
Channels are blocking message queues, that is, when the main program or a function tries to receive a message from a channel, the execution is blocked until a new message arrives on the channel.
Each channel must be defined on a specific back-end, using the keyword on
after the variable declaration.
var ch = [type="channel"] on <Backend>
where Backend is an environment variable previously declared.
Communication Statements
Messages are sent on a channel using the character !
(e.g., the instruction ch!VAL sends a message VAL on the channel ch), while the character ?
is used to receive messages, (e.g., the instruction x=ch? reads a message from the channel ch and assigns the obtained value to the variable x).
Channels use network infrastructures to communicate with the cloud environment and for this reason a serialization mechanism is required for sending/receiving messages. FLY defines the serialization for objects, files, images and basic types. It is not allowed to send messages containing environments, channels, and random objects.
File
File object is the abstraction of file in FLY. The language supports four file formats: csv, json, img, and txt.
A new file object is defined using also additional parameters: path (the file system path) or a reference to the file, and by the separator sep, that is an optional parameter defined for CSV files.
The language provides two methods to access files, which depend on where the file is stored: local or remote.
var name = [type=”file” , path="path/to/the/file.(txt, json, csv, img)" , sep="separator"] on Env ( optional )
If the environment will not be specified, FLY’ll assume the file locally.
Dataframe
FLY has a specific focus on csv files managing them as a Dataframe (similar to R language dataframes). The memory is seen as a matrix structure, allowing the user to access to rows and columns, while it provides dedicated operations for querying, filtering, random access, etc.
var table = [type="dataframe", table_name=STRING, source=(STRING | SQL_VARIABLE), separator=STRING, header=("true", "false"), query=STRING]
The syntax is the following:
- type: must be “dataframe”;
- table_name: the STRING representing the name of the table;
- source: the source from which obtain the table. Can be a csv file path or a SQL variable;
- separator: (only if source is a csv file) the separator to use. Is an optional parameter and the default value is ”,”;
- header: (only if source is a csv file) “true” if the file contains an header row to ignore, “false” otherwise. Is optional and the default value is “true”.
- query: (only if source is a SQL variable) the query to retrive data from the file. Is an optional parameter and the default value is “SELECT * FROM table_name”;
Database Connection
Database specific types can be used to interact with a SQL or a NoSQL Database instance.
A prerequisite is that both the instance on the cloud provider and the database are already created as the creation of a new instance takes too long to start, which goes against the goal of providing high performance of FLY.
SQL
The following are three example of SQL database connection.
Local Database connection:
var dbLocal = [type="sql", db_name=STRING, user=STRING, password=STRING] on Local
AWS Database connection
var dbAWS = [type="sql", instance=STRING, db_name=STRING, user=STRING, password=STRING] on CloudAWS
Azure Database connection
var dbAzure = [type="sql", resource_group=STRING, instance=STRING, db_name=STRING, user=STRING, password=STRING] on CloudAzure
The syntax is specified by the following parameters:
- type: must be “sql” for the SQL Database;
- db_name: the name of the Database;
- resource_group: (only on Azure): the resource group in which is hosted the Database instance;
- instance: (only on Azure and AWS): the name of the instance on wich the Database is running;
- user: the username to access to the Database instance;
- password: the secret password to access to the Database instance;
NoSQL
FLY can also manage Database connection object that communicate with NoSQL Databases. The syntax is specified by the following parameters:
- type: must be “nosql” for the NoSQL Databases;
- endpoint: (only when resource_group and instance parameters are not specified) represents the database endpoint string;
- db_name: the name of the Database;
- resource_group: (only on Azure Database): the resource group in which is hosted the Database instance;
- instance: (only on Azure and AWS): the name of the instance on wich the Database is running;
- collection: the name of the database collection;
- properties: (optional parameter) the absolute path of the file log4j.properties
- user: the username to access to the Database instance;
- password: the secret password to access to the Database instance;
Query
A Query Object domain can be used to make CRUD operations over Databases.
A Query variable can be defined with the following syntax for the SQL database interactions:
var query = [type="query", query_type=("update" | "value"), connection=SQL_VARIABLE, string=QUERY_STRING]
- type: must be “query”;
- query_type: is the type of the query and can be value if the query must return a table as a result (SELECT), or update if the query must modify a value in the Database (INSERT / DELETE / UPDATE);
- connection: is a variable of type SQL on which executing the query;
- string: is the effective query to execute (eg. SELECT * FROM table). Can be also a string variable;
Query objects can be used to make CRUD operation over NoSQL Databases. The syntax is very similar to the previous one:
var query = [type="query", query_type=("select" | "insert" | "update" | "replace" | "delete"), connection=NOSQL_VARIABLE, string=QUERY_STRING]
The parameter description is the same of the SQL Database Query, the only difference is given by the query_type.
Once the Query variable is defined, can be used the execute function to execute the query:
var result = query.execute() // or just query.execute() if the query type is update
Distributed Query
TODO da approfondire.