forked from loafle/openapi-generator-original
Merge branch 'master' of github.com:wordnik/swagger-codegen
This commit is contained in:
commit
d498f6f996
18
build.xml
18
build.xml
@ -11,10 +11,12 @@
|
||||
<mkdir dir="lib/ext"/>
|
||||
<mkdir dir="build"/>
|
||||
<mkdir dir="src/main/scala"/>
|
||||
<mkdir dir="src/test/java"/>
|
||||
<mkdir dir="src/test/scala"/>
|
||||
|
||||
<condition property="outputPath.set">
|
||||
<and>
|
||||
<isset property="outputPath"/>
|
||||
<isset property="outputDir"/>
|
||||
<isset property="apiServerRootDir"/>
|
||||
</and>
|
||||
</condition>
|
||||
@ -129,20 +131,20 @@
|
||||
<!-- generates the classes -->
|
||||
<target name="generate-java" depends="compile" description="generates APIs and model classes for java language">
|
||||
<fail unless="outputPath.set">
|
||||
Must specify the parameters: outputPath and apiServerRootDir eg. -DoutputPath=../../api-server-lib/java/src/main/java/com/wordnik/
|
||||
-DapiServerRootDir=../../api-server-lib/java/
|
||||
Must specify the parameters: outputPath and apiServerRootDir
|
||||
eg. -DoutputDir=../api-server-lib/java/src/main/java/com/wordnik/swagger -DapiServerRootDir=../api-server-lib/java/
|
||||
These are the output path of the Apis and the root directory that will be created for the api server (directory where structure is created)
|
||||
</fail>
|
||||
<mkdir dir="${outputPath}/api"/>
|
||||
<mkdir dir="${outputPath}/model"/>
|
||||
<mkdir dir="${outputDir}/api"/>
|
||||
<mkdir dir="${outputDir}/model"/>
|
||||
<echo>
|
||||
outputPath for Api = ${outputPath}
|
||||
outputDir for Api = ${outputDir}
|
||||
</echo>
|
||||
<echo>
|
||||
apiServerRootDir = ${apiServerRootDir}
|
||||
</echo>
|
||||
<delete>
|
||||
<fileset dir="${outputPath}" includes="*.java"/>
|
||||
<fileset dir="${outputDir}" includes="*.java"/>
|
||||
</delete>
|
||||
<java classname="com.wordnik.swagger.codegen.config.java.JavaLibCodeGen">
|
||||
<classpath>
|
||||
@ -151,7 +153,7 @@
|
||||
<include name="**/*.jar"/>
|
||||
</fileset>
|
||||
</classpath>
|
||||
<arg value="${outputPath}"/>
|
||||
<arg value="${apiServerRootDir}/config/apiConfiguration.json"/>
|
||||
</java>
|
||||
<copy todir="${apiServerRootDir}" overwrite="true">
|
||||
<fileset dir="conf/java/structure"/>
|
||||
|
@ -41,6 +41,24 @@ public class ApiConfiguration {
|
||||
|
||||
}
|
||||
|
||||
public String getDefaultServiceBaseClass() {
|
||||
return defaultServiceBaseClass;
|
||||
}
|
||||
|
||||
public void setDefaultServiceBaseClass(String defaultServiceBaseClass) {
|
||||
this.defaultServiceBaseClass = defaultServiceBaseClass;
|
||||
}
|
||||
|
||||
public Map<String, String> getBaseClassNames() {
|
||||
|
||||
return baseClassNames;
|
||||
}
|
||||
|
||||
public void setBaseClassNames(Map<String, String> baseClassNames) {
|
||||
this.baseClassNames = baseClassNames;
|
||||
}
|
||||
|
||||
|
||||
public void setServiceBaseClass(String defaultServiceBaseClass) {
|
||||
this.defaultServiceBaseClass = defaultServiceBaseClass;
|
||||
}
|
||||
|
@ -30,4 +30,20 @@ public class JavaCodeGenRulesProvider implements RulesProvider {
|
||||
return ignoreModels.contains(modelName);
|
||||
}
|
||||
|
||||
public List<String> getIgnoreMethods() {
|
||||
return ignoreMethods;
|
||||
}
|
||||
|
||||
public void setIgnoreMethods(List<String> ignoreMethods) {
|
||||
this.ignoreMethods = ignoreMethods;
|
||||
}
|
||||
|
||||
public List<String> getIgnoreModels() {
|
||||
return ignoreModels;
|
||||
}
|
||||
|
||||
public void setIgnoreModels(List<String> ignoreModels) {
|
||||
this.ignoreModels = ignoreModels;
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -5,9 +5,11 @@ import com.wordnik.swagger.codegen.config.ApiConfiguration;
|
||||
import com.wordnik.swagger.codegen.config.LanguageConfiguration;
|
||||
import com.wordnik.swagger.codegen.config.common.CamelCaseNamingPolicyProvider;
|
||||
import com.wordnik.swagger.exception.CodeGenerationException;
|
||||
import org.codehaus.jackson.map.DeserializationConfig;
|
||||
import org.codehaus.jackson.map.ObjectMapper;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
|
||||
/**
|
||||
* User: ramesh
|
||||
@ -18,59 +20,61 @@ public class JavaLibCodeGen extends LibraryCodeGenerator {
|
||||
|
||||
public static void main(String[] args) {
|
||||
if(args.length < 1){
|
||||
throw new CodeGenerationException("Invalid number of arguments passed: No command line argument was passed to the program for output path");
|
||||
throw new CodeGenerationException("Invalid number of arguments passed: No command line argument was passed to the program for config json");
|
||||
}
|
||||
|
||||
String outputPath = args[0];
|
||||
JavaLibCodeGen codeGenerator = new JavaLibCodeGen(outputPath);
|
||||
String configPath = args[0];
|
||||
JavaLibCodeGen codeGenerator = new JavaLibCodeGen(configPath);
|
||||
codeGenerator.generateCode();
|
||||
}
|
||||
|
||||
public JavaLibCodeGen(String outputPath){
|
||||
public JavaLibCodeGen(String configPath){
|
||||
|
||||
this.setApiConfig(initializeApiConfig());
|
||||
this.setLanguageConfig(initializeLangConfig(outputPath));
|
||||
final ObjectMapper mapper = new ObjectMapper();
|
||||
mapper.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES, false);
|
||||
this.setApiConfig(readApiConfiguration(configPath, mapper));
|
||||
this.setCodeGenRulesProvider(readRulesProviderConfig(configPath, mapper));
|
||||
this.setLanguageConfig( initializeLangConfig(readLanguageConfiguration(configPath, mapper)) );
|
||||
|
||||
this.setDataTypeMappingProvider(new JavaDataTypeMappingProvider());
|
||||
this.setCodeGenRulesProvider(new JavaCodeGenRulesProvider());
|
||||
this.setNameGenerator(new CamelCaseNamingPolicyProvider());
|
||||
}
|
||||
|
||||
private ApiConfiguration initializeApiConfig() {
|
||||
ApiConfiguration apiConfiguration = new ApiConfiguration();
|
||||
apiConfiguration.setServiceBaseClass("WordAPI","AbstractWordAPI");
|
||||
//default base class for services if not specified for a service
|
||||
apiConfiguration.setServiceBaseClass("WordnikAPI");
|
||||
apiConfiguration.setModelBaseClass("WordnikObject");
|
||||
private JavaCodeGenRulesProvider readRulesProviderConfig(String rulesProviderLocation, ObjectMapper mapper) {
|
||||
JavaCodeGenRulesProvider javaCodeGenRules = null;
|
||||
try {
|
||||
javaCodeGenRules = mapper.readValue(new File(rulesProviderLocation), JavaCodeGenRulesProvider.class);
|
||||
} catch (IOException e) {
|
||||
throw new CodeGenerationException("Java codegen rules configuration could not be read from the location : " + rulesProviderLocation);
|
||||
}
|
||||
|
||||
List<String> defaultModelImports = new ArrayList<String>();
|
||||
defaultModelImports.add("com.wordnik.swagger.common.WordListType");
|
||||
defaultModelImports.add("com.wordnik.swagger.common.StringValue");
|
||||
defaultModelImports.add("com.wordnik.swagger.common.Size");
|
||||
defaultModelImports.add("com.wordnik.swagger.common.WordnikObject");
|
||||
|
||||
List<String> defaultServiceImports = new ArrayList<String>();
|
||||
defaultServiceImports.add("com.wordnik.swagger.model.Long");
|
||||
defaultServiceImports.add("com.wordnik.swagger.common.*");
|
||||
defaultServiceImports.add("com.wordnik.swagger.common.ext.*");
|
||||
|
||||
apiConfiguration.setDefaultModelImports(defaultModelImports);
|
||||
apiConfiguration.setDefaultServiceImports(defaultServiceImports);
|
||||
|
||||
apiConfiguration.setModelPackageName("com.wordnik.swagger.model");
|
||||
apiConfiguration.setApiPackageName("com.wordnik.swagger.api");
|
||||
|
||||
apiConfiguration.setApiKey("myKey");
|
||||
apiConfiguration.setApiUrl("http://swagr.api.wordnik.com/v4/");
|
||||
apiConfiguration.setApiListResource("/list");
|
||||
|
||||
return apiConfiguration;
|
||||
return javaCodeGenRules;
|
||||
}
|
||||
|
||||
private LanguageConfiguration initializeLangConfig(String outputPath) {
|
||||
LanguageConfiguration javaConfiguration = new LanguageConfiguration();
|
||||
private ApiConfiguration readApiConfiguration(String apiConfigLocation, ObjectMapper mapper) {
|
||||
ApiConfiguration configuration = null;
|
||||
try {
|
||||
configuration = mapper.readValue(new File(apiConfigLocation), ApiConfiguration.class);
|
||||
} catch (IOException e) {
|
||||
throw new CodeGenerationException("Api configuration could not be read from the location : " + apiConfigLocation);
|
||||
}
|
||||
|
||||
return configuration;
|
||||
}
|
||||
|
||||
private LanguageConfiguration readLanguageConfiguration(String langConfigLocation, ObjectMapper mapper) {
|
||||
LanguageConfiguration langConfig = null;
|
||||
try {
|
||||
langConfig = mapper.readValue(new File(langConfigLocation), LanguageConfiguration.class);
|
||||
} catch (IOException e) {
|
||||
throw new CodeGenerationException("Language configuration value could not be read from the location : " + langConfigLocation);
|
||||
}
|
||||
|
||||
return langConfig;
|
||||
}
|
||||
|
||||
private LanguageConfiguration initializeLangConfig(LanguageConfiguration javaConfiguration) {
|
||||
javaConfiguration.setClassFileExtension(".java");
|
||||
javaConfiguration.setOutputDirectory(outputPath);
|
||||
javaConfiguration.setTemplateLocation("conf/java/templates");
|
||||
javaConfiguration.setExceptionPackageName("com.wordnik.swagger.exception");
|
||||
javaConfiguration.setAnnotationPackageName("com.wordnik.swagger.annotations");
|
||||
|
Loading…
x
Reference in New Issue
Block a user