SFTP Adapter for Microsoft BizTalk
Requirements: /n software Adapters for Microsoft BizTalk
Introduction
The /n software Adapters for Microsoft BizTalk include fully managed .NET Adapters that seamlessly integrate with the BizTalk Messaging Pipeline. The /n software Adapters extend the features of BizTalk with advanced internet communications and secure messaging capabilities.
Many different BizTalk adapters are currently supported: AS2 Adapters for EDI communications, FTPS, FTP, secure file transfer protocol (SFTP), Secure Shell (SSH), and email adapters. These adapters have completed the official adapter certification program (administered by Unisys) established by Microsoft for BizTalk server, which tests for scalability and interoperability with Microsoft BizTalk Server.
This guide will focus specifically on the SFTP adapter, which is used to communicate with SFTP servers. SFTP (which should not be confused with FTP or FTPS) is the SSH File Transfer Protocol. If you are interested in using SFTP communication in your BizTalk solution, you have come to the right place. Before you continue reading, please download the product and follow along with me through the tutorial.
Contents
- Adapter Installation
- Adapter Properties - Send Port
- Usage - Send Port
- Adapter Properties - Receive Port
- Usage - Receive Port
Adapter Installation
Before installing the adapter, you should stop the BizTalk host instance and close the BizTalk Administration Console. After you run the setup application, all of the necessary files will be installed on your system. The adapters will automatically be added to the BizTalk Administration Console, so we can begin using them in send ports and receive locations. If you open the BizTalk Administration Console and create a new receive location or send port, you'll see that the /n software SFTP adapter is now available as a transport type.
Adapter Properties: Send Port
One common situation in which the SFTP adapter might be used is one in which files dropped in a local folder need to be sent to a remote server. In this situation, a receive location of a transport-type FILE would be configured in BizTalk to monitor a folder, and you would configure a Send port that will send files picked up in this folder to a remote SFTP server.
After you add a new Send Port and set the transport type to "nsoftware.SFTP 2024" (also do not forget to set the Filters to associate this send port with the file pickup receive location), click on the Configure button to bring up a new window called "nsoftware.SFTP 2024 Transport Properties". Then you will specify the details of how and where the SFTP adapter should connect. Following are the four groups of properties:
Logging
The Transport Log property is the only property here. If you click the + symbol next to the property, this will expand the property and expose its fields. You will see Location, Log Mode, and Log Type. By default, the adapter will only log errors to the application event log. You can change the Log Mode to a mode with greater detail so that information event log entries are written to the event log during the course of execution. You may also change the Log Type so that events will be written to file instead of the event log. In that case, you will need to specify the full path to a file in the Location field.
SFTP
The next group of properties are SFTP properties. Here, you will tell the adapter where on the SFTP server to write the files. All of these properties are fairly self-explanatory:
After Connect | A set of FTP-style commands to be executed immediately after connecting to the SSHHost. The help files lists available commands. |
After Put | A set of FTP-style commands to be executed after the upload. The help files lists available commands. |
Append | Whether or not the adapter should append data to the RemoteFile. |
Before Put | A set of FTP-style commands to be executed before the upload. The help files lists available commands. |
Overwrite | If set to false, an error will occur if a file with the same name already exists on the remote server. If set to true, the file of the same name will be overwritten. |
Remote File | The name of the destination file on the remote SFTP server. |
Remote Path | The path of the remote SFTP server to which the Remote File should be uploaded. |
Remote Temp Path | A temporary directory on the remote SFTP server where files will be stored during the upload process. When the upload is complete, the temporary file(s) will be moved to Remote Path. If this property is left blank, files will be uploaded straight to Remote Path. |
SSH
The SSH properties specify where and how to connect for the SFTP connection:
SSH Accept Server Host Key | Instructs the adapter to accept the server host key that matches the supplied key. Clicking the ellipses will open the certificate selector dialog to load the public key. If you click the + symbol this will expand the property and reveal the associated fields. The "Accept Any" field may be set to Yes to instruct the adapter to accept any host key presented by the server. |
SSH Auth Mode | The type of authentication used by the adapter (public key, password, keyboard-interactive, and multi-factor authentication are all supported). |
SSH Cert | This property shows the subject of the certificate that is currently specified for public key authentication. Clicking the ellipses of this property will open the certificate selector dialog where you will be able to easily load your certificate. With the certificate selector dialog you can load certificates from the User and Machine stores, as well as from PFX or PEM files. |
SSH Compression Algorithm | Can be either "none" (default) or "Zlib". |
SSH Host | The internet address of the SSH host. |
SSH Password | The password to use when connecting to the SSH host. |
SSH Port | The port on the SSH host on which to connect. |
SSH User | The user id to use when connecting to the SSH host. |
It is very important to understand these SSH properties, because a complete understanding will help ensure the security of your transactions. To that end, a more complete discussion of each of these properties follows.
The "SSH Cert" property will allow you to specify a certificate in a variety of forms, as mentioned previously. The design of the certificate selector dialog is intended to allow you to easily select a certificate for public key authentication. If you are specifying a PEM File, you must specify an SSH2 RSA or SSH2 DSA private key.
The "SSH Accept Server Host Key" setting tells the adapter what host key to accept during the security handshaking procedure of the connection to the remote server. If the value specified here does not match the key that the server presents, the connection will be terminated with an error. This property acts like the SSH Cert property in that clicking the ellipses will open the certificate selector dialog where you may select a certificate.
As mentioned previously, you may also click the + symbol and set the Accept Any field to "Yes" to always accept the server's host key.
If you want to use the hex-encoded 16-byte MD5 fingerprint, this can be done through the use of the Other property in the Tuning section. You would give the Other property a value, as follows: SSHAcceptServerHostKeyFingerprint=0a:1b:2c:3d
The "SSH Auth Mode" specifies which form of authentication you would like to perform when connecting to the SSH server. The adapter supports regular "User/Password", public key, or keyboard interactive authentication. Multifactor authentication may be selected to use a combination of these three authentication mechanisms. If you choose to use public key authentication, you will also need to set the "SSH Cert" property to point the adapter to the key pair it should use. This article is not meant to explain how public key authentication works; however, if you would like to use this form of authentication, you should generate a key pair on your own computer, and copy the public key to the SSH server. Then, when you connect to the server, you can point the adapter to your private key to authenticate. The "SSH Cert" property is used only if you choose to use public key authentication.
The "SSH Compression Algorithm" property should be set to "ZLIB" if you want to implement ZLIB compression in your SSH communications. Use of compression will likely depend on your trading partner's requirements, but it is entirely optional. Generally, it is a good idea to compress large documents but inefficient to use it for small documents.
The "SSH Host", "SSH Port", "SSH User", and "SSH Password" settings are all self-explanatory: just specify the server you want to connect to, on what port (the default is port 22), and the user and password to use to connect with. If you use public key authentication, you still need to specify an "SSH User", but the "SSH Password" will be ignored.
Tuning Properties
Firewall | This may be expanded to configure the firewall type, host, port, user, and password if needed. | |
Other | This allows you to specify additional configuration settings in the format configname1=value1. See the Configuration section of the documentation for a list of supported settings. |
Usage: Send Port
To configure a send port to upload files from the pickup folder to my remote SFTP server, only a few of the following properties need to be set:
- For the SFTP properties, set the "Remote File" to %SourceFileName%, and the "Remote Path" to the name of the specific folder location on the remote server where you want to store the files (in my case "myTests").
- For the SSH properties, start by setting the Accept Any field of SSH Accept Server Host Key to "Yes" for testing. Use public key authentication because it is generally considered to be more secure, and then set the "SSH Auth Mode" to "Public Key". You will get the certificate from a PEM file, and should use the certificate selector dialog from the "SSH Cert" to specify the PEM File. Then all you have to do is set the "SSH Host" and "SSH User" and you will be ready to go.
To test, set the Filter of the send port to BTS.InboundTransportLocation == "C:\test\in\*.*", the location of my File adapter receive location. After you enable the ports, start the BizTalk Server and drop some test files. The adapter will transfer the picked up files to my remote SFTP server.
Adapter Properties - Receive Port
Another common situation in which the SFTP adapter might be used is one in which files dropped in a folder on a remote SFTP server need to be retrieved in a BizTalk orchestration or passthrough configuration so that these remote files can be used locally or automatically transferred elsewhere. In this situation, a receive location of a transport-type SFTP would be configured in BizTalk to monitor a remote folder. You could configure a Send port that will send files picked up in this folder to a local folder using the FILE adapter.
After you add a new Receive Location and set the transport type to "nsoftware.SFTP 2024" (remember to set the Filters to associate this receive location with the file send port), click on the Configure button to bring up a new window called "nsoftware.SFTP 2024 Transport Properties". Then you can specify the details of how and where the SFTP adapter should connect. Many of these properties are the same as those documented in the Send Port section. In this section, I will document only the properties specific to using the adapter in a receive location, because many of the properties have the same meaning as in those given in the description of the SFTP adapter in a send port.
SFTP
The SFTP properties tell the adapter where on the SFTP server to retrieve the files. Again, these properties are fairly self-explanatory:
After Get | A set of FTP-style commands to be executed after the download. The help files lists available commands. |
Before Get | A set of FTP-style commands to be executed before the download. The help files lists available commands. |
Delete Mode | Determines under what conditions the remote file should be deleted after download. |
File Mask | Indicates the type of files to download from the SFTP server (for example, "*.txt"). |
Temp Path | This property indicates a temporary directory where the adapter can store any data before the adapter processes it. |
SSH Properties
The adapter has the same SSH properties in a receive location as in a send port.
Tuning Properties
Error Threshold | This property limits the number of errors that the adapter can incur before it shuts down and stops processing messages. |
Max Batch Size | This property limits the maximum amount of data the adapter can store before finalizing and processing the current batch to the number of bytes indicated. The default value of 0 indicates no limit. |
Max File Count | This property places a limit on the number of files that can be transmitted in a single batch. |
Max File Size | This property limits the maximum size of any file in the current transmission batch to the number of bytes indicated. The default value of 0 indicates no limit. |
Polling Interval | The number of seconds to wait between download attempts (default is 60 seconds, so for example every 60 seconds the adapter would check the server for new files). |
Usage: Receive Port
To configure a receive port to download files from the remote SFTP server, only a few of the following properties need to be set:
- For the SFTP properties, set the "Delete Mode" to "Never" (because you do not want to delete the remote files after you pick them up) and set "File Mask" to . (because you want to get all the files).
- For the SSH properties, use the same settings as noted in the Send Port example because you are connecting to the same server.
To test this, create a send port of a transport-type FILE with a filter pointing to this new SFTP receive location. Then, enable the ports, start the BizTalk Server, and drop some files in the remote SFTP server folder. The files will be picked up by the adapter during the next poll, downloaded, and passed to the BizTalk Message Box for consumption by the FILE send port.
Conclusion
This article illustrates the ease of use of the SFTP adapter in particular, but /n software provides a full set of adapters for connecting to various types of internet servers. The adapter properties are kept to a minimum for simplicity, but we make an effort to provide those properties that are necessary for effective control over configurations.
We appreciate your feedback. If you have any questions, comments, or suggestions about this article please contact our support team at support@nsoftware.com.