キーストリングをオブジェクトの配列でマッピングしようとします。
シンプルなオブジェクトを作成できますが、これらの配列のオブジェクトを簡単に追加します。地図オブジェクトはこれを行うのに最適です。
問題:GraphQLのタイプマップを定義する方法はわかりません。
@ObjectType()
export class Inventaire
@Field()
_id: string;
@Field()
stocks: Map<string, Article[]>;
}
_
このパッケージを使用できます https://www.npmjs.com/package/graphql-type-json 。
例:
import { makeExecutableSchema } from 'graphql-tools';
import GraphQLJSON, { GraphQLJSONObject } from 'graphql-type-json';
const typeDefs = `
scalar JSON
scalar JSONObject
type MyType {
myValue: JSON
myObject: JSONObject
}
# ...
`;
const resolvers = {
JSON: GraphQLJSON,
JSONObject: GraphQLJSONObject,
};
export default makeExecutableSchema({ typeDefs, resolvers });
_
GraphQLはネイティブにマップタイプをサポートしていません。マップに独自のスカラを作成するか、repo https://github.com/graphql-java/graphql-java-拡張子 - スカラ
import graphql.Assert;
import graphql.language.ArrayValue;
import graphql.language.BooleanValue;
import graphql.language.EnumValue;
import graphql.language.FloatValue;
import graphql.language.IntValue;
import graphql.language.NullValue;
import graphql.language.ObjectValue;
import graphql.language.StringValue;
import graphql.language.Value;
import graphql.language.VariableReference;
import graphql.language.ObjectField;
import graphql.scalars.util.Kit;
import graphql.schema.Coercing;
import graphql.schema.CoercingParseLiteralException;
import graphql.schema.CoercingParseValueException;
import graphql.schema.CoercingSerializeException;
import graphql.schema.GraphQLScalarType;
import org.springframework.stereotype.Component;
import Java.util.Collections;
import Java.util.LinkedHashMap;
import Java.util.List;
import Java.util.Map;
import Java.util.stream.Collectors;
@Component
public class ObjectScalar extends GraphQLScalarType {
public ObjectScalar() {
this("Object", "An object scalar");
}
ObjectScalar(String name, String description) {
super(name, description, new Coercing<Object, Object>() {
public Object serialize(Object input) throws CoercingSerializeException {
return input;
}
public Object parseValue(Object input) throws CoercingParseValueException {
return input;
}
public Object parseLiteral(Object input) throws CoercingParseLiteralException {
return this.parseLiteral(input, Collections.emptyMap());
}
public Object parseLiteral(Object input, Map<String, Object> variables)
throws CoercingParseLiteralException {
if (!(input instanceof Value)) {
throw new CoercingParseLiteralException("Expected AST type 'StringValue' but" +
" was '" + Kit.typeName(input) + "'.");
} else if (input instanceof NullValue) {
return null;
} else if (input instanceof FloatValue) {
return ((FloatValue)input).getValue();
} else if (input instanceof StringValue) {
return ((StringValue)input).getValue();
} else if (input instanceof IntValue) {
return ((IntValue)input).getValue();
} else if (input instanceof BooleanValue) {
return ((BooleanValue)input).isValue();
} else if (input instanceof EnumValue) {
return ((EnumValue)input).getName();
} else if (input instanceof VariableReference) {
String varName = ((VariableReference)input).getName();
return variables.get(varName);
} else {
List values;
if (input instanceof ArrayValue) {
values = ((ArrayValue)input).getValues();
return values.stream().map((v) -> {
return this.parseLiteral(v, variables);
}).collect(Collectors.toList());
} else if (input instanceof ObjectValue) {
values = ((ObjectValue)input).getObjectFields();
Map<String, Object> parsedValues = new LinkedHashMap();
values.forEach((fld) -> {
Object parsedValue = this.parseLiteral(((ObjectField)fld).getValue(),
variables);
parsedValues.put(((ObjectField)fld).getName(), parsedValue);
});
return parsedValues;
} else {
return Assert.assertShouldNeverHappen("We have covered all Value types",
new Object[0]);
}
}
}
});
}
}
_
scalar Object
type Result {
value : Object
}
_