@leosprograms/vf-graphql-holochain
Version:
GraphQL schema bindings for the Holochain implementation of ValueFlows
95 lines • 18.7 kB
JavaScript
/**
* Resolvers for Process fields
*
* @package: HoloREA
* @since: 2019-09-12
*/
import { injectTypename, DEFAULT_VF_MODULES, VfModule } from '../types.js';
import { mapZomeFn, extractEdges } from '../connection.js';
import planQueries from '../queries/plan.js';
export default (enabledVFModules = DEFAULT_VF_MODULES, dnaConfig, conductorUri) => {
const hasHistory = -1 !== enabledVFModules.indexOf(VfModule.History);
const hasObservation = -1 !== enabledVFModules.indexOf(VfModule.Observation);
const hasProcessSpecification = -1 !== enabledVFModules.indexOf(VfModule.ProcessSpecification);
const hasCommitment = -1 !== enabledVFModules.indexOf(VfModule.Commitment);
const hasIntent = -1 !== enabledVFModules.indexOf(VfModule.Intent);
const hasPlan = -1 !== enabledVFModules.indexOf(VfModule.Plan);
const hasAgent = -1 !== enabledVFModules.indexOf(VfModule.Agent);
const readRevision = mapZomeFn(dnaConfig, conductorUri, 'combined', 'process', 'get_revision');
const readEvents = mapZomeFn(dnaConfig, conductorUri, 'combined', 'indexing', 'query_economic_events');
const readCommitments = mapZomeFn(dnaConfig, conductorUri, 'combined', 'indexing', 'query_commitments');
const readIntents = mapZomeFn(dnaConfig, conductorUri, 'combined', 'indexing', 'query_intents');
const readProcessBasedOn = mapZomeFn(dnaConfig, conductorUri, 'combined', 'process_specification', 'get_process_specification');
const readPlan = planQueries(dnaConfig, conductorUri)['plan'];
const readAgent = mapZomeFn(dnaConfig, conductorUri, 'combined', 'agent', 'get_agent');
return Object.assign({
nextProcesses: () => {
throw new Error('resolver unimplemented');
},
previousProcesses: () => {
throw new Error('resolver unimplemented');
},
}, (hasObservation ? {
observedInputs: injectTypename('EconomicEvent', async (record) => {
const results = await readEvents({ params: { inputOf: record.id } });
return extractEdges(results);
}),
observedOutputs: injectTypename('EconomicEvent', async (record) => {
const results = await readEvents({ params: { outputOf: record.id } });
return extractEdges(results);
}),
unplannedInputs: () => {
throw new Error('resolver unimplemented');
},
unplannedOutputs: () => {
throw new Error('resolver unimplemented');
},
previous: () => {
throw new Error('resolver unimplemented');
},
next: () => {
throw new Error('resolver unimplemented');
},
} : {}), (hasCommitment ? {
committedInputs: injectTypename('Commitment', async (record) => {
const results = await readCommitments({ params: { inputOf: record.id } });
return extractEdges(results);
}),
committedOutputs: injectTypename('Commitment', async (record) => {
const results = await readCommitments({ params: { outputOf: record.id } });
return extractEdges(results);
}),
} : {}), (hasIntent ? {
intendedInputs: async (record) => {
const results = await readIntents({ params: { inputOf: record.id } });
return extractEdges(results);
},
intendedOutputs: async (record) => {
const results = await readIntents({ params: { outputOf: record.id } });
return extractEdges(results);
},
} : {}), (hasProcessSpecification ? {
basedOn: async (record) => {
return (await readProcessBasedOn({ address: record.basedOn })).processSpecification;
},
} : {}), (hasPlan ? {
plannedWithin: async (record) => {
return (await readPlan(record, { id: record.plannedWithin }));
},
} : {}), (hasAgent ? {
involvedAgents: () => {
throw new Error('resolver unimplemented');
},
workingAgents: async (record) => {
return (await Promise.all((record.workingAgents || []).map((address) => readAgent({ address })))).map((agentResponse) => agentResponse.agent);
},
inScopeOf: async (record) => {
return (await Promise.all((record.inScopeOf || []).map((address) => readAgent({ address })))).map((agentResponse) => agentResponse.agent);
},
} : {}), (hasHistory ? {
revision: async (record, args) => {
return (await readRevision(args)).process;
},
} : {}));
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process.js","sourceRoot":"","sources":["../../resolvers/process.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Resolvers for Process fields\n *\n * @package: HoloREA\n * @since:   2019-09-12\n */\n\nimport { DNAIdMappings, injectTypename, DEFAULT_VF_MODULES, VfModule, ReadParams, ByRevision, ProcessSpecificationAddress, AgentAddress, AddressableIdentifier } from '../types.js'\nimport { mapZomeFn, extractEdges } from '../connection.js'\n\nimport {\n  Process,\n  ProcessResponse,\n  EconomicEvent,\n  Commitment,\n  Intent,\n  ProcessSpecification,\n  Plan,\n  EconomicEventConnection,\n  CommitmentConnection,\n  IntentConnection,\n  ProcessSpecificationResponse,\n  Agent,\n  AccountingScope\n} from '@leosprograms/vf-graphql'\nimport planQueries from '../queries/plan.js'\nimport { CommitmentSearchInput, EconomicEventSearchInput, IntentSearchInput } from './zomeSearchInputTypes.js'\nimport { AgentResponse } from '../mutations/agent.js'\n\nexport default (enabledVFModules: VfModule[] = DEFAULT_VF_MODULES, dnaConfig: DNAIdMappings, conductorUri: string) => {\n  const hasHistory = -1 !== enabledVFModules.indexOf(VfModule.History)\n  const hasObservation = -1 !== enabledVFModules.indexOf(VfModule.Observation)\n  const hasProcessSpecification = -1 !== enabledVFModules.indexOf(VfModule.ProcessSpecification)\n  const hasCommitment = -1 !== enabledVFModules.indexOf(VfModule.Commitment)\n  const hasIntent = -1 !== enabledVFModules.indexOf(VfModule.Intent)\n  const hasPlan = -1 !== enabledVFModules.indexOf(VfModule.Plan)\n  const hasAgent = -1 !== enabledVFModules.indexOf(VfModule.Agent)\n\n  const readRevision = mapZomeFn<ByRevision, ProcessResponse>(dnaConfig, conductorUri, 'combined', 'process', 'get_revision')\n  const readEvents = mapZomeFn<EconomicEventSearchInput, EconomicEventConnection>(dnaConfig, conductorUri, 'combined', 'indexing', 'query_economic_events')\n  const readCommitments = mapZomeFn<CommitmentSearchInput, CommitmentConnection>(dnaConfig, conductorUri, 'combined', 'indexing', 'query_commitments')\n  const readIntents = mapZomeFn<IntentSearchInput, IntentConnection>(dnaConfig, conductorUri, 'combined', 'indexing', 'query_intents')\n  const readProcessBasedOn = mapZomeFn<ReadParams, ProcessSpecificationResponse>(dnaConfig, conductorUri, 'combined', 'process_specification', 'get_process_specification')\n  const readPlan = planQueries(dnaConfig, conductorUri)['plan']\n  const readAgent = mapZomeFn<ReadParams, AgentResponse>(dnaConfig, conductorUri, 'combined', 'agent', 'get_agent')\n\n  return Object.assign(\n    {\n      nextProcesses: () => {\n        throw new Error('resolver unimplemented')\n      },\n      previousProcesses: () => {\n        throw new Error('resolver unimplemented')\n      },\n    },\n    (hasObservation ? {\n      observedInputs: injectTypename('EconomicEvent', async (record: Process): Promise<EconomicEvent[]> => {\n        const results = await readEvents({ params: { inputOf: record.id } })\n        return extractEdges(results)\n      }),\n\n      observedOutputs: injectTypename('EconomicEvent', async (record: Process): Promise<EconomicEvent[]> => {\n        const results = await readEvents({ params: { outputOf: record.id } })\n        return extractEdges(results)\n      }),\n\n      unplannedInputs: () => {\n        throw new Error('resolver unimplemented')\n      },\n      unplannedOutputs: () => {\n        throw new Error('resolver unimplemented')\n      },\n      previous: () => {\n        throw new Error('resolver unimplemented')\n      },\n      next: () => {\n        throw new Error('resolver unimplemented')\n      },\n    } : {}),\n    (hasCommitment ? {\n      committedInputs: injectTypename('Commitment', async (record: Process): Promise<Commitment[]> => {\n        const results = await readCommitments({ params: { inputOf: record.id } })\n        return extractEdges(results)\n      }),\n\n      committedOutputs: injectTypename('Commitment', async (record: Process): Promise<Commitment[]> => {\n        const results = await readCommitments({ params: { outputOf: record.id } })\n        return extractEdges(results)\n      }),\n    } : {}),\n    (hasIntent ? {\n      intendedInputs: async (record: Process): Promise<Intent[]> => {\n        const results = await readIntents({ params: { inputOf: record.id } })\n        return extractEdges(results)\n      },\n\n      intendedOutputs: async (record: Process): Promise<Intent[]> => {\n        const results = await readIntents({ params: { outputOf: record.id } })\n        return extractEdges(results)\n      },\n    } : {}),\n    (hasProcessSpecification ? {\n      basedOn: async (record: { basedOn: ProcessSpecificationAddress }): Promise<ProcessSpecification> => {\n        return (await readProcessBasedOn({ address: record.basedOn })).processSpecification\n      },\n    } : {}),\n    (hasPlan ? {\n      plannedWithin: async (record: Process): Promise<Plan> => {\n        return (await readPlan(record, { id: record.plannedWithin }))\n      },\n    } : {}),\n    (hasAgent ? {\n      involvedAgents: () => {\n        throw new Error('resolver unimplemented')\n      },\n      workingAgents: async (record: { workingAgents: AgentAddress[] }): Promise<Agent[]> => {\n        return (await Promise.all((record.workingAgents || []).map((address)=>readAgent({address})))).map((agentResponse) => agentResponse.agent)\n      },\n      inScopeOf: async (record: { inScopeOf: AgentAddress[] }): Promise<AccountingScope[]> => {\n        return (await Promise.all((record.inScopeOf || []).map((address)=>readAgent({address})))).map((agentResponse) => agentResponse.agent)\n      },\n    } : {}),\n    (hasHistory ? {\n      revision: async (record: Process, args: { revisionId: AddressableIdentifier }): Promise<Process> => {\n        return (await readRevision(args)).process\n      },\n    } : {}),\n  )\n}\n"]}