Skip to content

A super simple SASjs app for uploading a local file to a directory on the Viya server

Notifications You must be signed in to change notification settings

sasjs/fileuploader

Repository files navigation

Gitpod ready-to-code

Demo SASjs File Uploader app

This is a vanilla JS demo app to show how to build a SAS-Powered file upload process. The app has a logon screen, then an input box (so the user can provide a target directory path), and a file picker.

The file is sent to SAS where the path is verified, the file is written, and a directory listing is returned.

If the file is greater than 5mb it is sent to SAS in chunks, with a progress bar displayed. A video demonstrating this process is available here: https://www.youtube.com/watch?v=rf9myXovrsk

screenshot of sasjs file uploader

If the user logs out of SAS whilst an upload is in progress, then the app will prompt for credentials on the next request. The "redirect" flow is implemented, which is compatible with 2FA and other more complex authentication mechanisms.

Fast Deploy

This app can be deployed as a streaming SAS app by running the code below. Be sure to set the value of appLoc to your preferred parent folder location in metadata (SAS 9) or SAS Drive (Viya).

%let apploc=/Public/app/fileuploader;
filename mc url "https://raw.githubusercontent.com/sasjs/fileuploader/master/stream.sas";
%inc mc;

The link to open the app will be shown in the log.

Alternatives

It is also possible to upload files using SAS Studio, into your home directory (you can set symlinks to other locations).

If your use case is simply about loading data into SAS, you might want to consider https://datacontroller.io (lets you load excel and CSV files into any SAS table or database with full audit trail - it's also free for up to 5 users).

Building from Source

To deploy this app, first install the SASjs CLI - full instructions here.

Next, run sasjs add to prepare your target (instructions).

Then run the below to deploy the backend (SAS) services:

npm install
sasjs cbd -t YOURTARGET

If you don't have the ability to sasjs add due to not having access to a client / secret, you can instead run sasjs cb and execute the resulting sasjsbuild/build.sas script in SAS Studio V to create the backend services.

Frontend

Configuration

Open index.html and make sure the value for appLoc is the same as that used when deploying the backend (sasjsconfig.json).

Also, update the <script> tag so that SASjs is pointing to a CDN (or copy the file from node_modules into the src folder and use a relative reference).

Deployment

The frontend (src folder) is deployed to your SAS Web server (/var/www/htdocs folder) - you can upload manually, or using the supplied NPM script in package.json.

To be able to run the deploy script, two environment variables need to be set:

SSH_ACCOUNT - your SSH account, this is of the form username@domain.com DEPLOY_PATH - the path on the server where sasjs-tests will be deployed to, typically /var/www/html/<some-subfolder>.

You can run the script like so:

SSH_ACCOUNT=me@my-sas-server.com
DEPLOY_PATH=/var/www/html/my-folder/file-uploader
npm run deploy

Closing remarks

If you have any problems, please just raise an issue! And if you find it useful, we'd appreciate a STAR.

For more information on the SASjs framework, see https://sasjs.io

About

A super simple SASjs app for uploading a local file to a directory on the Viya server

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages