Skip to content
This repository has been archived by the owner on Oct 11, 2024. It is now read-only.

Commit

Permalink
Add basic authentication for secure SOS
Browse files Browse the repository at this point in the history
  • Loading branch information
glegal committed Sep 7, 2017
1 parent 6a0c419 commit edfa117
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 11 deletions.
21 changes: 15 additions & 6 deletions bindings/src/main/resources/import-configuration.xsd
Original file line number Diff line number Diff line change
Expand Up @@ -1207,12 +1207,21 @@
If version 2.0.0 is used, the binding has to
be defined, e.g. SOAP, POX binding.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="insertSweArrayObservationTimeoutBuffer">
<xs:annotation>
<xs:documentation>
</xs:annotation>
</xs:element>
<xs:element ref="Credentials" minOccurs="0">
<xs:annotation>
<xs:documentation>
If the sos server is protected by Basic
authentication, the user name and password has to
be defined.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="insertSweArrayObservationTimeoutBuffer">
<xs:annotation>
<xs:documentation>
An additional timeout buffer for connect and socket
timeout when using import strategy
"SweArrayObservationWithSplitExtension". Scale is in
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -387,20 +387,44 @@ public URL getSosUrl() throws MalformedURLException {
}

/**
* <p>getUser.</p>
* <p>getSosUser.</p>
*
* @return a {@link java.lang.String} object.
*/
public String getUser() {
public String getSosUser() {
if (importConf.getSosMetadata().getCredentials() != null) {
return importConf.getSosMetadata().getCredentials().getUserName();
}
return null;
}

/**
* <p>getSosPassword.</p>
*
* @return a {@link java.lang.String} object.
*/
public String getSosPassword() {
if (importConf.getSosMetadata().getCredentials() != null) {
return importConf.getSosMetadata().getCredentials().getPassword();
}
return null;
}

/**
* <p>getFtpUser.</p>
*
* @return a {@link java.lang.String} object.
*/
public String getFtpUser() {
return importConf.getDataFile().getRemoteFile().getCredentials().getUserName();
}

/**
* <p>getPassword.</p>
* <p>getFtpPassword.</p>
*
* @return a {@link java.lang.String} object.
*/
public String getPassword() {
public String getFtpPassword() {
return importConf.getDataFile().getRemoteFile().getCredentials().getPassword();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.MalformedURLException;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
import java.nio.charset.Charset;
import java.text.ParseException;
Expand Down Expand Up @@ -261,6 +263,16 @@ public SensorObservationService(final Configuration config)
+ " if required.",
sweArrayObservationTimeOutBuffer);
}
if (config.getSosUser() != null && config.getSosPassword()!= null) {
try {
URI u = sosUrl.toURI();
sosWrapper.setBasicAuthHost(u.getScheme() + "://" + u.getHost() + ':' + u.getPort());
sosWrapper.setBasicAuthUser(config.getSosUser());
sosWrapper.setBasicAuthPassword(config.getSosPassword());
} catch (URISyntaxException ex) {
throw new OXFException(ex);
}
}
}

private Binding getBinding(final String binding) throws OXFException {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ private DataFile getRemoteFile() {
FileOutputStream fos = null;
try {
client.connect(config.getFtpHost());
final boolean login = client.login(config.getUser(), config.getPassword());
final boolean login = client.login(config.getFtpUser(), config.getFtpPassword());
if (login) {
LOG.info("FTP: connected...");
// download file
Expand Down

0 comments on commit edfa117

Please sign in to comment.