use of org.infinispan.protostream.descriptors.EnumDescriptor in project infinispan by infinispan.
the class AbstractSchemaJdbcStore method verifyParametersPresentForMessage.
void verifyParametersPresentForMessage(ImmutableSerializationContext ctx, String fullTypeName, Map<String, Parameter> parameterMap, boolean key) {
GenericDescriptor genericDescriptor;
try {
genericDescriptor = ctx.getDescriptorByName(fullTypeName);
} catch (IllegalArgumentException t) {
throw log.schemaNotFound(fullTypeName);
}
Set<String> seenNames = new HashSet<>();
if (genericDescriptor instanceof Descriptor) {
recursiveUpdateParameters((Descriptor) genericDescriptor, parameterMap, null, seenNames, key);
} else if (genericDescriptor instanceof EnumDescriptor) {
if (!key && config.getSchemaJdbcConfiguration().embeddedKey()) {
throw log.keyCannotEmbedWithEnum(fullTypeName);
}
String name = genericDescriptor.getName();
// treat an enum as just a string
Parameter enumParam = parameterMap.get(name.toUpperCase());
if (enumParam != null) {
assert enumParam.getType() == ProtostreamFieldType.STRING;
updateUnwrap(enumParam, key, json -> json.at("_value"));
enumParam.jsonUpdateConsumer = (json, o) -> {
json.set("_type", fullTypeName);
json.set("_value", o);
};
}
} else {
throw new UnsupportedOperationException("Unsupported descriptor found " + genericDescriptor);
}
}
use of org.infinispan.protostream.descriptors.EnumDescriptor in project protostream by infinispan.
the class ProtoSchemaBuilderTest method testDocumentation.
@Test
public void testDocumentation() throws Exception {
SerializationContext ctx = createContext();
ProtoSchemaBuilder protoSchemaBuilder = new ProtoSchemaBuilder();
String schemaFile = protoSchemaBuilder.fileName("test1.proto").packageName("test_package1").addClass(TestEnum.class).addClass(TestClass.class).build(ctx);
FileDescriptorSource fileDescriptorSource = FileDescriptorSource.fromString("test1.proto", schemaFile);
Map<String, FileDescriptor> fileDescriptors = new SquareProtoParser(ctx.getConfiguration()).parse(fileDescriptorSource);
FileDescriptor fd = fileDescriptors.get("test1.proto");
assertNotNull(fd);
Map<String, EnumDescriptor> enums = new HashMap<>();
for (EnumDescriptor e : fd.getEnumTypes()) {
enums.put(e.getFullName(), e);
}
Map<String, Descriptor> messages = new HashMap<>();
for (Descriptor m : fd.getMessageTypes()) {
messages.put(m.getFullName(), m);
}
EnumDescriptor testEnum = enums.get("test_package1.TestEnumABC");
assertNotNull(testEnum);
assertEquals("bla bla bla\nand some more bla\n@TypeId(100777)", testEnum.getDocumentation());
assertEquals("This should never be read.", testEnum.getValues().get(0).getDocumentation());
Descriptor testClass = messages.get("test_package1.TestClass");
assertNotNull(testClass);
assertEquals("@Indexed()\nbla bla bla\nand some more bla", testClass.getDocumentation());
assertEquals("The surname, of course", testClass.getFields().get(0).getDocumentation());
}
use of org.infinispan.protostream.descriptors.EnumDescriptor in project protostream by infinispan.
the class ProtobufParserTest method testTagHandler.
@Test
public void testTagHandler() throws Exception {
ImmutableSerializationContext ctx = createContext();
User user = new User();
user.setId(1);
user.setName("John");
user.setSurname("Batman");
user.setGender(User.Gender.MALE);
user.setAccountIds(new HashSet<>(Arrays.asList(1, 3)));
user.setAddresses(Arrays.asList(new Address("Old Street", "XYZ42", -12), new Address("Bond Street", "W23", 2)));
byte[] userBytes = ProtobufUtil.toWrappedByteArray(ctx, user);
Descriptor wrapperDescriptor = ctx.getMessageDescriptor(WrappedMessage.PROTOBUF_TYPE_NAME);
TagHandler messageHandler = new TagHandler() {
@Override
public void onStart(GenericDescriptor descriptor) {
log.debugf("\tonStart %s", descriptor);
}
@Override
public void onTag(int fieldNumber, FieldDescriptor fieldDescriptor, Object tagValue) {
log.debugf("\tonTag %d %s %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null, tagValue);
}
@Override
public void onStartNested(int fieldNumber, FieldDescriptor fieldDescriptor) {
log.debugf("\tonStartNested %d %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null);
}
@Override
public void onEndNested(int fieldNumber, FieldDescriptor fieldDescriptor) {
log.debugf("\tonEndNested %d %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null);
}
@Override
public void onEnd() {
log.debug("\tonEnd");
}
};
TagHandler wrapperHandler = new TagHandler() {
private Integer typeId;
private String typeName;
private byte[] wrappedMessage;
private Integer wrappedEnum;
private GenericDescriptor getDescriptor() {
return typeId != null ? ctx.getDescriptorByTypeId(typeId) : ctx.getDescriptorByName(typeName);
}
@Override
public void onStart(GenericDescriptor descriptor) {
log.debugf("onStart %s", descriptor);
}
@Override
public void onTag(int fieldNumber, FieldDescriptor fieldDescriptor, Object tagValue) {
log.debugf("onTag %d %s %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null, tagValue);
if (fieldDescriptor == null) {
// ignore unknown fields
return;
}
switch(fieldNumber) {
case WrappedMessage.WRAPPED_TYPE_ID:
typeId = (Integer) tagValue;
break;
case WrappedMessage.WRAPPED_TYPE_NAME:
typeName = (String) tagValue;
break;
case WrappedMessage.WRAPPED_MESSAGE:
wrappedMessage = (byte[]) tagValue;
break;
case WrappedMessage.WRAPPED_ENUM:
wrappedEnum = (Integer) tagValue;
break;
case WrappedMessage.WRAPPED_DOUBLE:
case WrappedMessage.WRAPPED_FLOAT:
case WrappedMessage.WRAPPED_INT64:
case WrappedMessage.WRAPPED_UINT64:
case WrappedMessage.WRAPPED_INT32:
case WrappedMessage.WRAPPED_FIXED64:
case WrappedMessage.WRAPPED_FIXED32:
case WrappedMessage.WRAPPED_BOOL:
case WrappedMessage.WRAPPED_STRING:
case WrappedMessage.WRAPPED_BYTES:
case WrappedMessage.WRAPPED_UINT32:
case WrappedMessage.WRAPPED_SFIXED32:
case WrappedMessage.WRAPPED_SFIXED64:
case WrappedMessage.WRAPPED_SINT32:
case WrappedMessage.WRAPPED_SINT64:
messageHandler.onStart(null);
messageHandler.onTag(fieldNumber, fieldDescriptor, tagValue);
messageHandler.onEnd();
break;
}
}
@Override
public void onStartNested(int fieldNumber, FieldDescriptor fieldDescriptor) {
log.debugf("onStartNested %d %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null);
}
@Override
public void onEndNested(int fieldNumber, FieldDescriptor fieldDescriptor) {
log.debugf("onEndNested %d %s", fieldNumber, fieldDescriptor != null ? fieldDescriptor.getFullName() : null);
}
@Override
public void onEnd() {
if (wrappedEnum != null) {
EnumDescriptor enumDescriptor = (EnumDescriptor) getDescriptor();
String enumConstantName = enumDescriptor.findValueByNumber(wrappedEnum).getName();
FieldDescriptor fd = wrapperDescriptor.findFieldByNumber(WrappedMessage.WRAPPED_ENUM);
messageHandler.onStart(enumDescriptor);
messageHandler.onTag(WrappedMessage.WRAPPED_ENUM, fd, enumConstantName);
messageHandler.onEnd();
} else if (wrappedMessage != null) {
try {
Descriptor messageDescriptor = (Descriptor) getDescriptor();
ProtobufParser.INSTANCE.parse(messageHandler, messageDescriptor, wrappedMessage);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
log.debug("onEnd");
}
};
ProtobufParser.INSTANCE.parse(wrapperHandler, wrapperDescriptor, userBytes);
}
use of org.infinispan.protostream.descriptors.EnumDescriptor in project kogito-runtimes by kiegroup.
the class AbstractMarshallerGenerator method generate.
public List<CompilationUnit> generate(FileDescriptorSource proto) throws IOException {
List<CompilationUnit> units = new ArrayList<>();
TemplatedGenerator generator = TemplatedGenerator.builder().withFallbackContext(JavaKogitoBuildContext.CONTEXT_NAME).withTemplateBasePath(TEMPLATE_PERSISTENCE_FOLDER).build(context, "MessageMarshaller");
Predicate<String> typeExclusions = ExclusionTypeUtils.createTypeExclusions();
// filter types that don't require to create a marshaller
Predicate<Descriptor> packagePredicate = (msg) -> !msg.getFileDescriptor().getPackage().equals("kogito");
Predicate<Descriptor> jacksonPredicate = (msg) -> !typeExclusions.test(packageFromOption(msg.getFileDescriptor(), msg) + "." + msg.getName());
Predicate<Descriptor> predicate = packagePredicate.and(jacksonPredicate);
CompilationUnit parsedClazzFile = generator.compilationUnitOrThrow();
SerializationContext serializationContext = new SerializationContextImpl(Configuration.builder().build());
FileDescriptorSource kogitoTypesDescriptor = new FileDescriptorSource().addProtoFile("kogito-types.proto", context.getClassLoader().getResourceAsStream("META-INF/kogito-types.proto"));
serializationContext.registerProtoFiles(kogitoTypesDescriptor);
serializationContext.registerProtoFiles(proto);
Map<String, FileDescriptor> descriptors = serializationContext.getFileDescriptors();
for (Entry<String, FileDescriptor> entry : descriptors.entrySet()) {
FileDescriptor d = entry.getValue();
List<Descriptor> messages = d.getMessageTypes().stream().filter(predicate).collect(Collectors.toList());
for (Descriptor msg : messages) {
CompilationUnit clazzFile = parsedClazzFile.clone();
units.add(clazzFile);
String javaType = packageFromOption(d, msg) + "." + msg.getName();
clazzFile.setPackageDeclaration(d.getPackage());
ClassOrInterfaceDeclaration clazz = clazzFile.findFirst(ClassOrInterfaceDeclaration.class, sl -> true).orElseThrow(() -> new InvalidTemplateException(generator, "No class found"));
clazz.setName(msg.getName() + "MessageMarshaller");
clazz.getImplementedTypes(0).setTypeArguments(NodeList.nodeList(new ClassOrInterfaceType(null, javaType)));
MethodDeclaration getJavaClassMethod = clazz.findFirst(MethodDeclaration.class, md -> md.getNameAsString().equals("getJavaClass")).orElseThrow(() -> new InvalidTemplateException(generator, "No getJavaClass method found"));
getJavaClassMethod.setType(new ClassOrInterfaceType(null, new SimpleName(Class.class.getName()), NodeList.nodeList(new ClassOrInterfaceType(null, javaType))));
BlockStmt getJavaClassMethodBody = new BlockStmt();
getJavaClassMethodBody.addStatement(new ReturnStmt(new NameExpr(javaType + ".class")));
getJavaClassMethod.setBody(getJavaClassMethodBody);
MethodDeclaration getTypeNameMethod = clazz.findFirst(MethodDeclaration.class, md -> md.getNameAsString().equals("getTypeName")).orElseThrow(() -> new InvalidTemplateException(generator, "No getTypeName method found"));
BlockStmt getTypeNameMethodBody = new BlockStmt();
getTypeNameMethodBody.addStatement(new ReturnStmt(new StringLiteralExpr(msg.getFullName())));
getTypeNameMethod.setBody(getTypeNameMethodBody);
MethodDeclaration readFromMethod = clazz.findFirst(MethodDeclaration.class, md -> md.getNameAsString().equals("readFrom")).orElseThrow(() -> new InvalidTemplateException(generator, "No readFrom method found"));
readFromMethod.setType(javaType);
readFromMethod.setBody(new BlockStmt());
MethodDeclaration writeToMethod = clazz.findFirst(MethodDeclaration.class, md -> md.getNameAsString().equals("writeTo")).orElseThrow(() -> new InvalidTemplateException(generator, "No writeTo method found"));
writeToMethod.getParameter(1).setType(javaType);
writeToMethod.setBody(new BlockStmt());
ClassOrInterfaceType classType = new ClassOrInterfaceType(null, javaType);
// read method
VariableDeclarationExpr instance = new VariableDeclarationExpr(new VariableDeclarator(classType, "value", new ObjectCreationExpr(null, classType, NodeList.nodeList())));
readFromMethod.getBody().ifPresent(b -> b.addStatement(instance));
for (FieldDescriptor field : msg.getFields()) {
String protoStreamMethodType = protoStreamMethodType(field.getTypeName());
Expression write = null;
Expression read = null;
if (protoStreamMethodType != null && !field.isRepeated()) {
// has a mapped type
read = new MethodCallExpr(new NameExpr("reader"), "read" + protoStreamMethodType).addArgument(new StringLiteralExpr(field.getName()));
String accessor = protoStreamMethodType.equals("Boolean") ? "is" : "get";
write = new MethodCallExpr(new NameExpr("writer"), "write" + protoStreamMethodType).addArgument(new StringLiteralExpr(field.getName())).addArgument(new MethodCallExpr(new NameExpr("t"), accessor + StringUtils.ucFirst(field.getName())));
} else {
// custom types
String customTypeName = javaTypeForMessage(d, field.getTypeName(), serializationContext);
if (field.isRepeated()) {
if (null == customTypeName || customTypeName.isEmpty()) {
customTypeName = primaryTypeClassName(field.getTypeName());
}
String writeMethod;
if (isArray(javaType, field)) {
writeMethod = "writeArray";
read = new MethodCallExpr(new NameExpr("reader"), "readArray").addArgument(new StringLiteralExpr(field.getName())).addArgument(new NameExpr(customTypeName + ".class"));
} else {
writeMethod = "writeCollection";
read = new MethodCallExpr(new NameExpr("reader"), "readCollection").addArgument(new StringLiteralExpr(field.getName())).addArgument(new ObjectCreationExpr(null, new ClassOrInterfaceType(null, ArrayList.class.getCanonicalName()), NodeList.nodeList())).addArgument(new NameExpr(customTypeName + ".class"));
}
write = new MethodCallExpr(new NameExpr("writer"), writeMethod).addArgument(new StringLiteralExpr(field.getName())).addArgument(new MethodCallExpr(new NameExpr("t"), "get" + StringUtils.ucFirst(field.getName()))).addArgument(new NameExpr(customTypeName + ".class"));
} else {
read = new MethodCallExpr(new NameExpr("reader"), "readObject").addArgument(new StringLiteralExpr(field.getName())).addArgument(new NameExpr(customTypeName + ".class"));
write = new MethodCallExpr(new NameExpr("writer"), "writeObject").addArgument(new StringLiteralExpr(field.getName())).addArgument(new MethodCallExpr(new NameExpr("t"), "get" + StringUtils.ucFirst(field.getName()))).addArgument(new NameExpr(customTypeName + ".class"));
}
if (customTypeName.equals(Serializable.class.getName())) {
String fieldClazz = (String) field.getOptionByName(KOGITO_JAVA_CLASS_OPTION);
if (fieldClazz == null) {
throw new IllegalArgumentException(format("Serializable proto field '%s' is missing value for option %s", field.getName(), KOGITO_JAVA_CLASS_OPTION));
} else {
read = new CastExpr().setExpression(new EnclosedExpr(read)).setType(fieldClazz);
}
}
}
MethodCallExpr setter = new MethodCallExpr(new NameExpr("value"), "set" + StringUtils.ucFirst(field.getName())).addArgument(read);
readFromMethod.getBody().ifPresent(b -> b.addStatement(setter));
// write method
writeToMethod.getBody().orElseThrow(() -> new NoSuchElementException("A method declaration doesn't contain a body!")).addStatement(write);
}
readFromMethod.getBody().ifPresent(b -> b.addStatement(new ReturnStmt(new NameExpr("value"))));
clazz.getMembers().sort(new BodyDeclarationComparator());
}
for (EnumDescriptor msg : d.getEnumTypes()) {
CompilationUnit compilationUnit = new CompilationUnit();
units.add(compilationUnit);
String javaType = packageFromOption(d, msg) + "." + msg.getName();
ClassOrInterfaceDeclaration classDeclaration = compilationUnit.setPackageDeclaration(d.getPackage()).addClass(msg.getName() + "EnumMarshaller").setPublic(true);
classDeclaration.addImplementedType(EnumMarshaller.class).getImplementedTypes(0).setTypeArguments(NodeList.nodeList(new ClassOrInterfaceType(null, javaType)));
classDeclaration.addMethod("getTypeName", PUBLIC).setType(String.class).setBody(new BlockStmt().addStatement(new ReturnStmt(new StringLiteralExpr(msg.getFullName()))));
classDeclaration.addMethod("getJavaClass", PUBLIC).setType(new ClassOrInterfaceType(null, new SimpleName(Class.class.getName()), NodeList.nodeList(new ClassOrInterfaceType(null, javaType)))).setBody(new BlockStmt().addStatement(new ReturnStmt(new ClassExpr(new ClassOrInterfaceType(null, javaType)))));
BlockStmt encodeBlock = new BlockStmt().addStatement(new IfStmt(new BinaryExpr(new NullLiteralExpr(), new NameExpr(STATE_PARAM), EQUALS), new ThrowStmt(new ObjectCreationExpr(null, new ClassOrInterfaceType(null, IllegalArgumentException.class.getName()), NodeList.nodeList(new StringLiteralExpr("Invalid value provided to enum")))), null)).addStatement(new ReturnStmt(new MethodCallExpr(new NameExpr(STATE_PARAM), "ordinal")));
classDeclaration.addMethod("encode", PUBLIC).setType("int").addParameter(javaType, STATE_PARAM).setBody(encodeBlock);
MethodDeclaration decode = classDeclaration.addMethod("decode", PUBLIC).setType(javaType).addParameter("int", "value");
SwitchStmt decodeSwitch = new SwitchStmt().setSelector(new NameExpr("value"));
msg.getValues().forEach(v -> {
SwitchEntry dEntry = new SwitchEntry();
dEntry.getLabels().add(new IntegerLiteralExpr(v.getNumber()));
dEntry.addStatement(new ReturnStmt(new NameExpr(javaType + "." + v.getName())));
decodeSwitch.getEntries().add(dEntry);
});
decodeSwitch.getEntries().add(new SwitchEntry().addStatement(new ThrowStmt(new ObjectCreationExpr(null, new ClassOrInterfaceType(null, IllegalArgumentException.class.getName()), NodeList.nodeList(new StringLiteralExpr("Invalid value provided to enum"))))));
decode.setBody(new BlockStmt().addStatement(decodeSwitch));
}
}
return units;
}
use of org.infinispan.protostream.descriptors.EnumDescriptor in project protostream by infinispan.
the class SerializationContextImpl method unregisterFileDescriptorTypes.
@GuardedBy("descriptorLock")
private void unregisterFileDescriptorTypes(FileDescriptor fileDescriptor) {
if (fileDescriptor.isResolved()) {
for (GenericDescriptor d : fileDescriptor.getTypes().values()) {
Integer typeId = d.getTypeId();
if (typeId != null) {
typeIds.remove(typeId);
}
if (d instanceof EnumDescriptor) {
for (EnumValueDescriptor ev : ((EnumDescriptor) d).getValues()) {
enumValueDescriptors.remove(ev.getScopedName());
}
}
}
genericDescriptors.keySet().removeAll(fileDescriptor.getTypes().keySet());
fileDescriptor.markUnresolved();
}
for (FileDescriptor fd : fileDescriptor.getDependants().values()) {
unregisterFileDescriptorTypes(fd);
}
}
Aggregations