Hi Freeman

While I appreciate yout effort I'm -1 on this commit.
Here is why:

- we've worked hard on minimizing cxf rt frontend jaxrs and in one ho you add a Swagger related code without even discussing it.

Please revert your commits.

IMHO, it may go as an *optional* dependency to rt/rs/description module which is where it should stay, on the trunk only. I honestly do not want it in the rt/frontend/jaxrs affectinf CXF 2.7.x deployments

Thanks, Sergey




On 08/11/13 03:30, [email protected] wrote:
Author: ffang
Date: Fri Nov  8 03:30:41 2013
New Revision: 1539911

URL: http://svn.apache.org/r1539911
Log:
[CXF-5379]introduce cxf swagger feature

Added:
     cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/
     
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/SwaggerFeature.java
Modified:
     cxf/trunk/parent/pom.xml
     cxf/trunk/rt/frontend/jaxrs/pom.xml
     
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/AbstractJAXRSFactoryBean.java

Modified: cxf/trunk/parent/pom.xml
URL: 
http://svn.apache.org/viewvc/cxf/trunk/parent/pom.xml?rev=1539911&r1=1539910&r2=1539911&view=diff
==============================================================================
--- cxf/trunk/parent/pom.xml (original)
+++ cxf/trunk/parent/pom.xml Fri Nov  8 03:30:41 2013
@@ -149,6 +149,7 @@
          <cxf.spring.osgi.version>1.2.1</cxf.spring.osgi.version>
          <cxf.spring.ldap.version>1.3.1.RELEASE</cxf.spring.ldap.version>
          <cxf.spring.mock>spring-test</cxf.spring.mock>
+        <cxf.swagger.version>1.3.0</cxf.swagger.version>
          <cxf.velocity.version>1.7</cxf.velocity.version>
          <cxf.woodstox.core.version>4.2.0</cxf.woodstox.core.version>
          <cxf.woodstox.stax2-api.version>3.1.1</cxf.woodstox.stax2-api.version>
@@ -1615,6 +1616,12 @@
                  <artifactId>msv-core</artifactId>
                  <version>${cxf.msv.version}</version>
              </dependency>
+            <dependency>
+                <groupId>com.wordnik</groupId>
+                <artifactId>swagger-jaxrs_2.10</artifactId>
+                <version>${cxf.swagger.version}</version>
+            </dependency>
+
          </dependencies>
      </dependencyManagement>


Modified: cxf/trunk/rt/frontend/jaxrs/pom.xml
URL: 
http://svn.apache.org/viewvc/cxf/trunk/rt/frontend/jaxrs/pom.xml?rev=1539911&r1=1539910&r2=1539911&view=diff
==============================================================================
--- cxf/trunk/rt/frontend/jaxrs/pom.xml (original)
+++ cxf/trunk/rt/frontend/jaxrs/pom.xml Fri Nov  8 03:30:41 2013
@@ -36,6 +36,7 @@
              javax.servlet*;version="${cxf.osgi.javax.servlet.version}",
              org.apache.aries*;version="${cxf.aries.version.range}",
              
org.springframework*;resolution:="optional";version="${cxf.osgi.spring.version}",
+            com.wordnik.swagger.jaxrs*;resolution:="optional";version="[1.3.0, 
1.4.0)",
              javax.ws.rs.client;version="[2.0,3)",
              javax.ws.rs*;version="[1.0,3)",
          </cxf.osgi.import>
@@ -158,6 +159,10 @@
                  </exclusion>
              </exclusions>
          </dependency>
+        <dependency>
+            <groupId>com.wordnik</groupId>
+            <artifactId>swagger-jaxrs_2.10</artifactId>
+        </dependency>
      </dependencies>



Modified: 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/AbstractJAXRSFactoryBean.java
URL: 
http://svn.apache.org/viewvc/cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/AbstractJAXRSFactoryBean.java?rev=1539911&r1=1539910&r2=1539911&view=diff
==============================================================================
--- 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/AbstractJAXRSFactoryBean.java
 (original)
+++ 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/AbstractJAXRSFactoryBean.java
 Fri Nov  8 03:30:41 2013
@@ -110,6 +110,7 @@ public class AbstractJAXRSFactoryBean ex
          super.setBus(bus);
          checkBindingFactory(bus);
          serviceFactory.setBus(bus);
+        bus.setProperty(JAXRSServiceFactoryBean.class.getName(), 
serviceFactory);
      }

      /*
@@ -204,6 +205,7 @@ public class AbstractJAXRSFactoryBean ex
       */
      public void setServiceFactory(JAXRSServiceFactoryBean serviceFactory) {
          this.serviceFactory = serviceFactory;
+        getBus().setProperty(JAXRSServiceFactoryBean.class.getName(), 
serviceFactory);
      }

      protected Endpoint createEndpoint() throws BusException, 
