(JavaScript) AWS Transfer for SFTP (Amazon S3)
Once you've setup your AWS Transfer for SFTP in the AWS Console, interacting with it is no different than any other SSH/SFTP server. AWS will provide a private key in PEM format. It is used for authentication (instead of a password). For more information, see https://docs.aws.amazon.com/transfer/latest/userguide/getting-started-use-the-service.html
var success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
var sftp = new CkSFtp();
// Connect to the AWS SFTP server.
// Change the domain to your value.
var domain = "s-123456df999999fab.server.transfer.eu-west-2.amazonaws.com";
var port = 22;
success = sftp.Connect(domain,port);
if (success == false) {
console.log(sftp.LastErrorText);
return;
}
// Load your AWS SFTP private key PEM file..
var sshKey = new CkSshKey();
var keyText = sshKey.LoadText("qa_data/pem/s3_sftp_privateKey.pem");
if (sshKey.LastMethodSuccess !== true) {
console.log(sshKey.LastErrorText);
return;
}
success = sshKey.FromOpenSshPrivateKey(keyText);
if (success == false) {
console.log(sshKey.LastErrorText);
return;
}
// Authenticate with the SSH server using the private key.
success = sftp.AuthenticatePk("myUsername",sshKey);
if (success == false) {
console.log(sftp.LastErrorText);
return;
}
// After authenticating, the SFTP subsystem must be initialized:
success = sftp.InitializeSftp();
if (success == false) {
console.log(sftp.LastErrorText);
return;
}
// Upload from the local file to the SSH server.
// Important -- the remote filepath is the 1st argument,
// the local filepath is the 2nd argument;
var remoteFilePath = "hamlet.xml";
var localFilePath = "c:/temp/hamlet.xml";
success = sftp.UploadFileByName(remoteFilePath,localFilePath);
if (success == false) {
console.log(sftp.LastErrorText);
return;
}
console.log("Success.");
|