graphql-shield
Version:
GraphQL Server permissions as another layer of abstraction!
79 lines (78 loc) • 3.78 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.getResolversFromSchema = void 0;
const graphql_1 = require("graphql");
function getResolversFromSchema(schema,
// Include default merged resolvers
includeDefaultMergedResolver, includeDefaultFieldResolver = false) {
var _a, _b, _c;
const resolvers = Object.create(null);
const typeMap = schema.getTypeMap();
for (const typeName in typeMap) {
if (!typeName.startsWith('__')) {
const type = typeMap[typeName];
if ((0, graphql_1.isScalarType)(type)) {
if (!(0, graphql_1.isSpecifiedScalarType)(type)) {
const config = type.toConfig();
delete config.astNode; // avoid AST duplication elsewhere
resolvers[typeName] = new graphql_1.GraphQLScalarType(config);
}
}
else if ((0, graphql_1.isEnumType)(type)) {
resolvers[typeName] = {};
const values = type.getValues();
for (const value of values) {
resolvers[typeName][value.name] = value.value;
}
}
else if ((0, graphql_1.isInterfaceType)(type)) {
if (type.resolveType != null) {
resolvers[typeName] = {
__resolveType: type.resolveType,
};
}
}
else if ((0, graphql_1.isUnionType)(type)) {
if (type.resolveType != null) {
resolvers[typeName] = {
__resolveType: type.resolveType,
};
}
}
else if ((0, graphql_1.isObjectType)(type)) {
resolvers[typeName] = {};
if (type.isTypeOf != null) {
resolvers[typeName].__isTypeOf = type.isTypeOf;
}
const fields = type.getFields();
for (const fieldName in fields) {
const field = fields[fieldName];
if (field.subscribe != null) {
resolvers[typeName][fieldName] = resolvers[typeName][fieldName] || {};
resolvers[typeName][fieldName].subscribe = field.subscribe;
}
if (includeDefaultFieldResolver && (field.resolve == null || ((_a = field.resolve) === null || _a === void 0 ? void 0 : _a.name) == 'defaultFieldResolver')) {
resolvers[typeName][fieldName] = resolvers[typeName][fieldName] || {};
resolvers[typeName][fieldName].resolve =
includeDefaultFieldResolver === true ? graphql_1.defaultFieldResolver : includeDefaultFieldResolver;
}
if (field.resolve != null && ((_b = field.resolve) === null || _b === void 0 ? void 0 : _b.name) !== 'defaultFieldResolver') {
switch ((_c = field.resolve) === null || _c === void 0 ? void 0 : _c.name) {
case 'defaultMergedResolver':
if (!includeDefaultMergedResolver) {
continue;
}
break;
case 'defaultFieldResolver':
continue;
}
resolvers[typeName][fieldName] = resolvers[typeName][fieldName] || {};
resolvers[typeName][fieldName].resolve = field.resolve;
}
}
}
}
}
return resolvers;
}
exports.getResolversFromSchema = getResolversFromSchema;