Upload data programmatically
Programmatic uploads to the Data Platform use capabilities provided by the underlying Flywheel system. There are two options:
- use the Flywheel CLI tool, or
- use a Flywheel provided SDK, available for both Python and MatLab.
Flywheel CLI
The first option is to use software that is already built and can be used to perform transfers from a computer using the command line. Flywheel has two CLI options, but only one currently allows file transfers from a local computer: the Classic Flywheel CLI tool. (If you are transferring files to cloud storage such as AWS S3, the Beta Flywheel CLI tool is the better option.)
We recommend using the CLI if your goal is to upload files from the command line. The tool can be downloaded from the Classic Flywheel CLI tool page and installed locally.
Once you have the CLI running, the command
fw ls
will list the Flywheel groups that you can access. Most people will only see one, which is for their center. (If it looks weird, please ask.)
To see which pipeline projects you can access, use the command fw ls
followed by the center group name.
For instance, the command
fw ls sample-center
shows the projects in the group labeled sample-center
.
Use the label for your center instead and you will see the projects you can access.
The pipelines that allow upload start with either ingest-
or sandbox-
.
Use the sandbox-
pipeline project while you are figuring things out, and when you are ready to submit actual data use the ingest-
project.
The pipelines are specific to data types:
- If you are authorized to upload research form data you will see
ingest-form
andsandbox-form
. - If you are authorized to upload enrollment form data you will see
ingest-enrollment
andsandbox-enrollment
.
If you don't have any of these pipeline projects, you have not been authorized by the center administrator.
To upload a file to sandbox-form
, you need the group label from running fw ls
.
We will use sample-center
as the group.
The command
fw upload dummy_data-uds.csv fw://sample-center/sandbox-form
will upload the file dummy_data-uds.csv
in the current working directory.
File name should have -[module].csv
suffix. Find the list of file name suffixes for currently supported modules here.
Flywheel SDK
The second option is limited to scenarios where a center wants to transfer data directly from their data systems without direct human involvement. Building this integration will require someone who is able to build the software that performs the transfer.
For more details on how to build integrations between systems, see the NACC Data Platform Demos.