I have an app which uses Guice and Jersey for REST services. How do I configure Swagger in Guice? I already have the following dependency:
compile group: 'io.swagger', name: 'swagger-jersey2-jaxrs', version: '1.5.0'
How do I generate the API docs automatically? Someone who has faced similar issues, please shed some light on this integration. Thanks a lot!
Guice like:
public class ServletContextListener extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
if(lifecycleInjector != null) return lifecycleInjector;
this.lifecycleInjector = InjectorBuilder
.fromModules(defineModules())
.createInjector(Stage.DEVELOPMENT);
return this.lifecycleInjector;
}
private List<Module> defineModules() {
ArrayList<Module> modules = new ArrayList<>();
modules.add(new ServletModule());
return modules;
}
}
JerseyServletModule like:
public class ServletModule extends JerseyServletModule {
@Override
protected void configureServlets() {
bind(GuiceContainer.class).to(GovernatorServletContainer.class).asEagerSingleton();
serve("/api/*").with(GuiceContainer.class);
}
@Provides
ResourceConfig getResourceConfig() {
final List<String> resources = new ArrayList<>();
resources.add("com.fasterxml.jackson.jaxrs.json");
final String[] arrayPackages = new String[resources.size()];
resources.toArray(arrayPackages);
return new RestApp(ImmutableMap.<String, Object>builder()
.put(PROPERTY_PACKAGES, arrayPackages)
.put(FEATURE_DISABLE_WADL, "true")
.build());
}
@SwaggerDefinition(tags = {@Tag(name = "app API", description = "Administrative API for app")})
@ApplicationPath(RestApp.BASE_REST_APP_URI)
public class RestApp extends PackagesResourceConfig {
public static final String BASE_REST_APP_URI = "/api";
@Override
public Set<Class<?>> getClasses() {
Set<Class<?>> classes = new HashSet<>();
classes.add(AppRestResource.class);
return classes;
}
}
How can I add the Swagger?
Thanks above all, I have fixed this problem. The sample is sample of guice-jersey-swagger