File Upload - Amazon S3 Storage or Alpha Anywhere Server

Description

Upload one or more files to Amazon S3 or to the Alpha Anywhere server.

Discussion

The File Upload - Amazon S3 Storage or Alpha Anywhere Server action can be used to upload one or more files to either Amazon S3 or the Alpha Anywhere server.

If you are uploading files in a data bound UX Component, the File Upload action is more appropriate.

If you are uploading files in a PhoneGap mobile application, see PhoneGap - File Upload.

Target Server Properties 

  • Upload target 

    Specify the target server to which files should be uploaded. You can upload to Amazon S3, or the Alpha Anywhere server.

    Target
    Description
    S3

    Images will be uploaded to Amazon S3. Specific information about the destination S3 bucket is specified in the Amazon S3 File Upload Properties.

    AlphaAnywhere

    Files will be uploaded to the Alpha Anywhere Server. You must define an Xbasic function to handle the files after they have been uploaded.

  • Options available for the 'S3' Upload target.
  • Options available for the 'AlphaAnywhere' Upload target.
  • Xbasic function 

    The Xbasic function to call when a file is uploaded to the Alpha Anywhere server. The Xbasic function will be called once for each file uploaded to the Alpha Anywhere server. Your code can process the file in any way that you want. For example, you might want to store the file in permanent storage on disk or in a database.

    The Xbasic function will be passed an 'e' object that contains information about the uploaded file as well as the component definition.

    Property
    Description
    e.tmpl

    The component definition.

    e.sourceFileName

    The source filename on the client-side (this is the name of the file that was uploaded).

    e.contentType

    The content type of the uploaded file.

    e.characterSet

    The character set of the upload file.

    e.encoding

    The encoding of the uploaded file.

    e.size

    The size of the uploaded file.

    e.localFileName

    A temporary file on the server where the uploaded file has been stored. This is the file that your code must process in some way.

    If you define any additional info to submit, the 'e' object will also contain the e.__additionalInfo property. (See Additional info to submit - Javascript for more information.)

    function afterUpload as v (e as p)
    
        'Example:
        'Store the uploaded file permanently in the 'myuploads' folder relative to the Webroot folder
    
        'get the webroot folder
        dim webroot as c
        webroot = a5_default_path
    
        dim targetFolder as c ="myuploads"
    
        dim targetFolderFullyQualified as c
        targetFolderFullyQualified = a5_removetrailingbackslash(webroot) + chr(92) + targetFolder
    
        'make sure that the target folder exists
        dir_create_recurse(targetFolderFullyQualified)
    
        dim targetFilename as c
        targetFilename = targetFolderFullyQualified + chr(92) + e.sourceFileName
    
        'copy the temporary file to the permanent location
        file.copy2(e.localFilename,targetFilename)
    
    end function

    The Xbasic function property is only available if Upload target is set to 'AlphaAnywhere'.

  • Additional info to submit - Javascript 

    Specify the Javascript to execute to collect any information from the client-side that you want to make available to the Xbasic function. Your code should return a string. The data returned by this function will be available in the Xbasic function in a property called e.__additionalInfo.

    Your JavaScript can return a single value to pass to the Xbasic function (e.g. '12') or multiple values as name-value pairs using JSON notation (e.g. '{"folder": "myfolder", "type": "type"}'. For example:

    function additionalInfo() {
        var info = {}
        info.folder = {dialog.object}.getValue('TargetFolder');
        info.type = {dialog.object}.getValue('UploadType');
    
        return JSON.stringify(info);
    }

    To read the variables passed in the JSON string, you will need to parse the e.__additionalInfo object to convert the string to Xbasic variables. This is done using the json_parse() Xbasic function:

    dim additionalInfo as c = ""
    if variable_exists("e.__additionalInfo") then
        ' assign e.__additional info to the local additionalInfo variable
        additionalInfo = e.__additionalInfo
    end if
    dim pi as p
    if additionalInfo <> "" then
        ' Parse the JSON in additionalInfo
        pi = json_parse(additionalInfo)
    end if
    
    'define pi.folder and pi.type in case they not defined in the e.__additionalInfo JSON string.
    dim pi.folder as c = default ""
    dim pi.type as c = default ""

    The Additional info to submit - Javascript property is only available if Upload target is set to 'AlphaAnywhere'.

File Selection Properties 

  • Method for selecting files 

    Specify if the user can select the file(s) to be uploaded, or if the data for the file to be uploaded will be supplied (in the form of a base64 encoded string -- that is formatted as a 'data URI' e.g. ....). Choices include User selects file(s), Base64Data.

  • Javascript function to get base64 encoded data 

    Specify the name of the Javascript function that will return the base64 encoded data to be uploaded. Returned base64 data is expected to be in data URI format. e.g. ......

Amazon S3 File Upload Properties Properties 

These properties are only available if the Upload target has been set to 'S3'.

  • Method for specifying Amazon S3 credentials and bucket 

    Should the Amazon S3 credentials and bucket be read from a named storage connection string, or do you want to specify explicit values for the access key, secret and bucket. Choices include Named Storage Connection String and Explicit.

  • Storage connection string 

    Specify the named storage connection string. This property is only available if Method for specifying Amazon S3 credentials and bucket has been set to 'Named Storage Connection String'.

    The storage connection string MUST NOT BE ENCRYPTED.

    To define a storage connection string, go to the Tools menu in the Web Projects Control Panel.

  • Access key 

    Specify the access key. This property is only available if Method for specifying Amazon S3 credentials and bucket has been set to 'Named Storage Connection String'.

  • Secret 

    Specify the secret. This property is only available if Method for specifying Amazon S3 credentials and bucket has been set to 'Named Storage Connection String'.

  • Bucket 

    Specify the bucket where files should be uploaded on Amazon S3. This property is only available if Method for specifying Amazon S3 credentials and bucket has been set to 'Named Storage Connection String'.

    In order to upload files directly from the browser to Amazon S3, you must set the CORS configuration on your Amazon S3 bucket.

    To set the CORS configuration on a bucket, open the Amazon Web Services Management console, select the bucket, then click the Properties button. Open the permissions section and then click the Edit CORS Configuration button.

    Below is a sample configuration definition that you can paste into the dialog that Amazon displays:

    <CORSConfiguration>
        <CORSRule>
            <AllowedOrigin>*</AllowedOrigin>
            <AllowedMethod>PUT</AllowedMethod>
            <MaxAgeSeconds>3000</MaxAgeSeconds>
            <AllowedHeader>Content-Type</AllowedHeader>
            <AllowedHeader>x-amz-acl</AllowedHeader>
            <AllowedHeader>origin</AllowedHeader>
        </CORSRule>
    </CORSConfiguration>
  • Authenticated read 

    Specify if authentication is required to read the object once it has been uploaded to S3.

  • S3 Timeout 

    Specify the S3 timeout in milliseconds. This is the amount of time allowed before authorization to upload files to S3 will expire. If you have a lot of files to upload, you may want to increase this value. Suggested value is 600.

Validation Properties 

  • Allow multiple files 

    Specify if the user can upload multiple files at once, or just a single file.

  • Maximum file size 

    Specify the maximum size file that the user can select. Set to -1 for no maximum.

  • Max file size exceeded error message 

    Specify message to show if user selects a file that is too big. You can use language or text dictionary tags. Your message can include these placeholders: [filename], [filesize], [maxfilesize]. Leave blank if you have defined a custom Javascript onValidate event handler.

    This property is only available if Maximum file size is not -1.

    Selected file [filename] (size [filesize]) exceeds the maximum allowed file size of [maxfilesize].
  • Max total file size 

    Specify the maximum total size of all selected files. Set to -1 for no maximum. This property is only available if Allow multiple files has been enabled.

  • Max total file size exceeded error message 

    Specify message to show if all files selected exceed the max allowed. You can use language or text dictionary tags. Your message can include these placeholders: [filecount], [totalfilesize] and [maxtotalfilesize]. Leave blank if you have defined a custom Javascript onValidate event handler.

    This property is only available if Max total file size is not -1.

    Selected files ([filecount] files, total size [totalfilesize]) exceed the maximum allowed total file size of [maxtotalfilesize].
  • Allowed file types 

    Enter a comma delimited list of allowed file extensions. Leave blank to allow all file extensions.

  • Invalid file type error message 

    Specify message to show if all files selected exceed the max allowed. You can use language or text dictionary tags. Your message can include these placeholders: [filename], [filetype]. Leave blank if you have defined a custom Javascript onValidate event handler.

    This property is only available if Allowed file types is not blank.

  • Display progress during file upload 

    Specify if progress should be shown while file(s) are being uploaded.

  • Allow cancel 

    Specify if the user can cancel an upload while the file is being uploaded. This property is only available if Display progress during file upload is enabled.

  • Progress indicator type 

    Specify the progress indicator style. 'Text' - display the percentage as text, 'Bar' - display a progress bar. Choices include Text, Bar. This property is only available if Display progress during file upload is enabled.

  • Progress bar color 

    Specify the progress bar color. This property is only available if Progress indicator type is set to 'Bar' and Display progress during file upload is enabled.

  • Progress bar width 

    Specify the progress bar width. Use CSS units. This property is only available if Progress indicator type is set to 'Bar' and Display progress during file upload is enabled.

  • Placeholder for progress indicator 

    Specify the name of a Placeholder control where the progress indicator should be shown. This property is only available if Display progress during file upload is enabled.

Javascript Properties 

  • Target object name on Amazon S3 

    You can define a function that returns the name of the object in Amazon S3. By default, the filename of the file on the client will be used. Your code can reference e.name, e.size and e.type (the client-side name, size and mime-type of the selected file). Your function must return the name to use. The name can include a folder. For example: return 'myfolder1/' + e.name. This will use the same name as the client-side file but the object will be stored in a folder called 'myfolder1'. NOTE: The target name on Amazon will be available to other Javascript functions in the e.targetName property.

  • Before file select 

    Fires before the user selects file(s). If the Javascript contains 'return false;', the file upload is aborted.

  • After file select 

    Fires after file(s) have been selected, but before any files have been uploaded. If your code includes 'return false' the upload is aborted. You code can reference 'e' - an array of objects with information about each file selected. Each item in the array contains these properties: name, size, type.

  • On Progress 

    Fires when another 'chunk' of the file being uploaded has been sent. This event allows you to write custom progress displays. Your code can reference these variables: e.percent - percentage complete, e.message - message describing the current state of the upload operation, e.name - name of the file being uploaded, e.number - if more than one file was selected, the number of file, e.size - the file size and e.type - the mime-type of the file, e.targetName - the name to use on Amazon to store the file (usually the same as e.name unless your 'Target name on Amazon S3' function returned a different name or specified a folder)

  • On Error 

    Fires if there is any type of error. Your Javascript can reference e.errorText, e.errorCode - the XHR error code and e.fileObject - an object with properties (such as name, size, type) for the file on which the error occurred.

  • On Upload Complete - Individual File 

    Fires after a file upload has been completed. This event will fire for each individual file this is uploaded and the 'On Upload Complete - All Files' event will fire after all files have been uploaded. Your code can reference this variables: e.name - name of the file just uploaded, e.type - mime-type, e.aborted - true if the user cancelled, e.size - file size, e.number - if more than one file was uploaded, the number of the file and and e.targetName - the name to use on Amazon to store the file (usually the same as e.name unless your 'Target name on Amazon S3' function returned a different name or specified a folder).

  • On Upload Complete - All Files 

    Fires after all selected files have been uploaded. You code can reference e.fileArray - an array of objects containing information about each file that was uploaded. Each item in the array has these properties, name, size, type,aborted, targetName (name used on Amazon - same as name unless you specified a different name).

  • On Upload Complete 

    Fires after the selected file has been uploaded. Your code can reference this variables: e.name - name of the file just uploaded,e.aborted - did the user abort the upload, e.type - mime-type, e.size - file size, e.targetName - name used on Amazon.

  • On validate error 

    Fires if any of the selected files violate a validation rule. Your Javascript can refer to e.violationType ( can be 'size', 'totalSize' or 'type'), e.name, e.size and e.type.

See Also