Hi Everyone,[Nav 2017]
I would like to transfer Nav Exported file to SFTP directory file and download file from SFTP to Nav directory.(File is in Csv format)
Eg. Nav folder: C:\Desktop\DEMO\ForSFTP
> SFTP folder: C:\Desktop\DEMO\FromNav
Nav folder: C:\Desktop\DEMO\FromSFTP <
SFTP folder: C:\Desktop\DEMO\ForNav
For this I am using WinSCP. And, I want to do this with codeunit. How can i proceed this. Please help about Cal\code.
thanks,
Mani
0
Comments
This is an example to download files from and SFTP site
Where the vars are:
Regards
Thanks for the sample cal/code.
few things, i want to clear about parameter that you use in the above function:
remotePath(Text) = SFTP Path ??
localPath(Text) = Local path directory ??
fileMask(Text) = not confirm
logFile(Text) = not confirm
please guide me. Can i transfer file from SFTP file to Nav directory only running by codeunit ie the above code will work for codeunit. OR, have to create job queue like that to run?
Please help me.
Thanks,
Mani.
I reply in your quote:
Regards
I am trying the below codeunit, but I am not able to get the file from SFTP directory to My Nav local directory. Please check and guide me,what and where i am doing mistake.
OnRun()
remotePath :='/<root>/in'; //SFTP path,from where i want to get file
localPath :='C:\Desktop\3PL DEMO\FromSFTP'; // local path,where i want to save
fileMask := '*.Csv'; //format of file
logFile := 'C:\Program Files (x86)\WinSCP'; // WinSCP installed path
SFTP_GetFilesList(PortNumber : Integer;FTPAddress : Text;Login : Text;Password : Text;remotePath : Text;localPath : Text;fileMask : Text;logFile : Text) : Integer
WinSCP_SessionOptions := WinSCP_SessionOptions.SessionOptions;
WinSCP_SessionOptions.Protocol := WinSCP_Protocol.Sftp;
IF PortNumber <= 0 THEN
WinSCP_SessionOptions.PortNumber := 22
ELSE
WinSCP_SessionOptions.PortNumber := 8743;
WinSCP_SessionOptions.HostName := gsdhs.co;
WinSCP_SessionOptions.Password := 873ewdd@3;
WinSCP_SessionOptions.UserName := abc;
WinSCP_SessionOptions.GiveUpSecurityAndAcceptAnySshHostKey := TRUE;
WinSCP_Session := WinSCP_Session.Session;
WinSCP_Session.SessionLogPath(logFile);
WinSCP_Session.Open(WinSCP_SessionOptions);
WinSCP_TransferOptions := WinSCP_TransferOptions.TransferOptions;
IF fileMask <> '' THEN
WinSCP_TransferOptions.FileMask(fileMask);
WinSCP_TransferResult := WinSCP_Session.GetFiles(remotePath, localPath, FALSE, WinSCP_TransferOptions);
WinSCP_TransferResult.Check();
WinSCP_Transfers := WinSCP_TransferResult.Transfers;
EXIT(WinSCP_Transfers.Count);
Thanks,
Mani.
I tried the below code also, but I am not able to get the file from SFTP to nav directory. Could you please check and suggest/guide me regarding my issue.
OnRun()
SourceFileP :='C:\3PL DEMO\FromSFTP';
RemotPath :='/<root>/in';
LOCAL UploadFile(SourceFileP : Text)
WinSCPSessionOptions := WinSCPSessionOptions.SessionOptions();
WinSCPSessionOptions.Protocol := WinSCP_Protocol.Sftp;
WinSCPSessionOptions.HostName := 'sftpxm.co';
WinSCPSessionOptions.PortNumber := 4322;
WinSCPSessionOptions.UserName := 'abcd';
WinSCPSessionOptions.Password := '9843fueeiwei223';
WinSCPSessionOptions.GiveUpSecurityAndAcceptAnySshHostKey := TRUE;
WinSCPSesh := WinSCPSesh.Session();
WinSCPSesh.ExecutablePath(WinScp_Executable_Path);
WinSCPSesh.Open(WinSCPSessionOptions);
IF WinSCPSesh.Opened THEN BEGIN
WinSCPTransferOptions := WinSCPTransferOptions.TransferOptions;
WinSCPTransferOptions.TransferMode := 0;
WinSCPTransferResumeSupport := WinSCPTransferOptions.ResumeSupport;
WinSCPTransferResumeSupport.State(WinSCPTransferResumeSupportState.Off);
IF WinSCPSesh.FileExists(RemotPath + 'upload/' + FileManagement.GetFileName(SourceFileP)) THEN
WinSCPSesh.RemoveFiles(RemotPath + 'upload/' + FileManagement.GetFileName(SourceFileP));
WinSCPTransferResults := WinSCPSesh.PutFiles(SourceFileP, RemotPath + 'uploads/',FALSE,WinSCPTransferOptions);
END ELSE ERROR('Connecion Failed!');
IF WinSCPSesh.Opened THEN WinSCPSesh.Dispose();
Thanks,
Mani.
Lets focus in your first example
It's the remote path correct ? -> '/<root>/in'
The logFile must be a file not a folder, try this one :
After running the code you could be the content of this file to see what has happend.
And the more important thing is how you declare the dotNET variables, by default are declared to run on Server, so the local paths and files are actually in the server where the service is running not in your client computer.
Regards
According to your suggestion, i put the 1.logFile:
logFile := 'C:\Desktop\3PL DEMO\FromSFTP\logFile.txt'; And I tried for .Csv format also.
2. I corrrect the remote path(/in) also, from where the file will take(.txt/.Csv).
But, I am not getting my file in destination(Local directry/path)
So, Please guide me how can i pass the source file path(remote path) in my function, because it seems like its not calling that path in my sourceFile function.
Your help will be appreciable.
Thanks,
Mani.
Could you send what is in the logFIle after running your code ?
And if you can export your code in txt format and send it too, better.
Regards
After running code, I am not getting anything in logfile. its showing blank.
For checking purpose I created one text/Csv file with inside some text, so that after running codeunit that text should come in my local path file from remot path directory. But its not coming.
I put here content of exported codeunit in txt format for reference[I am not able to attach the exported txt file here].Please check and guide me.
Thank you so much for your continuous help .
OBJECT Codeunit 50120 SFTPmanagement_M
{
OBJECT-PROPERTIES
{
Date=10/22/19;
Time=11:51:08 AM;
Modified=Yes;
Version List=;
}
PROPERTIES
{
OnRun=BEGIN
remotePath :='/in';
localPath :='C:\Users\maniratnamkumarm\Desktop\3PL DEMO\FromSFTP';
fileMask := '*.Csv';
//logFile := 'C:\Program Files (x86)\WinSCP';
logFile := 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\FromSFTP\logFile.Csv';
END;
}
CODE
{
VAR
WinSCP_SessionOptions@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.SessionOptions";
WinSCP_Protocol@1000000001 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.Protocol";
WinSCP_Session@1000000002 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.Session";
WinSCP_TransferOptions@1000000003 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferOptions";
WinSCP_TransferResult@1000000004 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferOperationResult";
WinSCP_Transfers@1000000005 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferEventArgsCollection";
remotePath@1000000006 : Text;
localPath@1000000007 : Text;
fileMask@1000000008 : Text;
logFile@1000000009 : Text;
PROCEDURE SFTP_GetFilesList@1000000001(PortNumber@1000000000 : Integer;FTPAddress@1000000001 : Text;Login@1000000002 : Text;Password@1000000003 : Text;remotePath@1000000004 : Text;localPath@1000000005 : Text;fileMask@1000000006 : Text;logFile@1000000007 : Text) : Integer;
BEGIN
MESSAGE('SFTPTrigger');
WinSCP_SessionOptions := WinSCP_SessionOptions.SessionOptions;
WinSCP_SessionOptions.Protocol := WinSCP_Protocol.Sftp;
IF PortNumber <= 0 THEN
WinSCP_SessionOptions.PortNumber := 22
ELSE
WinSCP_SessionOptions.PortNumber := 7362;
WinSCP_SessionOptions.HostName := 'sftp.co';
WinSCP_SessionOptions.Password := '37etwtas2WE';
WinSCP_SessionOptions.UserName := 'abcjsd';
WinSCP_SessionOptions.GiveUpSecurityAndAcceptAnySshHostKey := TRUE;
WinSCP_Session := WinSCP_Session.Session;
WinSCP_Session.SessionLogPath(logFile);
WinSCP_Session.Open(WinSCP_SessionOptions);
WinSCP_TransferOptions := WinSCP_TransferOptions.TransferOptions;
IF fileMask <> '' THEN
WinSCP_TransferOptions.FileMask(fileMask);
WinSCP_TransferResult := WinSCP_Session.GetFiles(remotePath, localPath, FALSE, WinSCP_TransferOptions);
WinSCP_TransferResult.Check();
WinSCP_Transfers := WinSCP_TransferResult.Transfers;
EXIT(WinSCP_Transfers.Count);
END;
EVENT WinSCP_Session@1000000002::FileTransferred@49(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000002::Failed@50(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.FailedEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000002::OutputDataReceived@51(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.OutputDataReceivedEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000002::FileTransferProgress@52(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.FileTransferProgressEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000002::QueryReceived@53(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.QueryReceivedEventArgs");
BEGIN
END;
BEGIN
END.
}
}
Thanks,
Mani.
If you are running this codeunit you are missing the call to the function SFTP_GetFileList.
After
And better with a txt extension not a csv one, because is a text file.
You must call the function:
And change this part of your code to get the parameters
And like I said before, your dotNet variables are defined to run on the server so the paths and the files that you are dealing with are in the server not in your local machine.
Regards
I put the path and file both in server. And i tried the same code as you provide above. But, I am getting the below error, when i run codeunit{Its trigger the error at line:
WinSCP_Session.Open(WinSCP_SessionOptions); }.
Microsoft Dynamics NAV
A call to WinSCP.Session.Open failed with this message: Error occurred during logging. It's been turned off.
Can't open log file 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\FromSFTP\logFile.txt'.
System Error. Code: 5.
Access is denied
OK
Could you please, guide me; where i am doing wrong.
Thanks,
Mani.
Seems like it is a permission issue, change all the dotNET variables to run on client and try again.
Regards
Thank you so much. Now, I am able to export file from remote(SFTP) directory to local path.
Next part: I am trying to export from local path to remote(SFTP) directory.
As it will complete,will update you.
ONCE AGAIN THANKS FOR YOUR HELP.
Thanks,
Mani.
Same codeunit, i am trying to upload from local path to SFTP remote directory. Only, I changed the lineA with lineB. the codeunit is runing successfuly, but file is not transferring from local to remote directory.
[I put the local path file alredy in server]
lineA: WinSCP_TransferResult := WinSCP_Session.GetFiles(localPath,remotePath, FALSE,WinSCP_TransferOptions);//Remove
lineB: WinSCP_TransferResult := WinSCP_Session.PutFiles(localPath,remotePath, FALSE, WinSCP_TransferOptions); //Insert
Please check and guide me further.
Thanks,
Mani.
It must works, could you send the code in text format again?
Regards
Thank you so muchhhhhhhh............
Below is the content of my codeunit.
OBJECT Codeunit 50121 LocalTOSFTP_M
{
OBJECT-PROPERTIES
{
Date=10/23/19;
Time=[ 6:22:53 PM];
Modified=Yes;
Version List=;
}
PROPERTIES
{
OnRun=BEGIN
remotePath :='/in';
localPath :='C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP';
fileMask := '*.Csv';
logFile := 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\LogFileForSFTP\logFile.txt';
SFTP_GetFilesList(7362, 'sftp.co', 'abcjsd', '37etwtas2WE', remotePath, localPath, fileMask, logFile);
END;
}
CODE
{
VAR
WinSCP_SessionOptions@1000000009 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.SessionOptions" RUNONCLIENT;
WinSCP_Protocol@1000000008 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.Protocol";
WinSCP_Session@1000000007 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.Session" RUNONCLIENT;
WinSCP_TransferOptions@1000000006 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferOptions" RUNONCLIENT;
WinSCP_TransferResult@1000000005 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferOperationResult" RUNONCLIENT;
WinSCP_Transfers@1000000004 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferEventArgsCollection" RUNONCLIENT;
remotePath@1000000003 : Text;
localPath@1000000002 : Text;
fileMask@1000000001 : Text;
logFile@1000000000 : Text;
PROCEDURE SFTP_GetFilesList@1000000001(PortNumber@1000000000 : Integer;FTPAddress@1000000001 : Text;Login@1000000002 : Text;Password@1000000003 : Text;remotePath@1000000004 : Text;localPath@1000000005 : Text;fileMask@1000000006 : Text;logFile@1000000007 : Text) : Integer;
BEGIN
WinSCP_SessionOptions := WinSCP_SessionOptions.SessionOptions;
WinSCP_SessionOptions.Protocol := WinSCP_Protocol.Sftp;
IF PortNumber <= 0 THEN
WinSCP_SessionOptions.PortNumber := 22
ELSE
WinSCP_SessionOptions.PortNumber := PortNumber;
WinSCP_SessionOptions.HostName := FTPAddress;
WinSCP_SessionOptions.Password := Password;
WinSCP_SessionOptions.UserName := Login;
WinSCP_SessionOptions.GiveUpSecurityAndAcceptAnySshHostKey := TRUE;
WinSCP_Session := WinSCP_Session.Session;
WinSCP_Session.SessionLogPath(logFile);
WinSCP_Session.Open(WinSCP_SessionOptions);
WinSCP_TransferOptions := WinSCP_TransferOptions.TransferOptions;
IF fileMask <> '' THEN
WinSCP_TransferOptions.FileMask(fileMask);
WinSCP_TransferResult := WinSCP_Session.PutFiles(localPath,remotePath, FALSE, WinSCP_TransferOptions);
WinSCP_TransferResult.Check();
WinSCP_Transfers := WinSCP_TransferResult.Transfers;
EXIT(WinSCP_Transfers.Count);
END;
EVENT WinSCP_Session@1000000007::FileTransferred@49(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.TransferEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000007::Failed@50(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.FailedEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000007::OutputDataReceived@51(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.OutputDataReceivedEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000007::FileTransferProgress@52(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.FileTransferProgressEventArgs");
BEGIN
END;
EVENT WinSCP_Session@1000000007::QueryReceived@53(sender@1000000001 : Variant;e@1000000000 : DotNet "'WinSCPnet, Version=1.6.5.9849, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf'.WinSCP.QueryReceivedEventArgs");
BEGIN
END;
BEGIN
END.
}
}
Please check and guide me.
Thanks,
Mani.
The code looks ok,
Could you send the logfile created after the execution of this code ?.
Regards.
Below is the content of log file after running the codeunit.
. 2019-10-23 18:58:22.907
. 2019-10-23 18:58:22.908 WinSCP Version 5.15.4 (Build 9849) (OS 10.0.14393 - Windows Server 2016 Standard)
. 2019-10-23 18:58:22.908 Configuration: nul
. 2019-10-23 18:58:22.908 Log level: Normal
. 2019-10-23 18:58:22.908 Local account: KTC\maniratnamkumarm
. 2019-10-23 18:58:22.908 Working directory: C:\Program Files (x86)\WinSCP
. 2019-10-23 18:58:22.908 Process ID: 11548
. 2019-10-23 18:58:22.909 Command-line: "C:\Program Files (x86)\WinSCP\winscp.exe" /xmllog="C:\Users\maniratnamkumarm\AppData\Local\Temp\9\wscp1BC4.0282F632.tmp" /xmlgroups /xmllogrequired /nointeractiveinput /dotnet=5.15.4 /ini=nul /log="C:\Users\maniratnamkumarm\Desktop\3PL DEMO\LogFileForSFTP\logFile.txt" /console /consoleinstance=_7108_43689923_734
. 2019-10-23 18:58:22.909 Time zone: Current: GMT+5:30 (Sri Lanka Standard Time), No DST
. 2019-10-23 18:58:22.909 Login time: Wednesday, October 23, 2019 6:58:22 PM
. 2019-10-23 18:58:22.909
. 2019-10-23 18:58:22.909 Script: Retrospectively logging previous script records:
> 2019-10-23 18:58:22.909 Script: option batch on
< 2019-10-23 18:58:22.909 Script: batch on
< 2019-10-23 18:58:22.909 Script: reconnecttime 120
> 2019-10-23 18:58:22.909 Script: option confirm off
< 2019-10-23 18:58:22.909 Script: confirm off
> 2019-10-23 18:58:22.909 Script: option reconnecttime 120
< 2019-10-23 18:58:22.909 Script: reconnecttime 120
> 2019-10-23 18:58:22.909 Script: open sftp://(My/Sftp username):***@(My host name):(My port no) -hostkey="*" -timeout=15
. 2019-10-23 18:58:22.909
. 2019-10-23 18:58:22.910 Session name: (My/Sftp username)@(My host name) (Ad-Hoc site)
. 2019-10-23 18:58:22.910 Host name: (My host name) (Port: (My port no))
. 2019-10-23 18:58:22.910 User name: (My/Sftp username) (Password: Yes, Key file: No, Passphrase: No)
. 2019-10-23 18:58:22.910 Tunnel: No
. 2019-10-23 18:58:22.910 Transfer Protocol: SFTP
. 2019-10-23 18:58:22.910 Ping type: Off, Ping interval: 30 sec; Timeout: 15 sec
. 2019-10-23 18:58:22.910 Disable Nagle: No
. 2019-10-23 18:58:22.910 Proxy: None
. 2019-10-23 18:58:22.910 Send buffer: 262144
. 2019-10-23 18:58:22.910 SSH protocol version: 2; Compression: No
. 2019-10-23 18:58:22.910 Bypass authentication: No
. 2019-10-23 18:58:22.910 Try agent: Yes; Agent forwarding: No; TIS/CryptoCard: No; KI: Yes; GSSAPI: Yes
. 2019-10-23 18:58:22.910 GSSAPI: Forwarding: No; Libs: gssapi32,sspi,custom; Custom:
. 2019-10-23 18:58:22.910 Ciphers: aes,chacha20,blowfish,3des,WARN,arcfour,des; Ssh2DES: No
. 2019-10-23 18:58:22.910 KEX: ecdh,dh-gex-sha1,dh-group14-sha1,rsa,WARN,dh-group1-sha1
. 2019-10-23 18:58:22.910 SSH Bugs: Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto,Auto
. 2019-10-23 18:58:22.910 Simple channel: Yes
. 2019-10-23 18:58:22.910 Return code variable: Autodetect; Lookup user groups: Auto
. 2019-10-23 18:58:22.910 Shell: default
. 2019-10-23 18:58:22.910 EOL: LF, UTF: Auto
. 2019-10-23 18:58:22.910 Clear aliases: Yes, Unset nat.vars: Yes, Resolve symlinks: Yes; Follow directory symlinks: No
. 2019-10-23 18:58:22.910 LS: ls -la, Ign LS warn: Yes, Scp1 Comp: No; Exit code 1 is error: No
. 2019-10-23 18:58:22.910 SFTP Bugs: Auto,Auto
. 2019-10-23 18:58:22.910 SFTP Server: default
. 2019-10-23 18:58:22.910 Local directory: default, Remote directory: home, Update: Yes, Cache: Yes
. 2019-10-23 18:58:22.911 Cache directory changes: Yes, Permanent: Yes
. 2019-10-23 18:58:22.911 Recycle bin: Delete to: No, Overwritten to: No, Bin path:
. 2019-10-23 18:58:22.911 DST mode: Unix
. 2019-10-23 18:58:22.911
. 2019-10-23 18:58:22.911 Looking up host "(My host name)" for SSH connection
. 2019-10-23 18:58:22.917 Connecting to 35.241.217.254 port (My port no)
. 2019-10-23 18:58:23.150 We claim version: SSH-2.0-WinSCP_release_5.15.4
. 2019-10-23 18:58:23.388 Server version: SSH-2.0-OpenSSH_7.4p1 Debian-10+deb9u7
. 2019-10-23 18:58:23.388 Using SSH protocol version 2
. 2019-10-23 18:58:23.621 Doing ECDH key exchange with curve Curve25519 and hash SHA-256
. 2019-10-23 18:58:24.851 Server also has ssh-rsa host key, but we don't know it
. 2019-10-23 18:58:24.854 Host key fingerprint is:
. 2019-10-23 18:58:24.854 ssh-ed25519 256 d5:6c:40:ea:dc:ff:58:1e:70:eb:4a:82:74:b4:f0:93
The remaining part is in next comment.
* 2019-10-23 18:58:24.855 WARNING! Giving up security and accepting any host key as configured!
. 2019-10-23 18:58:24.855 Initialised AES-256 SDCTR client->server encryption
. 2019-10-23 18:58:24.855 Initialised HMAC-SHA-256 client->server MAC algorithm
. 2019-10-23 18:58:24.855 Initialised AES-256 SDCTR server->client encryption
. 2019-10-23 18:58:24.855 Initialised HMAC-SHA-256 server->client MAC algorithm
! 2019-10-23 18:58:25.361 Using username "(My/Sftp username)".
. 2019-10-23 18:58:25.594 Server offered these authentication methods: publickey,password,keyboard-interactive
. 2019-10-23 18:58:25.594 Attempting keyboard-interactive authentication
. 2019-10-23 18:58:25.825 Server refused keyboard-interactive authentication
. 2019-10-23 18:58:25.825 Server offered these authentication methods: publickey,password,keyboard-interactive
. 2019-10-23 18:58:25.826 Prompt (password, "SSH password", <no instructions>, "&Password: ")
. 2019-10-23 18:58:25.826 Using stored password.
. 2019-10-23 18:58:25.827 Sent password
. 2019-10-23 18:58:26.064 Access granted
. 2019-10-23 18:58:26.064 Opening session as main channel
. 2019-10-23 18:58:26.577 Opened main channel
. 2019-10-23 18:58:27.082 Started a shell/command
. 2019-10-23 18:58:27.082
. 2019-10-23 18:58:27.082 Using SFTP protocol.
. 2019-10-23 18:58:27.082 Doing startup conversation with host.
> 2019-10-23 18:58:27.082 Type: SSH_FXP_INIT, Size: 5, Number: -1
< 2019-10-23 18:58:27.316 Type: SSH_FXP_VERSION, Size: 150, Number: -1
. 2019-10-23 18:58:27.316 SFTP version 3 negotiated.
. 2019-10-23 18:58:27.317 Unknown server extension posix-rename@openssh.com="1"
. 2019-10-23 18:58:27.317 Supports statvfs@openssh.com extension version "2"
. 2019-10-23 18:58:27.317 Unknown server extension fstatvfs@openssh.com="2"
. 2019-10-23 18:58:27.317 Supports hardlink@openssh.com extension version "1"
. 2019-10-23 18:58:27.317 Unknown server extension fsync@openssh.com="1"
. 2019-10-23 18:58:27.317 We believe the server has signed timestamps bug
. 2019-10-23 18:58:27.317 We will use UTF-8 strings until server sends an invalid UTF-8 string as with SFTP version 3 and older UTF-8 strings are not mandatory
. 2019-10-23 18:58:27.317 Limiting packet size to OpenSSH sftp-server limit of 262148 bytes
. 2019-10-23 18:58:27.317 Getting current directory name.
. 2019-10-23 18:58:27.318 Getting real path for '.'
> 2019-10-23 18:58:27.318 Type: SSH_FXP_REALPATH, Size: 10, Number: 16
< 2019-10-23 18:58:27.550 Type: SSH_FXP_NAME, Size: 23, Number: 16
. 2019-10-23 18:58:27.550 Real path is '/'
. 2019-10-23 18:58:27.550 Startup conversation with host finished.
< 2019-10-23 18:58:27.550 Script: Active session: [1] (My/Sftp username)@(My host name)
> 2019-10-23 18:58:27.745 Script: pwd
< 2019-10-23 18:58:27.745 Script: /
> 2019-10-23 18:58:27.811 Script: put -nopermissions -preservetime -transfer="binary" -filemask="*.Csv" -- "C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP" "/out"
. 2019-10-23 18:58:27.813 Copying 1 files/directories to remote directory "/"
. 2019-10-23 18:58:27.813 PrTime: Yes; PrRO: No; Rght: rw-r--r--; PrR: No (No); FnCs: N; RIC: 0100; Resume: S (102400); CalcS: No; Mask: out
. 2019-10-23 18:58:27.813 TM: B; ClAr: No; RemEOF: No; RemBOM: No; CPS: 0; NewerOnly: No; EncryptNewFiles: Yes; ExcludeHiddenFiles: No; ExcludeEmptyDirectories: No; InclM: *.Csv; ResumeL: 0
. 2019-10-23 18:58:27.813 AscM: *.*html; *.htm; *.txt; *.php; *.php3; *.cgi; *.c; *.cpp; *.h; *.pas; *.bas; *.tex; *.pl; *.js; .htaccess; *.xtml; *.css; *.cfg; *.ini; *.sh; *.xml
. 2019-10-23 18:58:27.813 Getting real path for '/'
> 2019-10-23 18:58:27.813 Type: SSH_FXP_REALPATH, Size: 10, Number: 272
< 2019-10-23 18:58:28.045 Type: SSH_FXP_NAME, Size: 23, Number: 272
. 2019-10-23 18:58:28.045 Real path is '/'
. 2019-10-23 18:58:28.045 File: 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP' [2019-10-23T10:03:38.249Z] [0]
. 2019-10-23 18:58:28.046 Listing file "/out".
> 2019-10-23 18:58:28.046 Type: SSH_FXP_LSTAT, Size: 13, Number: 519
< 2019-10-23 18:58:28.277 Type: SSH_FXP_ATTRS, Size: 37, Number: 519
. 2019-10-23 18:58:28.277 out;D;0;2019-10-23T07:36:16.000Z;3;"" [1005];"" [1004];rwxrwxr-x;0
. 2019-10-23 18:58:28.278 File: 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP\TestCSVDocument.csv' [2019-10-16T07:28:41.000Z] [52]
. 2019-10-23 18:58:28.278 Copying "C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP\TestCSVDocument.csv" to remote directory started.
. 2019-10-23 18:58:28.278 Binary transfer mode selected.
. 2019-10-23 18:58:28.278 Opening remote file.
> 2019-10-23 18:58:28.279 Type: SSH_FXP_OPEN, Size: 49, Number: 771
< 2019-10-23 18:58:28.510 Type: SSH_FXP_HANDLE, Size: 13, Number: 771
> 2019-10-23 18:58:28.510 Type: SSH_FXP_WRITE, Size: 77, Number: 1286
> 2019-10-23 18:58:28.511 Type: SSH_FXP_CLOSE, Size: 13, Number: 1540
> 2019-10-23 18:58:28.511 Type: SSH_FXP_SETSTAT, Size: 45, Number: 1033
< 2019-10-23 18:58:28.742 Type: SSH_FXP_STATUS, Size: 24, Number: 1286
< 2019-10-23 18:58:28.742 Status code: 0
< 2019-10-23 18:58:28.974 Type: SSH_FXP_STATUS, Size: 24, Number: 1540
< 2019-10-23 18:58:28.974 Status code: 0
. 2019-10-23 18:58:28.974 Preserving timestamp [2019-10-16T07:28:41.000Z]
< 2019-10-23 18:58:28.974 Type: SSH_FXP_STATUS, Size: 24, Number: 1033
< 2019-10-23 18:58:28.974 Status code: 0
. 2019-10-23 18:58:28.974 Transfer done: 'C:\Users\maniratnamkumarm\Desktop\3PL DEMO\ForSFTP\TestCSVDocument.csv' => '/out/TestCSVDocument.csv' [52]
. 2019-10-23 18:58:28.974 Copying finished: Transferred: 52, Elapsed: 0:00:01, CPS: 0/s
> 2019-10-23 18:58:29.486 Script: exit
. 2019-10-23 18:58:29.486 Script: Exit code: 0
. 2019-10-23 18:58:29.487 Closing connection.
. 2019-10-23 18:58:29.487 Sending special code: 12
. 2019-10-23 18:58:29.487 Sent EOF message
Thanks,
Mani.
According to the logfile the upload was ok:
Regards.
I am very very happy with your help...
Thankssss
Its coming.DOne.....
[If you wish,plse share your personal mail id for immediate help this is my mail id: maniratnamkr1@gmail.com]
Thanks,
Mani.
I will send you my personal email but I think that is better that you continue posting here your doubts so other people can benefit for the answers that you receive.
Regards
Thanks, Sure; I will post continue here my doubts as of your suggestion.
Thanks,
Mani.
Is it possible to run it on the server? I already install the WinSCP on the server and copy the DLL to addins folder, but I still get the same error when I didn't have installed yet on the server.
thanks in advance
NGS
Could you elaborate a little what it's the error that you are getting ?
Regards.
Blog - rockwithnav.wordpress.com/
Twitter - https://twitter.com/RockwithNav
Facebook - https://facebook.com/rockwithnav/
The error is this one
Cannot create an instance of the following .NET Framework object: assembly WinSCPnet, Version=1.7.2.10414, Culture=neutral, PublicKeyToken=2271ec4a3c56d0bf, type WinSCP.SessionOptions.
and it is raised on the first line of code.
WinSCPSessionOptions := WinSCPSessionOptions.SessionOptions;
WinSCPSessionOptions.HostName := SessionHostName;
WinSCPSessionOptions.UserName := SessionUser;
WinSCPSessionOptions.Password := SessionPassword;
WinSCPSessionOptions.Protocol := WinSCPProtocol.Ftp;
WinSCPSessionOptions.FtpMode := WinSCPFTPMode.Active;
All the variables are declared RunOnClient = NO
If I run the same code on stage server I don't get the error, I thought it was because we didn't start the service. Yesterday I could make a restart of the service but I still get the same error.
@RockWithNAV I saw someone on the comments of the link you post to register on the server, to do that I only need to run the setup program or I need to do something else?
Do you have the WinSCPnet DLL in the Server Add-in folder ?
Regards