Skip to main content

Upload File to SFTP

Introduction

This document outlines the process for creating a Cloud Scheduler job to upload files to an SFTP server. The job will upload specific files according to a scheduled time and frequency.

Creating a Scheduler for SFTP Uploads

To create a scheduler for this task, follow these steps:

  1. Navigate to Cloud Scheduler in the Google Cloud Console.
  2. Select CREATE JOB to begin setting up the scheduler.

Preparation Checklist

Ensure the following resources are in place before scheduling the job:

  • SFTP server
  • Pub/Sub topic
  • Google Cloud Storage bucket

Setup Requirements

Create a Cloud Scheduler job with the following parameters:

  • Name: Upload file to SFTP
  • Region: europe-west2 (Select the region closest to your SFTP server for optimal performance)
  • Frequency: 0 9 * * 1 (This cron expression schedules the job to run every Monday at 9:00 AM)
  • TimeZone: British Summer Time (BST)
  • Target Type: Pub/Sub (This will trigger a Pub/Sub topic when the job is executed)
  • Cloud Pub/Sub Topic: There are two versions of this topic:
    • projects/<projectId>/topics/UploadFileToSFTP (uses password-based authentication)
    • projects/<projectId>/topics/uploadFileToSFTPUsingKeyAuth (uses key-based authentication) (Replace <projectId> with your actual project ID)

Key Generation (Key Based Authentication)

NOTE: Will be added soon... (There will be some changes done in how the secrets will be managed, after that this section will be updated)


JSON Object for SFTP Upload Scheduler

The following JSON object will be used in the Pub/Sub message payload:

Password-based Authentication:

{
"sftpHostAddress": "eu-central-1.sftpcloud.io",
"username": "90aed4d72ece4e17ae34bf08834ba559",
"password": "e6BRyesOeEjT5zWJPdTausExz3DsO1",
"bucketName": "biddirect-2.appspot.com",
"sourceFolderName": "supplier-import/",
"sourceFileName": "/^invoice_\\d{6}\\.txt$/",
"destinationFolderName": "./Inbound/SubFolder/",
"emailId": "mailgundev@digitalinnk.com",
"errorEmailId": "mailgundev@digitalinnk.com",
"emailSubject": "SFTP File Upload"
}

Key-based Authentication:

{
"sftpHostAddress": "eu-central-1.sftpcloud.io",
"username": "90aed4d72ece4e17ae34bf08834ba559",
"bucketName": "biddirect-2.appspot.com",
"sourceFolderName": "supplier-import/",
"sourceFileName": "/^invoice_\\d{6}\\.txt$/",
"destinationFolderName": "./Inbound/SubFolder/",
"emailId": "mailgundev@digitalinnk.com",
"errorEmailId": "mailgundev@digitalinnk.com",
"emailSubject": "SFTP File Upload"
}

Payload Description

The payload for configuring Cloud Scheduler includes the following parameters:

Sr.NoPayloadDescription
1sftpHostAddressThe address of the SFTP server where files will be uploaded.
2usernameThe username for authentication with the SFTP server.
3passwordThe password associated with the username for SFTP server access. This is only required for password-based authentication.
4bucketNameThe Google Cloud Storage bucket name where files are stored before upload.
5sourceFolderNameThe folder within the bucket containing the source files.
6sourceFileNameThe specification for the files to be uploaded can be defined in two ways:
  • Regular Expression Pattern: A pattern to match specific file names for upload. The regex should start with / and end with /.
    • Example 1:
      /^invoice_\d6\.txt$/
      matches files like invoice_123456.txt.
    • Example 2:
      /^VOR_ACTION_EXPORT_\d2_\d2_\d4\.csv$/
      matches files like VOR_ACTION_EXPORT_23_08_2024.csv.
  • Exact File Name: Specify the exact file name that needs to be uploaded.
7destinationFolderNameThe target directory on the SFTP server where files will be placed.
8emailIdThe email address to receive notifications upon successful uploads.
9errorEmailIdThe email address to receive notifications if upload fails.
10emailSubjectThe subject line for notification emails post-upload.

Scheduler Creation Instructions

To set up the scheduler, follow these steps:

  1. Define the Scheduler: Configure the name, region, frequency, and timezone.
  2. Configure Scheduler: Target the Pub/Sub topic you created.
  3. Optional Settings: Add any required message body or authentication details.
Define Scheduler
Configure Scheduler
Optional Scheduler Settings

Testing Procedure (Password-based Authentication)

To test the setup, use a free trial demo account from SFTP Cloud:

  1. Visit the website and click Create test SFTP server.
  2. Note the temporary host, username, password, and SFTP host details (valid for 1 hour).
  3. Update the Pub/Sub payload with these details and save the changes.
  4. Upload a file using this temporary setup.
  5. The process will be logged in the Di-Admin under the Process Log section.
    Optional Scheduler Settings

Tip: Use FileZilla to configure the connection and verify the uploaded file.

Status: Approved
Category: Protected
Authored By: Jeyakumar Arunagiri on Aug 29, 2024
Revisions
25 Oct, 2024 - Added details about SFTP server key based authentication - VN-14886 by Gladson