@leosprograms/vf-graphql-holochain
Version:
GraphQL schema bindings for the Holochain implementation of ValueFlows
72 lines • 12.6 kB
JavaScript
/**
* 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"]}