import 'package:angel_framework/angel_framework.dart'; import 'package:graphql_schema/graphql_schema.dart'; Map _fetchRequestInfo(Map arguments) { return { '__requestctx': arguments.remove('__requestctx'), '__responsectx': arguments.remove('__responsectx'), }; } Map _getQuery(Map arguments) { var f = Map.from(arguments)..remove('id')..remove('data'); return f.isEmpty ? null : f; } /// A GraphQL resolver that `index`es an Angel service. /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver, Serialized> resolveViaServiceIndex(Service service) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); return await service.index(params); }; } /// A GraphQL resolver that calls `findOne` on an Angel service. /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver resolveViaServiceFindOne( Service service) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); return await service.findOne(params); }; } /// A GraphQL resolver that `read`s a single value from an Angel service. /// /// This resolver should be used on a field with at least the following inputs: /// * `id`: a [graphQLId] or [graphQLString] /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver resolveViaServiceRead(Service service, {String idField = 'id'}) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); var id = arguments.remove(idField); return await service.read(id, params); }; } /// A GraphQL resolver that `creates` a single value in an Angel service. /// /// This resolver should be used on a field with at least the following input: /// * `data`: a [GraphQLObjectType] corresponding to the format of `data` to be passed to `create` /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver resolveViaServiceCreate( Service service) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); return await service.create(arguments['data'] as Value, params); }; } /// A GraphQL resolver that `modifies` a single value from an Angel service. /// /// This resolver should be used on a field with at least the following inputs: /// * `id`: a [graphQLId] or [graphQLString] /// * `data`: a [GraphQLObjectType] corresponding to the format of `data` to be passed to `modify` /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver resolveViaServiceModify(Service service, {String idField = 'id'}) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); var id = arguments.remove(idField); return await service.modify(id, arguments['data'] as Value, params); }; } /// A GraphQL resolver that `update`s a single value from an Angel service. /// /// This resolver should be used on a field with at least the following inputs: /// * `id`: a [graphQLId] or [graphQLString] /// * `data`: a [GraphQLObjectType] corresponding to the format of `data` to be passed to `update` /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. /// /// Keep in mind that `update` **overwrites** existing contents. /// To avoid this, use [resolveViaServiceModify] instead. GraphQLFieldResolver resolveViaServiceUpdate(Service service, {String idField = 'id'}) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); var id = arguments.remove(idField); return await service.update(id, arguments['data'] as Value, params); }; } /// A GraphQL resolver that `remove`s a single value from an Angel service. /// /// This resolver should be used on a field with at least the following inputs: /// * `id`: a [graphQLId] or [graphQLString] /// /// The arguments passed to the resolver will be forwarded to the service, and the /// service will receive [Providers.graphql]. GraphQLFieldResolver resolveViaServiceRemove(Service service, {String idField = 'id'}) { return (_, arguments) async { var _requestInfo = _fetchRequestInfo(arguments); var params = {'query': _getQuery(arguments), 'provider': Providers.graphQL} ..addAll(_requestInfo); var id = arguments.remove(idField); return await service.remove(id, params); }; }