UNPKG

@leosprograms/vf-graphql-holochain

Version:

GraphQL schema bindings for the Holochain implementation of ValueFlows

72 lines 12.6 kB
/** * Agent queries * * :TODO: wire into Personas hApp and replace generated agent names with serving of profile data * * @package: hREA * @since: 2020-02-19 */ import { injectTypename } from '../types.js'; import { mapZomeFn } from '../connection.js'; export function addAgentTypename(record) { record['__typename'] = record.agentType.toLowerCase() === 'person' ? 'Person' : (record.agentType.toLowerCase() === 'organization' ? 'Organization' : record.agentType); return record; } export default (dnaConfig, conductorUri) => { //assumes there is a link from agentPubKey to a Person entry, but what if link cannot be resolved? const readMyAgent = mapZomeFn(dnaConfig, conductorUri, 'combined', 'agent', 'get_my_agent'); const readAgent = mapZomeFn(dnaConfig, conductorUri, 'combined', 'agent', 'get_agent'); const readAll = mapZomeFn(dnaConfig, conductorUri, 'combined', 'indexing', 'read_all_agents'); const readAllAgentType = mapZomeFn(dnaConfig, conductorUri, 'combined', 'indexing', 'query_agents'); const agentRelationship = () => { throw new Error('query unimplemented'); }; const agentRelationships = () => { throw new Error('query unimplemented'); }; const agentRelationshipRole = () => { throw new Error('query unimplemented'); }; const agentRelationshipRoles = () => { throw new Error('query unimplemented'); }; return { // :TODO: is myAgent always a 'Person' in Holochain, or will we allow users to act in an Organization context directly? myAgent: injectTypename('Person', async (root, args) => { return (await readMyAgent(null)).agent; }), agent: async (root, args) => { return addAgentTypename((await readAgent({ address: args.id })).agent); }, organization: injectTypename('Organization', async (root, args) => { return ((await readAgent({ address: args.id })).agent); // TODO: type check if person or organization and provide error if person }), person: injectTypename('Person', async (root, args) => { return ((await readAgent({ address: args.id })).agent); // TODO: type check if person or organization and provide error if organization }), agents: async (root, args) => { const agents = await readAll(args); return { pageInfo: agents.pageInfo, edges: agents.edges.map(({ cursor, node }) => { return { cursor, node: addAgentTypename(node) }; }) }; }, organizations: async (root, args) => { const agents = await readAllAgentType({ params: { agentType: 'Organization' } }); return agents; }, people: async (root, args) => { const agents = await readAllAgentType({ params: { agentType: 'Person' } }); return agents; }, agentRelationship, agentRelationships, agentRelationshipRole, agentRelationshipRoles, }; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agent.js","sourceRoot":"","sources":["../../queries/agent.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Agent queries\n *\n * :TODO: wire into Personas hApp and replace generated agent names with serving of profile data\n *\n * @package: hREA\n * @since:   2020-02-19\n */\n\nimport { DNAIdMappings, injectTypename, ReadParams } from '../types.js'\nimport { mapZomeFn, serializeHash, deserializeHash } from '../connection.js'\n\nimport {\n  AccountingScope,\n  Agent,\n  AgentConnection,\n  AgentEdge,\n  Organization,\n  OrganizationConnection,\n  Person,\n  PersonConnection\n} from '@leosprograms/vf-graphql'\nimport { AgentPubKey } from '@holochain/client'\nimport { AgentResponse } from '../mutations/agent'\nimport { AgentSearchInput, PagingParams } from '../resolvers/zomeSearchInputTypes.js'\n\nexport interface RegistrationQueryParams {\n  pubKey: AgentPubKey,\n}\nexport type AgentWithType = Agent & { agentType: string }\nexport interface AgentWithTypeResponse {\n  agent: AgentWithType\n}\nexport interface AgentEdgeWithTypeEdge extends Omit<AgentEdge, 'node'> {\n  node: AgentWithType\n}\nexport interface AgentConnectionWithType extends Omit<AgentConnection, 'edges'> {\n  edges: AgentEdgeWithTypeEdge[]\n}\n\nexport function addAgentTypename(record: AgentWithType) {\n  record['__typename'] = record.agentType.toLowerCase() === 'person' ? 'Person' : (\n    record.agentType.toLowerCase() === 'organization' ? 'Organization' : record.agentType\n  )\n  return record as Agent\n}\n\nexport default (dnaConfig: DNAIdMappings, conductorUri: string) => {\n\n  //assumes there is a link from agentPubKey to a Person entry, but what if link cannot be resolved?\n  const readMyAgent = mapZomeFn<null, AgentResponse>(dnaConfig, conductorUri, 'combined', 'agent', 'get_my_agent')\n  const readAgent = mapZomeFn<ReadParams, AgentWithTypeResponse>(dnaConfig, conductorUri, 'combined', 'agent', 'get_agent')\n  const readAll = mapZomeFn<PagingParams, AgentConnectionWithType>(dnaConfig, conductorUri, 'combined', 'indexing', 'read_all_agents')\n  const readAllAgentType = mapZomeFn<AgentSearchInput, AgentConnection>(dnaConfig, conductorUri, 'combined', 'indexing', 'query_agents')\n\n  const agentRelationship = () => {\n    throw new Error('query unimplemented')\n  }\n  const agentRelationships = () => {\n    throw new Error('query unimplemented')\n  }\n  const agentRelationshipRole = () => {\n    throw new Error('query unimplemented')\n  }\n  const agentRelationshipRoles = () => {\n    throw new Error('query unimplemented')\n  }\n\n  return {\n    // :TODO: is myAgent always a 'Person' in Holochain, or will we allow users to act in an Organization context directly?\n    myAgent: injectTypename('Person', async (root, args): Promise<Agent> => {\n      return (await readMyAgent(null)).agent\n    }),\n    agent: async (root, args): Promise<Agent> => {\n      return addAgentTypename((await readAgent({ address: args.id })).agent)\n    },\n    organization: injectTypename('Organization', async (root, args): Promise<Organization> => {\n      return ((await readAgent({ address: args.id })).agent) as Organization\n      // TODO: type check if person or organization and provide error if person\n    }),\n    person: injectTypename('Person', async (root, args): Promise<Person> => {\n      return ((await readAgent({ address: args.id })).agent) as Person\n      // TODO: type check if person or organization and provide error if organization\n    }),\n    agents: async (root, args: PagingParams): Promise<AgentConnection> => {\n      const agents = await readAll(args)\n      return {\n        pageInfo: agents.pageInfo,\n        edges: agents.edges.map(({ cursor, node }) => {\n          return { cursor, node: addAgentTypename(node) }\n        })\n      } as AgentConnection\n    },\n    organizations: async (root, args: PagingParams): Promise<OrganizationConnection> => {\n      const agents = await readAllAgentType({ params: { agentType: 'Organization' } })\n      return (agents as OrganizationConnection)\n    },\n    people: async (root, args: PagingParams): Promise<PersonConnection> => {\n      const agents = await readAllAgentType({ params: { agentType: 'Person' } })\n      return (agents as PersonConnection)\n    },\n    agentRelationship,\n    agentRelationships,\n    agentRelationshipRole,\n    agentRelationshipRoles,\n  }\n}\n"]}