All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.juneau.rest.swagger.BasicSwaggerProvider Maven / Gradle / Ivy

// ***************************************************************************************************************************
// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.  See the NOTICE file *
// * distributed with this work for additional information regarding copyright ownership.  The ASF licenses this file        *
// * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance            *
// * with the License.  You may obtain a copy of the License at                                                              *
// *                                                                                                                         *
// *  http://www.apache.org/licenses/LICENSE-2.0                                                                             *
// *                                                                                                                         *
// * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an  *
// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the        *
// * specific language governing permissions and limitations under the License.                                              *
// ***************************************************************************************************************************
package org.apache.juneau.rest.swagger;

import java.util.*;

import org.apache.juneau.cp.*;
import org.apache.juneau.dto.swagger.Swagger;
import org.apache.juneau.jsonschema.*;
import org.apache.juneau.rest.*;
import org.apache.juneau.rest.annotation.*;
import org.apache.juneau.svl.*;

/**
 * Basic implementation of a {@link SwaggerProvider}.
 *
 * 
See Also:
*/ public class BasicSwaggerProvider implements SwaggerProvider { private final VarResolver vr; private final JsonSchemaGenerator js; private final Messages messages; private final FileFinder fileFinder; private final BeanStore beanStore; /** * Constructor. * * @param beanStore The bean store containing injectable beans for this logger. */ public BasicSwaggerProvider(BeanStore beanStore) { this( SwaggerProvider .create(beanStore) .varResolver(()->beanStore.getBean(VarResolver.class).get()) .fileFinder(()->beanStore.getBean(FileFinder.class).get()) .messages(()->beanStore.getBean(Messages.class).get()) .jsonSchemaGenerator(()->beanStore.getBean(JsonSchemaGenerator.class).get()) ); } /** * Constructor. * * @param builder The builder containing the settings for this Swagger provider. */ public BasicSwaggerProvider(SwaggerProvider.Builder builder) { this.beanStore = builder.beanStore; this.vr = builder.varResolver().orElse(beanStore.getBean(VarResolver.class).orElse(VarResolver.DEFAULT)); this.js = builder.jsonSchemaGenerator().orElse(beanStore.getBean(JsonSchemaGenerator.class).orElse(JsonSchemaGenerator.DEFAULT)); this.messages = builder.messages().orElse(null); this.fileFinder = builder.fileFinder().orElse(null); } /** * Returns the Swagger associated with the specified context of a {@link Rest}-annotated class. * *

* Subclasses can override this to provide their own method for generating Swagger. * * @param context The context of the {@link Rest}-annotated class. * @param locale The request locale. * @return A new {@link Swagger} object. * @throws Exception If an error occurred producing the Swagger. */ @Override /* SwaggerProvider */ public Swagger getSwagger(RestContext context, Locale locale) throws Exception { Class c = context.getResourceClass(); FileFinder ff = fileFinder != null ? fileFinder : FileFinder.create(beanStore).cp(c,null,false).build(); Messages mb = messages != null ? messages.forLocale(locale) : Messages.create(c).build().forLocale(locale); VarResolverSession vrs = vr.createSession().bean(Messages.class, mb); BasicSwaggerProviderSession session = new BasicSwaggerProviderSession(context, locale, ff, messages, vrs, js.getSession()); return session.getSwagger(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy