[jboss-jira] [JBoss JIRA] Resolved: (JBESB-298) URL parsing in EdtFtpImpl.checkParms()

Esteban Schifman (JIRA) jira-events at jboss.com
Wed Jan 3 17:57:26 EST 2007


     [ http://jira.jboss.com/jira/browse/JBESB-298?page=all ]

Esteban Schifman resolved JBESB-298.
------------------------------------

    Fix Version/s: 4.0
       Resolution: Done

Fixed following Bernard's suggestion.  Thank you Bernard !   :-)

> URL parsing in EdtFtpImpl.checkParms()
> --------------------------------------
>
>                 Key: JBESB-298
>                 URL: http://jira.jboss.com/jira/browse/JBESB-298
>             Project: JBoss ESB
>          Issue Type: Bug
>      Security Level: Public(Everyone can see) 
>            Reporter: Bernard Tison
>         Assigned To: Esteban Schifman
>             Fix For: 4.0
>
>
> I think there might be a problem with the way user/password information is parsed from the FTP URL for a FTP Gateway.
> This is based on the static router quickstart example.
> The jbossesb.xml contains the following provider definition:
> Code:
> <ftp-provider name="FTPprovider" hostname="localhost" >
>           	<ftp-bus busid="StaticRouterFtpGW" >
>           		<ftp-message-filter
>           			username="ftpuser"
>           			password="ftppassword"
>           			passive="false"
>           			directory="/tmp/esbInput"
>           			input-suffix=".dat"
>           		/>
>           	</ftp-bus>
>           </ftp-provider>
> 	
> This results in the following definition in the jbossesb-gateway.xml:
> Code:
> <Ftp-Gateway URL="ftp://ftpuser:ftppassword@localhost:/tmp/esbInput"
>  errorDelete="true" gatewayClass="org.jboss.soa.esb.listeners.gateway.RemoteGatewayListener"
>  ...(non-relevant portion removed) "/>
> 	
> When the gateway is initialized, the org.jboss.internal.soa.esb.util.EdtFtpImpl class will parse the URL and connect to the FTP server.
> To parse the username/password out of the URL, the checkParms() method of the EdtFtpImpl class uses the following code (lines 190-198):
> Code:
> 		String[] sa = (null == url) ? null
> 				: url.getAuthority().split(":"); 
> 		m_sUser =  (null!=sa) ? sa[0] :m_oParms.getAttribute(PARMS_USER);
> 		if (null == m_sUser)
> 			throw new Exception("No username specified for FTP");
> 		m_sPasswd = (null!=sa) ? sa[1] :m_oParms.getAttribute(PARMS_PASSWD);
> 	
> The url.getAuthority() method returns ftpuser:ftppassword at localhost, which results in m_sUser="ftpuser" and m_sPasswd="ftppassword at localhost". This should be: m_sUser="ftpuser" and m_sPasswd="ftppassword".
> Suggestion for fix: use url.getUserInfo() to get the user/password out of the FTP URL. This is how it is done in the EdtFtpImpl(FTPEpr p_oP, boolean p_bConnect) constructor. 

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira

        



More information about the jboss-jira mailing list