NOTE: this SDK supports code written for input data of class move2
and not moveStack
, as all input data of class moveStack
will be converted to class move2
. For all other input/output types, this SDK works as usual. Please contact us under support@moveapps.org if you have any questions.
This documentation provides a short introduction to the MoveApps R SDK.
As a first step, and before your read this, you should have used this GitHub template to create a copy of it in your personal space and named the repository as your App will be named in MoveApps.
The MoveApps User Manual provides a step-by-step explanation of how to create an App. Please carefully follow these steps when creating a MoveApps App.
This template is designed according to a file structure that is necessary for your App to run in your local development environment similar to the way it will run in the MoveApps environment later. Please contain the structure and only change/add files as necessary for your App's functionality. Take a look at the overview in the User Manual to see which files can be changed and which should remain as is for simulation of the behaviour on MoveApps on your local system.
Here you find an overview of the files and their function in the SDK:
./RFunction.R
: must be modified by the developer. This is the entrypoint for your App logic. MoveApps will call this function during a Workflow execution which includes your App. The file must be namedRFunction.R
, do not alter it. See Step 3 in the User Manual../appspec.json
: must be modified by the developer. This file defines the settings and metadata of your App. See Step 5 in the User Manual../README.md
: must be modified by the developer. Provided template for the documentation of the App (see Step 6 in the User Manual)../tests/**
: must be modified by the developer. Location for Unit Tests. See Step 4 of the User Manual../renv.lock
: Definition of the dependencies of your App. We userenv
as library manager. Optional, see below../sdk.R
: use for App testing. The main entrypoint of the SDK. Use it to execute your App in your compiler (e.g. RStudio)../app-configuration.json
: adjust for App testing. The configuration/settings file of your App (in JSON format - must correspondent with thesettings
of yourappspec.json
, see MoveApps parameters for an example)./.env
: adjust for App testing. Defining the SDK Runtime environment, see below. Make sure to check Show Hidden Files in the settings menu of the Files tab in RStudio../data/**
: use for App testing. Resources of the SDKauxiliary/**
: Simulates the usage of auxiliary files. You can put files into this folder to simulate an App run with provided/user-uploaded files.output/**
: The output data (output.rds
) that will be passed on to the next App in a Workflow and other output files (artifacts) that your App may produce will be stored here. See producing artifacts for more information.raw/**
: Collection of sample App input data. You can use these data to test an App run with real input.
- all remaining files are used to emulate MoveApps when testing the App locally, to setup the automatic sync of your repository with the template, or to provide information related to the template. These files are not to be modified. Modifying them will prevent you from testing your App appropriately.
Critical parts of the SDK can be adjusted by environment variables
. Keep in mind that these variables are only changeable during App development and not during an App run on MoveApps. They are predefined with sensible defaults - they should work for you as they are. While testing your App you will want to modify the SOURCE_FILE
variable to either call the different example data sets provided in the template or other data sets that you want to use to test your App.
CONFIGURATION_FILE
: path to the configuration/settings file of your App (in JSON format - must correspondent with thesettings
of yourappspec.json
, see MoveApps parameters for an example of theapp-configuration.json
file).PRINT_CONFIGURATION
: prints the configuration your App receives (yes|no
)SOURCE_FILE
: path to an input file for your App during developmentOUTPUT_FILE
: path to the output file of your AppERROR_FILE
: path to a file collecting error messagesAPP_ARTIFACTS_DIR
: base directory for writing App artifactsUSER_APP_FILE_HOME_DIR
: home aka base directory of your local user/auxiliary App filesCLEAR_OUTPUT
: clears all output of the previously app run at each start of the SDK aka the next app start
You can adjust these environment variables by adjusting the file ./.env
.
The file ./.env
is hidden by default in RStudio
! You can show it by
- Tab
Files
inRStudio
More
Button in the Files-Toolbar- Activate Show Hidden Files
Which files will be bundled into the final App running on MoveApps?
-
the file `./RFunction.R
-
all directories defined in your
appspec.json
atprovidedAppFiles
-
the file
./appspec.json
will be used to build and create the metadata of your App -
the file
./README.md
will be reference to for the documentation of your App
Nothing else.
The template is prepared to use renv
as a dependency manager - but is disabled by default (opt-in).
You can activate renv
with renv::activate()
and then use it in the usual renv
workflow.
Your app will be executed on MoveApps in a Docker container. Specially for debugging errors that are not straight forward, it can be very useful to execute your App in a docker container. These more complex errors are often due to system libraries that need to be installed in MoveApps to run the App. The easiest way to find out which ones they are is to run the App locally in a docker container:
- enable
renv
(see above) - set a working title for your app by
export MY_MOVEAPPS_APP=hello-world
(in your terminal) - build the Docker image locally by
docker build --platform=linux/amd64 -t $MY_MOVEAPPS_APP .
(in your terminal) - execute the image with
docker run --platform=linux/amd64 --rm --name $MY_MOVEAPPS_APP -it $MY_MOVEAPPS_APP
(in your terminal) - you will get a
bash
terminal of the running container. There you can get a R console byR
or simply start your app by invoking/home/moveapps/co-pilot-r/start-process.sh
(in thebash
of the running container)
This template includes a GitHub action to keep your copy synchronized with the original template. Take a look at the documentation and make sure to keep your repository up-to-date.