Client generator now working
This commit is contained in:
parent
360db1d296
commit
45c968532d
|
@ -57,8 +57,12 @@ public abstract class BaseRuntimeDeclaredChildDefinition extends BaseRuntimeChil
|
||||||
Class<?> declaringClass = myField.getDeclaringClass();
|
Class<?> declaringClass = myField.getDeclaringClass();
|
||||||
final Class<?> targetReturnType = myField.getType();
|
final Class<?> targetReturnType = myField.getType();
|
||||||
try {
|
try {
|
||||||
final Method accessor = BeanUtils.findAccessor(declaringClass, targetReturnType, myElementName);
|
String elementName = myElementName;
|
||||||
final Method mutator = BeanUtils.findMutator(declaringClass, targetReturnType, myElementName);
|
if ("Class".equals(elementName)) {
|
||||||
|
elementName = "ClassElement"; // because getClass() is reserved
|
||||||
|
}
|
||||||
|
final Method accessor = BeanUtils.findAccessor(declaringClass, targetReturnType, elementName);
|
||||||
|
final Method mutator = BeanUtils.findMutator(declaringClass, targetReturnType, elementName);
|
||||||
|
|
||||||
if (List.class.isAssignableFrom(targetReturnType)) {
|
if (List.class.isAssignableFrom(targetReturnType)) {
|
||||||
myAccessor = new ListAccessor(accessor);
|
myAccessor = new ListAccessor(accessor);
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
package ca.uhn.fhir.model.api;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.model.api.annotation.ResourceDef;
|
||||||
|
|
||||||
|
@ResourceDef(name="Binary", profile="http://hl7.org/fhir/profiles/Binary", id="binary")
|
||||||
|
public class Binary implements IResource {
|
||||||
|
|
||||||
|
// TODO: implement binary
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -6,6 +6,9 @@ public class UndeclaredExtension extends BaseElement {
|
||||||
private IElement myValue;
|
private IElement myValue;
|
||||||
private boolean myIsModifier;
|
private boolean myIsModifier;
|
||||||
|
|
||||||
|
public UndeclaredExtension() {
|
||||||
|
}
|
||||||
|
|
||||||
public UndeclaredExtension(boolean theIsModifier) {
|
public UndeclaredExtension(boolean theIsModifier) {
|
||||||
myIsModifier = theIsModifier;
|
myIsModifier = theIsModifier;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
package ca.uhn.fhir.model.dstu.composite;
|
||||||
|
|
||||||
|
public class AgeDt extends QuantityDt {
|
||||||
|
|
||||||
|
// TODO: implement restricions
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
package ca.uhn.fhir.model.primitive;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.model.api.BasePrimitive;
|
||||||
|
import ca.uhn.fhir.model.api.IElement;
|
||||||
|
import ca.uhn.fhir.parser.DataFormatException;
|
||||||
|
|
||||||
|
public class IdrefDt extends BasePrimitive<String> {
|
||||||
|
|
||||||
|
private IElement myTarget;
|
||||||
|
private String myValue;
|
||||||
|
|
||||||
|
public IElement getTarget() {
|
||||||
|
return myTarget;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getValue() {
|
||||||
|
return myValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getValueAsString() throws DataFormatException {
|
||||||
|
return myValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTarget(IElement theTarget) {
|
||||||
|
myTarget = theTarget;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setValue(String theValue) throws DataFormatException {
|
||||||
|
myValue = theValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setValueAsString(String theValue) throws DataFormatException {
|
||||||
|
myValue = theValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,7 @@
|
||||||
|
package ca.uhn.fhir.model.primitive;
|
||||||
|
|
||||||
|
public class OidDt extends UriDt {
|
||||||
|
|
||||||
|
// TODO: implement restrictions
|
||||||
|
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<classpath>
|
<classpath>
|
||||||
<classpathentry excluding="**/*.java" kind="src" output="target/test-classes" path="src/test/resources"/>
|
<classpathentry excluding="**/*.java" kind="src" path="src/test/resources"/>
|
||||||
<classpathentry kind="src" path="target/gen"/>
|
<classpathentry kind="src" path="target/gen"/>
|
||||||
<classpathentry including="**/*.java" kind="src" path="src/main/java"/>
|
<classpathentry including="**/*.java" kind="src" path="src/main/java"/>
|
||||||
<classpathentry excluding="**/*.java" kind="src" path="src/main/resources"/>
|
<classpathentry excluding="**/*.java" kind="src" path="src/main/resources"/>
|
||||||
|
|
|
@ -10,7 +10,9 @@ import java.io.InputStreamReader;
|
||||||
import java.lang.annotation.Annotation;
|
import java.lang.annotation.Annotation;
|
||||||
import java.lang.reflect.Constructor;
|
import java.lang.reflect.Constructor;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.TreeSet;
|
import java.util.TreeSet;
|
||||||
|
|
||||||
import org.apache.commons.lang3.ObjectUtils;
|
import org.apache.commons.lang3.ObjectUtils;
|
||||||
|
@ -27,6 +29,7 @@ import ca.uhn.fhir.tinder.model.BaseElement;
|
||||||
import ca.uhn.fhir.tinder.model.Child;
|
import ca.uhn.fhir.tinder.model.Child;
|
||||||
import ca.uhn.fhir.tinder.model.Extension;
|
import ca.uhn.fhir.tinder.model.Extension;
|
||||||
import ca.uhn.fhir.tinder.model.Resource;
|
import ca.uhn.fhir.tinder.model.Resource;
|
||||||
|
import ca.uhn.fhir.tinder.model.ResourceBlock;
|
||||||
import ca.uhn.fhir.tinder.model.SimpleSetter.Parameter;
|
import ca.uhn.fhir.tinder.model.SimpleSetter.Parameter;
|
||||||
|
|
||||||
public abstract class BaseStructureParser {
|
public abstract class BaseStructureParser {
|
||||||
|
@ -128,6 +131,8 @@ public abstract class BaseStructureParser {
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Resource next : myResources) {
|
for (Resource next : myResources) {
|
||||||
|
scanForTypeNameConflicts(next);
|
||||||
|
|
||||||
File f = new File(theOutputDirectory, next.getName() + getFilenameSuffix() + ".java");
|
File f = new File(theOutputDirectory, next.getName() + getFilenameSuffix() + ".java");
|
||||||
try {
|
try {
|
||||||
write(next, f, thePackageBase);
|
write(next, f, thePackageBase);
|
||||||
|
@ -137,6 +142,30 @@ public abstract class BaseStructureParser {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void scanForTypeNameConflicts(Resource theNext) {
|
||||||
|
Set<String> typeNames = new HashSet<String>();
|
||||||
|
typeNames.add(theNext.getName());
|
||||||
|
scanForTypeNameConflicts(theNext,typeNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void scanForTypeNameConflicts(BaseElement theResourceBlock, Set<String> theTypeNames) {
|
||||||
|
for (BaseElement nextChild : theResourceBlock.getChildren()){
|
||||||
|
if (nextChild instanceof ResourceBlock) {
|
||||||
|
ResourceBlock resourceBlock = (ResourceBlock) nextChild;
|
||||||
|
String className = resourceBlock.getClassName();
|
||||||
|
String newClassName = className;
|
||||||
|
int index = 2;
|
||||||
|
while (theTypeNames.contains(newClassName)) {
|
||||||
|
newClassName = className + (index++);
|
||||||
|
resourceBlock.setForcedClassName(newClassName);
|
||||||
|
}
|
||||||
|
theTypeNames.add(newClassName);
|
||||||
|
|
||||||
|
scanForTypeNameConflicts(resourceBlock, theTypeNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected abstract String getFilenameSuffix();
|
protected abstract String getFilenameSuffix();
|
||||||
|
|
||||||
private void write(Resource theResource, File theFile, String thePackageBase) throws IOException {
|
private void write(Resource theResource, File theFile, String thePackageBase) throws IOException {
|
||||||
|
|
|
@ -30,12 +30,14 @@ import ca.uhn.fhir.model.dstu.resource.Profile.StructureSearchParam;
|
||||||
import ca.uhn.fhir.model.dstu.valueset.DataTypeEnum;
|
import ca.uhn.fhir.model.dstu.valueset.DataTypeEnum;
|
||||||
import ca.uhn.fhir.parser.DataFormatException;
|
import ca.uhn.fhir.parser.DataFormatException;
|
||||||
import ca.uhn.fhir.parser.XmlParser;
|
import ca.uhn.fhir.parser.XmlParser;
|
||||||
|
import ca.uhn.fhir.tinder.model.AnyChild;
|
||||||
import ca.uhn.fhir.tinder.model.BaseElement;
|
import ca.uhn.fhir.tinder.model.BaseElement;
|
||||||
import ca.uhn.fhir.tinder.model.Child;
|
import ca.uhn.fhir.tinder.model.Child;
|
||||||
import ca.uhn.fhir.tinder.model.Resource;
|
import ca.uhn.fhir.tinder.model.Resource;
|
||||||
import ca.uhn.fhir.tinder.model.ResourceBlock;
|
import ca.uhn.fhir.tinder.model.ResourceBlock;
|
||||||
import ca.uhn.fhir.tinder.model.SearchParameter;
|
import ca.uhn.fhir.tinder.model.SearchParameter;
|
||||||
import ca.uhn.fhir.tinder.model.Slicing;
|
import ca.uhn.fhir.tinder.model.Slicing;
|
||||||
|
import ca.uhn.fhir.tinder.model.UndeclaredExtensionChild;
|
||||||
|
|
||||||
public class ProfileParser extends BaseStructureParser {
|
public class ProfileParser extends BaseStructureParser {
|
||||||
|
|
||||||
|
@ -46,7 +48,8 @@ public class ProfileParser extends BaseStructureParser {
|
||||||
// FhirContext fhirContext = new FhirContext(Profile.class);
|
// FhirContext fhirContext = new FhirContext(Profile.class);
|
||||||
// XmlParser parser = fhirContext.newXmlParser();
|
// XmlParser parser = fhirContext.newXmlParser();
|
||||||
//
|
//
|
||||||
// String file = IOUtils.toString(new FileReader("src/test/resources/prof/organization.xml"));
|
// String file = IOUtils.toString(new
|
||||||
|
// FileReader("src/test/resources/prof/organization.xml"));
|
||||||
// Profile text = (Profile) parser.parseResource(file);
|
// Profile text = (Profile) parser.parseResource(file);
|
||||||
//
|
//
|
||||||
// ValueSetGenerator vsp = new ValueSetGenerator();
|
// ValueSetGenerator vsp = new ValueSetGenerator();
|
||||||
|
@ -54,7 +57,8 @@ public class ProfileParser extends BaseStructureParser {
|
||||||
// vsp.parse();
|
// vsp.parse();
|
||||||
//
|
//
|
||||||
// ProfileParser p = new ProfileParser();
|
// ProfileParser p = new ProfileParser();
|
||||||
// p.parseSingleProfile(text, "http://fhir.connectinggta.ca/static/Profile/organization.xml");
|
// p.parseSingleProfile(text,
|
||||||
|
// "http://fhir.connectinggta.ca/static/Profile/organization.xml");
|
||||||
// p.bindValueSets(vsp);
|
// p.bindValueSets(vsp);
|
||||||
// p.writeAll("target/generated/valuesets/ca/uhn/fhir/model/dstu/resource");
|
// p.writeAll("target/generated/valuesets/ca/uhn/fhir/model/dstu/resource");
|
||||||
//
|
//
|
||||||
|
@ -92,8 +96,10 @@ public class ProfileParser extends BaseStructureParser {
|
||||||
elem = new ResourceBlock();
|
elem = new ResourceBlock();
|
||||||
// } else if (type.startsWith("@")) {
|
// } else if (type.startsWith("@")) {
|
||||||
// elem = new ResourceBlockCopy();
|
// elem = new ResourceBlockCopy();
|
||||||
// } else if (type.equals("*")) {
|
} else if (next.getDefinition().getType().get(0).getCode().getValue().equals("*")) {
|
||||||
// elem = new AnyChild();
|
elem = new AnyChild();
|
||||||
|
} else if (next.getDefinition().getType().get(0).getCode().getValue().equals("Extension")) {
|
||||||
|
elem = new UndeclaredExtensionChild();
|
||||||
} else {
|
} else {
|
||||||
elem = new Child();
|
elem = new Child();
|
||||||
}
|
}
|
||||||
|
@ -125,7 +131,9 @@ public class ProfileParser extends BaseStructureParser {
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Profiles come with a number of standard elements which are generally ignored because they are boilerplate, unless the definition is somehow changing their behaviour (e.g. through
|
* Profiles come with a number of standard elements which are
|
||||||
|
* generally ignored because they are boilerplate, unless the
|
||||||
|
* definition is somehow changing their behaviour (e.g. through
|
||||||
* slices)
|
* slices)
|
||||||
*/
|
*/
|
||||||
if (next.getPath().getValue().endsWith(".contained")) {
|
if (next.getPath().getValue().endsWith(".contained")) {
|
||||||
|
@ -258,18 +266,22 @@ public class ProfileParser extends BaseStructureParser {
|
||||||
}
|
}
|
||||||
|
|
||||||
// for (int i = 0; i < theBaseResourceNames.size(); i++) {
|
// for (int i = 0; i < theBaseResourceNames.size(); i++) {
|
||||||
// theBaseResourceNames.set(i, theBaseResourceNames.get(i).toLowerCase());
|
// theBaseResourceNames.set(i,
|
||||||
|
// theBaseResourceNames.get(i).toLowerCase());
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// try {
|
// try {
|
||||||
//
|
//
|
||||||
// Bundle bundle = fhirContext.newXmlParser().parseBundle(IOUtils.toString(getClass().getResourceAsStream("/prof/allprofiles.xml")));
|
// Bundle bundle =
|
||||||
|
// fhirContext.newXmlParser().parseBundle(IOUtils.toString(getClass().getResourceAsStream("/prof/allprofiles.xml")));
|
||||||
// TreeSet<String> allProfiles = new TreeSet<String>();
|
// TreeSet<String> allProfiles = new TreeSet<String>();
|
||||||
// for (BundleEntry nextResource : bundle.getEntries() ) {
|
// for (BundleEntry nextResource : bundle.getEntries() ) {
|
||||||
// Profile nextProfile = (Profile) nextResource.getResource();
|
// Profile nextProfile = (Profile) nextResource.getResource();
|
||||||
// allProfiles.add(nextProfile.getName().getValue());
|
// allProfiles.add(nextProfile.getName().getValue());
|
||||||
// if (theBaseResourceNames.contains(nextProfile.getName().getValue().toLowerCase())){
|
// if
|
||||||
// parseSingleProfile(nextProfile, bundle.getLinkBase().getValueNotNull());
|
// (theBaseResourceNames.contains(nextProfile.getName().getValue().toLowerCase())){
|
||||||
|
// parseSingleProfile(nextProfile,
|
||||||
|
// bundle.getLinkBase().getValueNotNull());
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
|
|
|
@ -4,6 +4,7 @@ import static org.apache.commons.lang.StringUtils.defaultString;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileReader;
|
||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
@ -62,6 +63,21 @@ public class TinderClientMojo extends AbstractMojo {
|
||||||
public void execute() throws MojoExecutionException, MojoFailureException {
|
public void execute() throws MojoExecutionException, MojoFailureException {
|
||||||
determinePaths();
|
determinePaths();
|
||||||
|
|
||||||
|
//
|
||||||
|
// try {
|
||||||
|
// ProfileParser pp = new ProfileParser();
|
||||||
|
// Profile prof=(Profile) new FhirContext(Profile.class).newXmlParser().parseResource(IOUtils.toString(new FileReader("src/test/resources/profile.xml")));
|
||||||
|
// pp.parseSingleProfile(prof, "http://foo");
|
||||||
|
// File resourceDir = new File(myDirectoryBase, "resource");
|
||||||
|
// resourceDir.mkdirs();
|
||||||
|
// pp.writeAll(resourceDir, myPackageBase);
|
||||||
|
// } catch (Exception e) {
|
||||||
|
// throw new MojoFailureException("Failed to load resource profile: ",e);
|
||||||
|
// }
|
||||||
|
// if (true) {
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
FhirContext ctx = new FhirContext(Conformance.class);
|
FhirContext ctx = new FhirContext(Conformance.class);
|
||||||
IRestfulClientFactory cFact = ctx.newRestfulClientFactory();
|
IRestfulClientFactory cFact = ctx.newRestfulClientFactory();
|
||||||
IBasicClient client = cFact.newClient(IBasicClient.class, "http://fhir.healthintersections.com.au/open");
|
IBasicClient client = cFact.newClient(IBasicClient.class, "http://fhir.healthintersections.com.au/open");
|
||||||
|
|
|
@ -2,6 +2,16 @@ package ca.uhn.fhir.tinder.model;
|
||||||
|
|
||||||
public class AnyChild extends Child {
|
public class AnyChild extends Child {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getReferenceType() {
|
||||||
|
return "IDatatype";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getAnnotationType() {
|
||||||
|
return getReferenceType();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTypeSuffix() {
|
public String getTypeSuffix() {
|
||||||
return "";
|
return "";
|
||||||
|
|
|
@ -42,6 +42,9 @@ public class Child extends BaseElement {
|
||||||
public String getMethodName() {
|
public String getMethodName() {
|
||||||
String elementName = getElementNameSimplified();
|
String elementName = getElementNameSimplified();
|
||||||
elementName = elementName.substring(0, 1).toUpperCase() + elementName.substring(1);
|
elementName = elementName.substring(0, 1).toUpperCase() + elementName.substring(1);
|
||||||
|
if ("Class".equals(elementName)) {
|
||||||
|
elementName = "ClassElement";
|
||||||
|
}
|
||||||
return elementName;
|
return elementName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,6 +98,9 @@ public class Child extends BaseElement {
|
||||||
public List<String> getReferenceTypesForMultiple() {
|
public List<String> getReferenceTypesForMultiple() {
|
||||||
ArrayList<String> retVal = new ArrayList<String>();
|
ArrayList<String> retVal = new ArrayList<String>();
|
||||||
for (String next : getType()) {
|
for (String next : getType()) {
|
||||||
|
if ("Any".equals(next)) {
|
||||||
|
next = "IResource";
|
||||||
|
}
|
||||||
retVal.add(next);
|
retVal.add(next);
|
||||||
// retVal.add(next + getTypeSuffix());
|
// retVal.add(next + getTypeSuffix());
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,12 +4,18 @@ import java.util.List;
|
||||||
|
|
||||||
public class ResourceBlock extends Child {
|
public class ResourceBlock extends Child {
|
||||||
|
|
||||||
|
private String myForcedClassName;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<BaseElement> getChildren() {
|
public List<BaseElement> getChildren() {
|
||||||
return super.getChildren();
|
return super.getChildren();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getClassName() {
|
public String getClassName() {
|
||||||
|
if (myForcedClassName != null) {
|
||||||
|
return myForcedClassName;
|
||||||
|
}
|
||||||
|
|
||||||
// return getElementName().substring(0, 1).toUpperCase() + getElementName().substring(1);
|
// return getElementName().substring(0, 1).toUpperCase() + getElementName().substring(1);
|
||||||
String name = getName();
|
String name = getName();
|
||||||
return convertFhirPathNameToClassName(name);
|
return convertFhirPathNameToClassName(name);
|
||||||
|
@ -44,4 +50,8 @@ public class ResourceBlock extends Child {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setForcedClassName(String theClassName) {
|
||||||
|
myForcedClassName =theClassName;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
package ca.uhn.fhir.tinder.model;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.model.api.UndeclaredExtension;
|
||||||
|
|
||||||
|
public class UndeclaredExtensionChild extends Child {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getReferenceType() {
|
||||||
|
if (isRepeatable()) {
|
||||||
|
return ArrayList.class.getCanonicalName() + "<" + UndeclaredExtension.class.getSimpleName()+">";
|
||||||
|
}
|
||||||
|
return UndeclaredExtension.class.getSimpleName();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getAnnotationType() {
|
||||||
|
return UndeclaredExtension.class.getSimpleName();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getSingleType() {
|
||||||
|
return UndeclaredExtension.class.getSimpleName();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTypeSuffix() {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isSingleChildInstantiable() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue