Added basic authentication for some resources.

This commit is contained in:
neviyn 2018-09-21 12:51:13 +01:00
parent 61e00c4a43
commit 876a09bc85
7 changed files with 70 additions and 3 deletions

View File

@ -11,4 +11,6 @@ database:
hibernate.hbm2ddl.auto: create hibernate.hbm2ddl.auto: create
server: server:
rootPath: /api/ rootPath: /api/
adminPassword: "testPassword"

View File

@ -2,14 +2,19 @@ package uk.co.neviyn.Observations;
import io.dropwizard.Application; import io.dropwizard.Application;
import io.dropwizard.assets.AssetsBundle; import io.dropwizard.assets.AssetsBundle;
import io.dropwizard.auth.AuthDynamicFeature;
import io.dropwizard.auth.AuthValueFactoryProvider;
import io.dropwizard.auth.basic.BasicCredentialAuthFilter;
import io.dropwizard.db.DataSourceFactory; import io.dropwizard.db.DataSourceFactory;
import io.dropwizard.hibernate.HibernateBundle; import io.dropwizard.hibernate.HibernateBundle;
import io.dropwizard.jersey.setup.JerseyEnvironment; import io.dropwizard.jersey.setup.JerseyEnvironment;
import io.dropwizard.setup.Bootstrap; import io.dropwizard.setup.Bootstrap;
import io.dropwizard.setup.Environment; import io.dropwizard.setup.Environment;
import uk.co.neviyn.Observations.auth.SimpleAuthenticator;
import uk.co.neviyn.Observations.core.Observation; import uk.co.neviyn.Observations.core.Observation;
import uk.co.neviyn.Observations.core.Site; import uk.co.neviyn.Observations.core.Site;
import uk.co.neviyn.Observations.core.Tutor; import uk.co.neviyn.Observations.core.Tutor;
import uk.co.neviyn.Observations.core.User;
import uk.co.neviyn.Observations.dao.ObservationDao; import uk.co.neviyn.Observations.dao.ObservationDao;
import uk.co.neviyn.Observations.dao.SiteDao; import uk.co.neviyn.Observations.dao.SiteDao;
import uk.co.neviyn.Observations.dao.TutorDao; import uk.co.neviyn.Observations.dao.TutorDao;
@ -45,6 +50,13 @@ public class ObservationsApplication extends Application<ObservationsConfigurati
@Override @Override
public void run(ObservationsConfiguration observationsConfiguration, Environment environment) { public void run(ObservationsConfiguration observationsConfiguration, Environment environment) {
final JerseyEnvironment jersey = environment.jersey(); final JerseyEnvironment jersey = environment.jersey();
jersey.register(new AuthDynamicFeature(
new BasicCredentialAuthFilter.Builder<User>()
.setAuthenticator(new SimpleAuthenticator(observationsConfiguration.getAdminPassword()))
.setRealm("SECURITY")
.buildAuthFilter()
));
jersey.register(new AuthValueFactoryProvider.Binder<>(User.class));
TutorDao tutorDao = new TutorDao(hibernate.getSessionFactory()); TutorDao tutorDao = new TutorDao(hibernate.getSessionFactory());
SiteDao siteDao = new SiteDao(hibernate.getSessionFactory()); SiteDao siteDao = new SiteDao(hibernate.getSessionFactory());
ObservationDao observationDao = new ObservationDao(hibernate.getSessionFactory()); ObservationDao observationDao = new ObservationDao(hibernate.getSessionFactory());

View File

@ -3,6 +3,7 @@ package uk.co.neviyn.Observations;
import com.fasterxml.jackson.annotation.JsonProperty; import com.fasterxml.jackson.annotation.JsonProperty;
import io.dropwizard.Configuration; import io.dropwizard.Configuration;
import io.dropwizard.db.DataSourceFactory; import io.dropwizard.db.DataSourceFactory;
import javax.validation.Valid; import javax.validation.Valid;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
@ -11,6 +12,10 @@ public class ObservationsConfiguration extends Configuration {
@NotNull @NotNull
private DataSourceFactory database = new DataSourceFactory(); private DataSourceFactory database = new DataSourceFactory();
@Valid
@NotNull
private String adminPassword;
@JsonProperty("database") @JsonProperty("database")
public void setDataSourceFactory(DataSourceFactory factory) { public void setDataSourceFactory(DataSourceFactory factory) {
this.database = factory; this.database = factory;
@ -21,4 +26,9 @@ public class ObservationsConfiguration extends Configuration {
return database; return database;
} }
@JsonProperty("adminPassword")
public String getAdminPassword() {
return adminPassword;
}
} }

View File

@ -0,0 +1,23 @@
package uk.co.neviyn.Observations.auth;
import io.dropwizard.auth.AuthenticationException;
import io.dropwizard.auth.Authenticator;
import io.dropwizard.auth.basic.BasicCredentials;
import lombok.AllArgsConstructor;
import uk.co.neviyn.Observations.core.User;
import java.util.Optional;
@AllArgsConstructor
public class SimpleAuthenticator implements Authenticator<BasicCredentials, User> {
private final String adminPassword;
@Override
public Optional<User> authenticate(BasicCredentials credentials) throws AuthenticationException {
if (adminPassword.equals(credentials.getPassword())) {
return Optional.of(new User(credentials.getUsername()));
}
return Optional.empty();
}
}

View File

@ -0,0 +1,16 @@
package uk.co.neviyn.Observations.core;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.security.Principal;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Principal {
private String name;
}

View File

@ -1,10 +1,12 @@
package uk.co.neviyn.Observations.resources; package uk.co.neviyn.Observations.resources;
import io.dropwizard.auth.Auth;
import io.dropwizard.hibernate.UnitOfWork; import io.dropwizard.hibernate.UnitOfWork;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import uk.co.neviyn.Observations.api.SelectOption; import uk.co.neviyn.Observations.api.SelectOption;
import uk.co.neviyn.Observations.core.Site; import uk.co.neviyn.Observations.core.Site;
import uk.co.neviyn.Observations.core.Tutor; import uk.co.neviyn.Observations.core.Tutor;
import uk.co.neviyn.Observations.core.User;
import uk.co.neviyn.Observations.dao.SiteDao; import uk.co.neviyn.Observations.dao.SiteDao;
import javax.ws.rs.*; import javax.ws.rs.*;
@ -22,7 +24,7 @@ public class SiteResource {
@POST @POST
@UnitOfWork @UnitOfWork
public Site add(String name) { public Site add(@Auth User user, String name) {
return dao.persist(new Site(name)); return dao.persist(new Site(name));
} }

View File

@ -1,11 +1,13 @@
package uk.co.neviyn.Observations.resources; package uk.co.neviyn.Observations.resources;
import com.fasterxml.jackson.annotation.JsonProperty; import com.fasterxml.jackson.annotation.JsonProperty;
import io.dropwizard.auth.Auth;
import io.dropwizard.hibernate.UnitOfWork; import io.dropwizard.hibernate.UnitOfWork;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import uk.co.neviyn.Observations.core.Site; import uk.co.neviyn.Observations.core.Site;
import uk.co.neviyn.Observations.core.Tutor; import uk.co.neviyn.Observations.core.Tutor;
import uk.co.neviyn.Observations.core.User;
import uk.co.neviyn.Observations.dao.SiteDao; import uk.co.neviyn.Observations.dao.SiteDao;
import uk.co.neviyn.Observations.dao.TutorDao; import uk.co.neviyn.Observations.dao.TutorDao;
@ -24,7 +26,7 @@ public class TutorResource {
@POST @POST
@UnitOfWork @UnitOfWork
public Tutor add(NewTutor newTutor) { public Tutor add(@Auth User user, NewTutor newTutor) {
final Site site = siteDao.get(newTutor.siteId); final Site site = siteDao.get(newTutor.siteId);
final Tutor tutor = Tutor.builder().name(newTutor.name).site(site).build(); final Tutor tutor = Tutor.builder().name(newTutor.name).site(site).build();
return dao.persist(tutor); return dao.persist(tutor);