// Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. // This source code is licensed under the Apache 2.0 license found // in the LICENSE file in the root directory of this source tree. // Code generated by entc, DO NOT EDIT. package entv2 import ( "context" "fmt" "github.com/facebookincubator/ent/dialect/sql/sqlgraph" "github.com/facebookincubator/ent/entc/integration/migrate/entv2/pet" "github.com/facebookincubator/ent/entc/integration/migrate/entv2/user" "github.com/facebookincubator/ent/schema/field" ) // PetCreate is the builder for creating a Pet entity. type PetCreate struct { config mutation *PetMutation hooks []Hook } // SetOwnerID sets the owner edge to User by id. func (pc *PetCreate) SetOwnerID(id int) *PetCreate { pc.mutation.SetOwnerID(id) return pc } // SetNillableOwnerID sets the owner edge to User by id if the given value is not nil. func (pc *PetCreate) SetNillableOwnerID(id *int) *PetCreate { if id != nil { pc = pc.SetOwnerID(*id) } return pc } // SetOwner sets the owner edge to User. func (pc *PetCreate) SetOwner(u *User) *PetCreate { return pc.SetOwnerID(u.ID) } // Mutation returns the PetMutation object of the builder. func (pc *PetCreate) Mutation() *PetMutation { return pc.mutation } // Save creates the Pet in the database. func (pc *PetCreate) Save(ctx context.Context) (*Pet, error) { var ( err error node *Pet ) if len(pc.hooks) == 0 { node, err = pc.sqlSave(ctx) } else { var mut Mutator = MutateFunc(func(ctx context.Context, m Mutation) (Value, error) { mutation, ok := m.(*PetMutation) if !ok { return nil, fmt.Errorf("unexpected mutation type %T", m) } pc.mutation = mutation node, err = pc.sqlSave(ctx) mutation.done = true return node, err }) for i := len(pc.hooks) - 1; i >= 0; i-- { mut = pc.hooks[i](mut) } if _, err := mut.Mutate(ctx, pc.mutation); err != nil { return nil, err } } return node, err } // SaveX calls Save and panics if Save returns an error. func (pc *PetCreate) SaveX(ctx context.Context) *Pet { v, err := pc.Save(ctx) if err != nil { panic(err) } return v } func (pc *PetCreate) sqlSave(ctx context.Context) (*Pet, error) { var ( pe = &Pet{config: pc.config} _spec = &sqlgraph.CreateSpec{ Table: pet.Table, ID: &sqlgraph.FieldSpec{ Type: field.TypeInt, Column: pet.FieldID, }, } ) if nodes := pc.mutation.OwnerIDs(); len(nodes) > 0 { edge := &sqlgraph.EdgeSpec{ Rel: sqlgraph.O2O, Inverse: true, Table: pet.OwnerTable, Columns: []string{pet.OwnerColumn}, Bidi: false, Target: &sqlgraph.EdgeTarget{ IDSpec: &sqlgraph.FieldSpec{ Type: field.TypeInt, Column: user.FieldID, }, }, } for _, k := range nodes { edge.Target.Nodes = append(edge.Target.Nodes, k) } _spec.Edges = append(_spec.Edges, edge) } if err := sqlgraph.CreateNode(ctx, pc.driver, _spec); err != nil { if cerr, ok := isSQLConstraintError(err); ok { err = cerr } return nil, err } id := _spec.ID.Value.(int64) pe.ID = int(id) return pe, nil }