Changes for page SFTP Known Hosts
                  Last modified by Danniar Firdausy on 2024/09/18 20:35
              
      
      From version  27.1 
    
    
              edited by Erik Bakker
        
on 2024/06/20 09:15
     on 2024/06/20 09:15
      Change comment:
              There is no comment for this version
          
         
      To version  34.3 
    
    
              edited by Danniar Firdausy
        
on 2024/09/11 16:46
     on 2024/09/11 16:46
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. ebakker1 +XWiki.dfirdausy 
- Content
-   ... ... @@ -11,9 +11,9 @@ 11 11 12 12 == 2. Key concepts == 13 13 14 -This microlearning is about SFTP s ecurity.14 +This microlearning is about SFTP known host files. 15 15 16 -By SFTP s ecurity, we mean: Making sure thattheSFTPwe connect toknowsthatwe are indeedeMagiz16 +By SFTP known hosts, we mean: Making sure that we are certain that we connect to the correct SFTP to prevent data theft as a result of a "man in the middle" attack. 17 17 18 18 * Each SFTP has a unique fingerprint that identifies the SFTP. 19 19 * To prevent a "man in the middle" attack, this fingerprint needs to be stored client side. ... ... @@ -27,6 +27,30 @@ 27 27 28 28 === 3.1 Known Hosts File Generation - Portal === 29 29 30 +To configure the preferred option we start at the flow level in Create. Once the flow is opened please enter "Start Editing" mode and navigate to the Support object tab in the right panel. In here open the SFTP (caching) session factory that is used to connect to the SFTP. 31 + 32 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-known-hosts--sftp-session-factory-start.png]] 33 + 34 +Once you see the configuration of the component please define a property for the known hosts field. This property will later on be used to generate and store the known hosts file while in Deploy. 35 + 36 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-known-hosts--sftp-session-known-hosts.png]] 37 + 38 +When you are satisfied with the configuration you can save it, press "Stop editing", and create a new version of the flow. Now that we have a new version of the flow we navigate to the Deploy phase to trigger eMagiz to generate and store the known hosts file correctly on runtime level. To do so we need to create the property (with the correct name) in Deploy. If you are unsure on how to create properties in the first place, please check out this [[microlearning>>Main.eMagiz Academy.Microlearnings.Intermediate Level.File based connectivity.intermediate-file-based-connectivity-sftp-connectivity||target="blank"]]. 39 + 40 +When defining the value of the property we now have an additional option in the "Data type" dropdown called "Known hosts String". Once you have selected this a cogwheel icon will apear next to the value field. 41 + 42 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-known-hosts--known-hosts-string-property-start.png]] 43 + 44 +Pressing this cogwheel icon will open a new pop-up in which you need to define the port and the host you want to connect to. 45 + 46 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-known-hosts--known-hosts-string-property-config-empty.png]] 47 + 48 +After filling in the correct values press the button called "Generate known hosts string" to make sure that eMagiz will generate the file for you. As a result, eMagiz will show you the correct string that defines the known host. 49 + 50 +[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-known-hosts--known-hosts-string-property-generated.png]] 51 + 52 +{{info}}In case you have multiple SFTP connections within your flow (or runtime) you should use distinct property placeholder for each SFTP to utilize this functionality.{{/info}} 53 + 30 30 === 3.2 Known Hosts File Generation - Command Line === 31 31 32 32 The secondary option, when there are IP restrictions, provides you with the option to execute several commands after gaining access to the correct server to generate the known hosts file. These steps are detailed below. ... ... @@ -41,31 +41,21 @@ 41 41 * Define a property for the known hosts field in the SFTP (caching) session factory. 42 42 ** Provide a value for the property upon deploying the release that follows the following structure: {{code}}classpath:emagiz-resources/[filename]{{/code}} 43 43 44 -If you are looking for some introductory reading into certificates, please check this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Novice.Securing Data Traffic.novice-securing-your-data-traffic-what-are-certificates.WebHome||target="blank"]]. 45 - 46 -As the private key is yours, you can ask a trusted party to generate the key, or you could create it yourself. The latter part happens a lot when connecting to an SFTP. You could use a tool like PuttyGen to achieve this. As a result, you will have a keypair. The private key should be kept safely with you in eMagiz, and you need to share the public key with the SFTP server party. In this microlearning, I will not explain how PuttyGen works in detail. Instead, we will focus on the part in eMagiz. In eMagiz, we need to refer to the key file (linked under Resources), and we need to refer to the password we use to save our key file securely. 47 - 48 -[[image:Main.Images.Microlearning.WebHome@intermediate-file-based-connectivity-sftp-security--private-key-config.png]] 49 - 50 -Note that the use of a password and a private key are mutually exclusive. So you need to either provide a password or a private key for authentication. In the help text provided by eMagiz, you can see how the reference to the key file should be made. 51 - 52 -When you have configured these settings, you have finished the configuration in eMagiz. Now you could test whether the configuration is set up correctly between eMagiz and the SFTP. If this is not the case, eMagiz will notify you via the Manage phase, either as an error message or a log entry. 53 - 54 -Using this setting gives the server the option to verify if the communication request came from eMagiz (or at least from the party that holds the private key of eMagiz). This is an additional security measure to ensure data integrity and quality. 55 - 56 56 == 4. Key takeaways == 57 57 58 -* Private key is unique per client 59 -* Private key should only be known to the client 60 -* Public key should be known to the SFTP (server), so they trust us when we set up the communication 61 -* A private key comes with a passphrase 70 +* Each SFTP has a unique fingerprint that identifies the SFTP. 71 +* To prevent a "man in the middle" attack, this fingerprint needs to be stored client side. 72 +* There are two distinct methods to generate the known hosts file. 62 62 63 63 == 5. Suggested Additional Readings == 64 64 65 65 If you are interested in this topic and want more information, please read the release notes provided by eMagiz. Furthermore, check out these links: 66 66 67 -* [[SFTP Outbound>>https://docs.spring.io/spring-integration/docs/2.2.6.RELEASE/reference/html/sftp.html#sftp-outbound||target="blank"]] 78 +* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] 79 +** [[File based connectivity (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.File based connectivity.WebHome||target="blank"]] 80 +*** [[SFTP Connectivity>>Main.eMagiz Academy.Microlearnings.Intermediate Level.File based connectivity.intermediate-file-based-connectivity-sftp-connectivity||target="blank"]] 81 +*** [[SFTP Security>>Main.eMagiz Academy.Microlearnings.Intermediate Level.File based connectivity.intermediate-file-based-connectivity-sftp-security||target="blank"]] 82 +* [[Known Hosts Files explained>>https://stackoverflow.com/questions/33243393/what-is-actually-in-known-hosts||target="blank"]] 68 68 * [[SFTP Session Factory>>https://docs.spring.io/spring-integration/docs/2.2.6.RELEASE/reference/html/sftp.html#sftp-session-factory||target="blank"]] 69 -* [[SFTP Authentication>>https://www.2brightsparks.com/resources/articles/sftp-authentication.html||target="blank"]] 70 70 71 71 )))((({{toc/}}))){{/container}}{{/container}} 
 
