UNPKG

@leosprograms/vf-graphql-holochain

Version:

GraphQL schema bindings for the Holochain implementation of ValueFlows

125 lines 19.1 kB
/** * base types for GraphQL query layer * * @package: HoloREA * @since: 2019-05-20 */ import { GraphQLScalarType } from 'graphql'; import { Kind } from 'graphql/language/index.js'; import Big from 'big.js'; export function addTypename(name) { return (obj) => { obj['__typename'] = name; return obj; }; } export function injectTypename(name, fn) { return async (root, args) => { const data = await fn(root, args); data['__typename'] = name; return data; }; } // VfModule listing. // for the reference, see: // https://lab.allmende.io/valueflows/vf-schemas/vf-graphql/-/tree/sprout/lib/schemas // enum containing the not yet implemented VfModule // obviously, move the variant to VfModule if implementing // it var UnimplementedVfModule; (function (UnimplementedVfModule) { UnimplementedVfModule["Geolocation"] = "geolocation"; UnimplementedVfModule["History"] = "history"; UnimplementedVfModule["Recipe"] = "recipe"; UnimplementedVfModule["Scenario"] = "scenario"; UnimplementedVfModule["ProductBatch"] = "product_batch"; UnimplementedVfModule["Appreciation"] = "appreciation"; UnimplementedVfModule["Claim"] = "claim"; UnimplementedVfModule["Filtering"] = "filtering"; UnimplementedVfModule["Ordering"] = "ordering"; })(UnimplementedVfModule || (UnimplementedVfModule = {})); // enum containing the implemented VF modules. // separate from above so that developers can import the enum and not turn on useless // features export var VfModule; (function (VfModule) { // always required regardless // see: https://lab.allmende.io/valueflows/vf-schemas/vf-graphql/-/blob/sprout/lib/index.js#L29 VfModule["Util"] = "util"; VfModule["Pagination"] = "pagination"; VfModule["History"] = "history"; // optional to enable VfModule["Agent"] = "agent"; VfModule["Agreement"] = "agreement"; VfModule["Action"] = "action"; VfModule["ProcessSpecification"] = "process_specification"; VfModule["ResourceSpecification"] = "resource_specification"; VfModule["Measurement"] = "measurement"; VfModule["Observation"] = "observation"; VfModule["Process"] = "process"; VfModule["Plan"] = "plan"; VfModule["Fulfillment"] = "fulfillment"; VfModule["Intent"] = "intent"; VfModule["Commitment"] = "commitment"; VfModule["Satisfaction"] = "satisfaction"; VfModule["Proposal"] = "proposal"; VfModule["Recipe"] = "recipe"; })(VfModule || (VfModule = {})); // default 'full suite' VF module set supported by hREA export const DEFAULT_VF_MODULES = [ VfModule.History, // Specification DNA VfModule.Action, VfModule.ProcessSpecification, VfModule.ResourceSpecification, VfModule.Measurement, // Agent DNA VfModule.Agent, // Agreement DNA VfModule.Agreement, // Observation DNA VfModule.Observation, VfModule.Process, // Proposal DNA VfModule.Proposal, // Plan DNA VfModule.Plan, // Planning DNA VfModule.Fulfillment, VfModule.Intent, VfModule.Commitment, VfModule.Satisfaction, // Recipe DNA VfModule.Recipe, ]; // scalar types export const URI = new GraphQLScalarType({ name: 'URI', description: 'The `URI` type declares a reference to any resolvable resource.', serialize: (v) => v, parseValue: (v) => v, parseLiteral(ast) { if (ast.kind === Kind.STRING) { if (!ast.value.match(/^\w+:/)) { throw new Error('Unable to parse URI- invalid format'); } return ast.value; } return null; }, }); // :TODO: this should be a GraphQLScalarType<Big, string> to avoid precision loss at API boundary export const Decimal = new GraphQLScalarType({ name: 'Decimal', description: 'The `Decimal` scalar type to handle precision arithmetic and potentially large values.', serialize: (v) => v.toNumber(), parseValue: (v) => Big(v), parseLiteral(ast) { if (ast.kind !== Kind.STRING && ast.kind !== Kind.INT && ast.kind !== Kind.FLOAT) { // @ts-ignore throw new TypeError(String(ast.value) + ' is not a valid decimal value.'); } return Big(ast.value); } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../types.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * base types for GraphQL query layer\n *\n * @package: HoloREA\n * @since:   2019-05-20\n */\n\nimport { SignalCb, CellId } from '@holochain/client'\nimport { IResolvers } from '@graphql-tools/utils'\nimport { GraphQLScalarType } from 'graphql'\nimport { Kind, ValueNode, VariableNode } from 'graphql/language/index.js'\nimport Big from 'big.js'\n\n// Configuration object to allow specifying custom conductor DNA IDs to bind to.\n// Default is to use a DNA with the same ID as the mapping ID (ie. agent = \"agent\")\nexport interface DNAIdMappings {\n  agent?: CellId,\n  agreement?: CellId,\n  observation?: CellId,\n  planning?: CellId,\n  proposal?: CellId,\n  specification?: CellId,\n  combined?: CellId,\n}\n\nexport { CellId }\n\n// Options for resolver generator\nexport interface ResolverOptions {\n  // AppAgentClient in case we need to make calls to the conductor in weave\n  weaveAppAgentClient: any;\n\n  // Array of ValueFlows modules to include in the schema\n  // @see https://lab.allmende.io/valueflows/vf-schemas/vf-graphql#generating-schemas\n  enabledVFModules: VfModule[],\n\n  // Mapping of DNA identifiers to runtime `CellId`s to bind to.\n  dnaConfig: DNAIdMappings,\n\n  // Custom Holochain conductor URI to use with this instance, to support connecting to multiple conductors.\n  // If not specified, connects to the local conductor or the URI stored in `process.env.REACT_APP_HC_CONN_URL`.\n  conductorUri: string,\n\n  // Custom Admin Holochain conductor URI to use with this instance, to support connecting to multiple conductors.\n  // If not specified, connects to the local conductor or the URI stored in `process.env.REACT_APP_HC_ADMIN_CONN_URL`.\n  adminConductorUri: string,\n\n  // This is needed in order to fetch the installed CellId's and grant authorization\n  // by the Admin API for any zome functions on those Cells to be called\n  appId: string,\n\n  // Callback to listen for signals from the Holochain app websocket, to support realtime event notifications.\n  traceAppSignals?: SignalCb,\n\n  // Origin\n  origin?: string,\n}\n\n// Schema generation options to be passed to vf-graphql\n// @see https://lab.allmende.io/valueflows/vf-schemas/vf-graphql#generating-schemas\nexport interface ExtensionOptions {\n  // Array of additional SDL schema strings to bundle into the resultant schema in addition to the\n  // specified modular sub-section of the ValueFlows spec.\n  extensionSchemas?: string[],\n\n  // Additional resolver callbacks to inject into the schema in addition to the specified bound\n  // set of hREA DNA resolvers.\n  // Used for injecting implementation logic for `extensionSchemas`: not recommended for overriding\n  // parts of the hREA core behaviour!\n  extensionResolvers?: IResolvers,\n}\n\nexport type BindSchemaOptions = Pick<ResolverOptions, 'dnaConfig' | 'conductorUri' | 'adminConductorUri' | 'appId' | 'traceAppSignals' | 'weaveAppAgentClient'>\n  & {\n    // optional because DEFAULT_VF_MODULES is assigned as fallback\n    enabledVFModules?: VfModule[] \n  }\n  & ExtensionOptions\n\n// Types that serialize for rust zome calls\n// start of section\nexport interface ReadParams {\n  address: AddressableIdentifier,\n}\nexport interface ById {\n  id: AddressableIdentifier,\n}\nexport interface ByRevision {\n  revisionId: AddressableIdentifier,\n}\n\nexport type AddressableIdentifier = string\nexport type CommitmentAddress = AddressableIdentifier\nexport type ProcessAddress = AddressableIdentifier\nexport type FulfillmentAddress = AddressableIdentifier\nexport type SatisfactionAddress = AddressableIdentifier\nexport type AgreementAddress = AddressableIdentifier\nexport type PlanAddress = AddressableIdentifier\nexport type ProposalAddress = AddressableIdentifier\nexport type IntentAddress = AddressableIdentifier\nexport type AgentAddress = AddressableIdentifier\nexport type EconomicResourceAddress = AddressableIdentifier\nexport type EconomicEventAddress = AddressableIdentifier\nexport type ResourceSpecificationAddress = AddressableIdentifier\nexport type ProposedIntentAddress = AddressableIdentifier\nexport type ProcessSpecificationAddress = AddressableIdentifier\nexport type RecipeProcessAddress = AddressableIdentifier\nexport type RecipeExchangeAddress = AddressableIdentifier\nexport type RecipeFlowAddress = AddressableIdentifier\n\nexport interface ByRevision {\n  revisionId: string\n}\n// end of section\n\n// helpers for resolvers to inject __typename parameter for union type disambiguation\n// ...this might be unnecessarily present due to lack of familiarity with GraphQL?\n\ntype ObjDecorator<T> = (obj: T) => T\ntype Resolver<T> = (root, args) => Promise<T>\n\nexport function addTypename<T> (name: string): ObjDecorator<T> {\n  return (obj) => {\n    obj['__typename'] = name\n    return obj\n  }\n}\n\nexport function injectTypename<T> (name: string, fn: Resolver<T>): Resolver<T> {\n  return async (root, args): Promise<T> => {\n    const data = await fn(root, args)\n    data['__typename'] = name\n    return data\n  }\n}\n\n// VfModule listing.\n// for the reference, see:\n// https://lab.allmende.io/valueflows/vf-schemas/vf-graphql/-/tree/sprout/lib/schemas\n\n// enum containing the not yet implemented VfModule\n// obviously, move the variant to VfModule if implementing\n// it\nenum UnimplementedVfModule {\n  Geolocation = 'geolocation',\n  History = 'history',\n  Recipe = 'recipe',\n  Scenario = 'scenario',\n  ProductBatch = 'product_batch',\n  Appreciation = 'appreciation',\n  Claim = 'claim',\n  Filtering = 'filtering',\n  Ordering = 'ordering',\n}\n\n// enum containing the implemented VF modules.\n// separate from above so that developers can import the enum and not turn on useless\n// features\nexport enum VfModule {\n  // always required regardless\n  // see: https://lab.allmende.io/valueflows/vf-schemas/vf-graphql/-/blob/sprout/lib/index.js#L29\n  Util = 'util',\n  Pagination = 'pagination',\n  History = 'history',\n  // optional to enable\n  Agent = 'agent',\n  Agreement = 'agreement',\n  Action = 'action',\n  ProcessSpecification = 'process_specification',\n  ResourceSpecification = 'resource_specification',\n  Measurement = 'measurement',\n  Observation = 'observation',\n  Process = 'process',\n  Plan = 'plan',\n  Fulfillment = 'fulfillment',\n  Intent = 'intent',\n  Commitment = 'commitment',\n  Satisfaction = 'satisfaction',\n  Proposal = 'proposal',\n  Recipe = 'recipe',\n}\n\n// default 'full suite' VF module set supported by hREA\nexport const DEFAULT_VF_MODULES = [\n  VfModule.History,\n  // Specification DNA\n  VfModule.Action,\n  VfModule.ProcessSpecification,\n  VfModule.ResourceSpecification,\n  VfModule.Measurement,\n  // Agent DNA\n  VfModule.Agent,\n  // Agreement DNA\n  VfModule.Agreement,\n  // Observation DNA\n  VfModule.Observation,\n  VfModule.Process,\n  // Proposal DNA\n  VfModule.Proposal,\n  // Plan DNA\n  VfModule.Plan,\n  // Planning DNA\n  VfModule.Fulfillment,\n  VfModule.Intent,\n  VfModule.Commitment,\n  VfModule.Satisfaction,\n  // Recipe DNA\n  VfModule.Recipe,\n]\n\n// scalar types\n\nexport const URI = new GraphQLScalarType({\n  name: 'URI',\n  description: 'The `URI` type declares a reference to any resolvable resource.',\n  serialize: (v) => v,\n  parseValue: (v) => v,\n  parseLiteral (ast) {\n    if (ast.kind === Kind.STRING) {\n      if (!ast.value.match(/^\\w+:/)) {\n        throw new Error('Unable to parse URI- invalid format')\n      }\n      return ast.value\n    }\n    return null\n  },\n})\n\n// :TODO: this should be a GraphQLScalarType<Big, string> to avoid precision loss at API boundary\nexport const Decimal: GraphQLScalarType = new GraphQLScalarType({\n  name: 'Decimal',\n  description: 'The `Decimal` scalar type to handle precision arithmetic and potentially large values.',\n  serialize: (v: unknown) => (v as Big).toNumber(),\n  parseValue: (v: unknown) => Big(v as number),\n  parseLiteral(ast: ValueNode) {\n    if (ast.kind !== Kind.STRING && ast.kind !== Kind.INT && ast.kind !== Kind.FLOAT) {\n      // @ts-ignore\n      throw new TypeError(String(ast.value) + ' is not a valid decimal value.')\n    }\n\n    return Big(ast.value)\n  }\n})\n"]}