EndpointException {

Added: 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/SwaggerFeature.java
URL: 
http://svn.apache.org/viewvc/cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/SwaggerFeature.java?rev=1539911&view=auto
==============================================================================
--- 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/SwaggerFeature.java
 (added)
+++ 
cxf/trunk/rt/frontend/jaxrs/src/main/java/org/apache/cxf/jaxrs/swagger/SwaggerFeature.java
 Fri Nov  8 03:30:41 2013
@@ -0,0 +1,142 @@
+/**
+ * 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.cxf.jaxrs.swagger;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.cxf.Bus;
+import org.apache.cxf.endpoint.Server;
+import org.apache.cxf.feature.AbstractFeature;
+import org.apache.cxf.jaxrs.JAXRSServiceFactoryBean;
+import org.apache.cxf.jaxrs.model.AbstractResourceInfo;
+import org.apache.cxf.jaxrs.provider.ProviderFactory;
+
+public class SwaggerFeature extends AbstractFeature {
+
+    private String resourcePackage;
+    private String version = "1.0.0";
+    private String basePath;
+    private String title = "Rest sample app";
+    private String description = "This is a app.";
+    private String contact = "[email protected]";
+    private String license = "Apache 2.0 License";
+    private String licenseUrl = 
"http://www.apache.org/licenses/LICENSE-2.0.html";;
+    private boolean scan = true;
+    @Override
+    public void initialize(Server server, Bus bus) {
+        List<Object> serviceBeans = new ArrayList<Object>();
+        serviceBeans.add(new 
com.wordnik.swagger.jaxrs.listing.ApiListingResourceJSON());
+        calulateDefaultResourcePackage(bus);
+        calulateDefaultBasePath(server);
+        
((JAXRSServiceFactoryBean)bus.getProperty(JAXRSServiceFactoryBean.class.getName())).
+            setResourceClassesFromBeans(serviceBeans);
+        List<Object> providers = new ArrayList<Object>();
+        providers.add(new 
com.wordnik.swagger.jaxrs.listing.ResourceListingProvider());
+        providers.add(new 
com.wordnik.swagger.jaxrs.listing.ApiDeclarationProvider());
+        
((ProviderFactory)bus.getProperty(ProviderFactory.class.getName())).setUserProviders(providers);
+        com.wordnik.swagger.jaxrs.config.BeanConfig beanConfig = new 
com.wordnik.swagger.jaxrs.config.BeanConfig();
+        beanConfig.setResourcePackage(getResourcePackage());
+        beanConfig.setVersion(getVersion());
+        beanConfig.setBasePath(getBasePath());
+        beanConfig.setTitle(getTitle());
+        beanConfig.setDescription(getDescription());
+        beanConfig.setContact(getContact());
+        beanConfig.setLicense(getLicense());
+        beanConfig.setLicenseUrl(getLicenseUrl());
+        beanConfig.setScan(isScan());
+        initializeProvider(server.getEndpoint(), bus);
+    }
+    private void calulateDefaultResourcePackage(Bus bus) {
+        JAXRSServiceFactoryBean serviceFactoryBean =
+            
(JAXRSServiceFactoryBean)bus.getProperty(JAXRSServiceFactoryBean.class.getName());
+        AbstractResourceInfo resourceInfo = 
serviceFactoryBean.getClassResourceInfo().get(0);
+
+        if ((resourceInfo != null)
+            && (getResourcePackage() == null || getResourcePackage().length() 
== 0)) {
+            
setResourcePackage(resourceInfo.getResourceClass().getPackage().getName());
+        }
+    }
+
+    private void calulateDefaultBasePath(Server server) {
+        String address = server.getEndpoint().getEndpointInfo().getAddress();
+        if (getBasePath() == null || getBasePath().length() == 0) {
+            if (address.startsWith("http")) {
+                setBasePath(address + "/api-docs");
+            } else {
+                setBasePath("http://localhost:8181/cxf"; + address + 
"/api-docs");
+            }
+        }
+    }
+    public String getResourcePackage() {
+        return resourcePackage;
+    }
+    public void setResourcePackage(String resourcePackage) {
+        this.resourcePackage = resourcePackage;
+    }
+    public String getVersion() {
+        return version;
+    }
+    public void setVersion(String version) {
+        this.version = version;
+    }
+    public String getBasePath() {
+        return basePath;
+    }
+    public void setBasePath(String basePath) {
+        this.basePath = basePath;
+    }
+    public String getTitle() {
+        return title;
+    }
+    public void setTitle(String title) {
+        this.title = title;
+    }
+    public String getDescription() {
+        return description;
+    }
+    public void setDescription(String description) {
+        this.description = description;
+    }
+    public String getContact() {
+        return contact;
+    }
+    public void setContact(String contact) {
+        this.contact = contact;
+    }
+    public String getLicense() {
+        return license;
+    }
+    public void setLicense(String license) {
+        this.license = license;
+    }
+    public String getLicenseUrl() {
+        return licenseUrl;
+    }
+    public void setLicenseUrl(String licenseUrl) {
+        this.licenseUrl = licenseUrl;
+    }
+    public boolean isScan() {
+        return scan;
+    }
+    public void setScan(boolean scan) {
+        this.scan = scan;
+    }
+
+}




--
Sergey Beryozkin

Talend Community Coders
http://coders.talend.com/

Blog: http://sberyozkin.blogspot.com

Reply via email to