2018-11-14 13:58:27 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018 ETH Zürich, Educational Development and Technology (LET)
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package ch.ethz.seb.sebserver.webservice;
|
|
|
|
|
2019-03-07 12:10:48 +01:00
|
|
|
import java.net.InetAddress;
|
|
|
|
import java.net.UnknownHostException;
|
|
|
|
|
2019-02-04 18:28:31 +01:00
|
|
|
import javax.sql.DataSource;
|
|
|
|
|
2019-04-23 12:34:11 +02:00
|
|
|
import org.cryptonode.jncryptor.AES256JNCryptor;
|
|
|
|
import org.cryptonode.jncryptor.JNCryptor;
|
2018-11-14 13:58:27 +01:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
2019-03-07 12:10:48 +01:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
2019-02-04 18:28:31 +01:00
|
|
|
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
|
2018-11-14 13:58:27 +01:00
|
|
|
import org.springframework.boot.context.event.ApplicationReadyEvent;
|
|
|
|
import org.springframework.context.ApplicationListener;
|
2019-02-04 18:28:31 +01:00
|
|
|
import org.springframework.context.annotation.Bean;
|
|
|
|
import org.springframework.context.annotation.Configuration;
|
|
|
|
import org.springframework.context.annotation.Import;
|
|
|
|
import org.springframework.context.annotation.Lazy;
|
2019-03-07 12:10:48 +01:00
|
|
|
import org.springframework.core.env.Environment;
|
2019-02-04 18:28:31 +01:00
|
|
|
import org.springframework.security.oauth2.provider.token.TokenStore;
|
|
|
|
import org.springframework.security.oauth2.provider.token.store.JdbcTokenStore;
|
2018-11-14 13:58:27 +01:00
|
|
|
|
2019-04-26 20:22:17 +02:00
|
|
|
import ch.ethz.seb.sebserver.gbl.Constants;
|
2018-11-14 13:58:27 +01:00
|
|
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
|
|
|
|
2019-03-07 12:10:48 +01:00
|
|
|
// TODO check if DataSourceAutoConfiguration and TokenStore bean definition is really needed here
|
|
|
|
// or if it is possible to move them to the WebServiceSecurityConfig.
|
|
|
|
// test with starting web and gui separately as well as together
|
2019-02-04 18:28:31 +01:00
|
|
|
@Configuration
|
2018-11-14 13:58:27 +01:00
|
|
|
@WebServiceProfile
|
2019-02-04 18:28:31 +01:00
|
|
|
@Import(DataSourceAutoConfiguration.class)
|
2018-11-14 13:58:27 +01:00
|
|
|
public class WebServiceInit implements ApplicationListener<ApplicationReadyEvent> {
|
|
|
|
|
|
|
|
private static final Logger log = LoggerFactory.getLogger(WebServiceInit.class);
|
|
|
|
|
2019-03-07 12:10:48 +01:00
|
|
|
@Autowired
|
|
|
|
private Environment environment;
|
|
|
|
|
2018-11-14 13:58:27 +01:00
|
|
|
@Override
|
|
|
|
public void onApplicationEvent(final ApplicationReadyEvent event) {
|
|
|
|
log.info("Initialize SEB-Server Web-Service Component");
|
|
|
|
|
2019-03-07 12:10:48 +01:00
|
|
|
try {
|
|
|
|
log.info("----> config server address: {}", this.environment.getProperty("server.address"));
|
|
|
|
log.info("----> config server port: {}", this.environment.getProperty("server.port"));
|
|
|
|
|
|
|
|
log.info("----> local host address: {}", InetAddress.getLocalHost().getHostAddress());
|
|
|
|
log.info("----> local host name: {}", InetAddress.getLocalHost().getHostName());
|
|
|
|
|
|
|
|
log.info("----> remote host address: {}", InetAddress.getLoopbackAddress().getHostAddress());
|
|
|
|
log.info("----> remote host address: {}", InetAddress.getLoopbackAddress().getHostName());
|
|
|
|
} catch (final UnknownHostException e) {
|
|
|
|
log.error("Unknown Host: ", e);
|
|
|
|
}
|
|
|
|
|
2018-11-15 11:24:18 +01:00
|
|
|
// TODO whatever has to be initialized for the web-service component right after startup comes here
|
2018-11-14 13:58:27 +01:00
|
|
|
|
|
|
|
}
|
2019-02-04 18:28:31 +01:00
|
|
|
|
|
|
|
@Lazy
|
|
|
|
@Bean
|
|
|
|
public TokenStore tokenStore(final DataSource dataSource) {
|
|
|
|
return new JdbcTokenStore(dataSource);
|
|
|
|
}
|
2019-04-23 12:34:11 +02:00
|
|
|
|
|
|
|
@Lazy
|
|
|
|
@Bean
|
|
|
|
public JNCryptor jnCryptor() {
|
2019-04-26 20:22:17 +02:00
|
|
|
final AES256JNCryptor aes256jnCryptor = new AES256JNCryptor();
|
|
|
|
aes256jnCryptor.setPBKDFIterations(Constants.JN_CRYPTOR_ITERATIONS);
|
|
|
|
return aes256jnCryptor;
|
2019-04-23 12:34:11 +02:00
|
|
|
}
|
2018-11-14 13:58:27 +01:00
|
|
|
}
|