Hi we are looking for examples on creating & upserting data with graph relationships.
In the example of a Post with Comments,
We are aware that the child (Comment) should have fields with @documentReference and @relationDocument directives to the parent (Post) .The parent should also have a field with @relationFrom directive referencing the ID field of Child. Supported directives | ComposeDB on Ceramic
We know how to compile and deploy such models, but are keen to see a working example of creating instances of Parent and Child.
Is it as simple as first creating Parent class to get a Parent instance id, then using that with the Parent model deployed address/stream/id to have the parameters for the @documentReference and @relationDocument fields when creating a child?
Also is it possible to do a nested mutation, where I can create the Parent and initialize or upsert Children, completely replace existing Children? Performing mutations | ComposeDB on Ceramic Hints at this
I’m not quite sure I understand your question about upserting Models, but please note that Models are immutable and cannot be updated after they are published.
Not sure what you mean by “Parent class” and “instance id”, but if you want to add a Comment relation to a Post for example, you simply need to create a Comment document setting the post ID to reference in the specified field.
No, that’s not possible as each document creation or update requires a unique transaction.
Wondering how to get the right value for @loadModel directive, it seems I need to deploy the model to get that loadModel parameter, so it feels like circular dependency.
I am able to create simple models (no nested relationship) with graphql mutation, but still have to figure out the syntax to create a ProposalVote (how to pass the associated Proposal id in create mutation)
Would appreciate pointer if this is the right direction for passing a Proposal id (proposal_stream_id field)
const create_vote_query = `
mutation CreateNounsProposalVote($vote: CreateNounsProposalVoteInput!) {
createNounsProposalVote(input: $vote) {
document {
// Is this the right field & location in this context?
proposal_stream_id // Parent proposal id
eth_address
vote_id
...
votes
}
}
}`
const create_vote_variables = {
"vote": {
"content": vote
}
}
Hi, your example seems pretty similar to what is described in the docs in Relations | ComposeDB on Ceramic
Essentially the flow is to create 3 different composites as follows:
Create your Proposal model with only its content fields (no views)
Load your Proposal model and add a view with the @relationFrom directive (see Supported directives | ComposeDB on Ceramic) pointing to the ProposalVote model created in step 2.
Regarding your question about creating ProposalVote documents, yes you simply need to provide the ID of the Proposal document in the field set as holding the relation with the @documentReference directive.