123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- // Code generated by entc, DO NOT EDIT.
- package ent
- import (
- "context"
- "errors"
- "fmt"
- "time"
- "code.osinet.fr/fgm/entdemo/ent/car"
- "code.osinet.fr/fgm/entdemo/ent/user"
- "github.com/facebookincubator/ent/dialect/sql/sqlgraph"
- "github.com/facebookincubator/ent/schema/field"
- )
- // CarCreate is the builder for creating a Car entity.
- type CarCreate struct {
- config
- mutation *CarMutation
- hooks []Hook
- }
- // SetModel sets the model field.
- func (cc *CarCreate) SetModel(s string) *CarCreate {
- cc.mutation.SetModel(s)
- return cc
- }
- // SetRegisteredAt sets the registered_at field.
- func (cc *CarCreate) SetRegisteredAt(t time.Time) *CarCreate {
- cc.mutation.SetRegisteredAt(t)
- return cc
- }
- // SetOwnerID sets the owner edge to User by id.
- func (cc *CarCreate) SetOwnerID(id int) *CarCreate {
- cc.mutation.SetOwnerID(id)
- return cc
- }
- // SetNillableOwnerID sets the owner edge to User by id if the given value is not nil.
- func (cc *CarCreate) SetNillableOwnerID(id *int) *CarCreate {
- if id != nil {
- cc = cc.SetOwnerID(*id)
- }
- return cc
- }
- // SetOwner sets the owner edge to User.
- func (cc *CarCreate) SetOwner(u *User) *CarCreate {
- return cc.SetOwnerID(u.ID)
- }
- // Save creates the Car in the database.
- func (cc *CarCreate) Save(ctx context.Context) (*Car, error) {
- if _, ok := cc.mutation.Model(); !ok {
- return nil, errors.New("ent: missing required field \"model\"")
- }
- if _, ok := cc.mutation.RegisteredAt(); !ok {
- return nil, errors.New("ent: missing required field \"registered_at\"")
- }
- var (
- err error
- node *Car
- )
- if len(cc.hooks) == 0 {
- node, err = cc.sqlSave(ctx)
- } else {
- var mut Mutator = MutateFunc(func(ctx context.Context, m Mutation) (Value, error) {
- mutation, ok := m.(*CarMutation)
- if !ok {
- return nil, fmt.Errorf("unexpected mutation type %T", m)
- }
- cc.mutation = mutation
- node, err = cc.sqlSave(ctx)
- return node, err
- })
- for i := len(cc.hooks) - 1; i >= 0; i-- {
- mut = cc.hooks[i](mut)
- }
- if _, err := mut.Mutate(ctx, cc.mutation); err != nil {
- return nil, err
- }
- }
- return node, err
- }
- // SaveX calls Save and panics if Save returns an error.
- func (cc *CarCreate) SaveX(ctx context.Context) *Car {
- v, err := cc.Save(ctx)
- if err != nil {
- panic(err)
- }
- return v
- }
- func (cc *CarCreate) sqlSave(ctx context.Context) (*Car, error) {
- var (
- c = &Car{config: cc.config}
- _spec = &sqlgraph.CreateSpec{
- Table: car.Table,
- ID: &sqlgraph.FieldSpec{
- Type: field.TypeInt,
- Column: car.FieldID,
- },
- }
- )
- if value, ok := cc.mutation.Model(); ok {
- _spec.Fields = append(_spec.Fields, &sqlgraph.FieldSpec{
- Type: field.TypeString,
- Value: value,
- Column: car.FieldModel,
- })
- c.Model = value
- }
- if value, ok := cc.mutation.RegisteredAt(); ok {
- _spec.Fields = append(_spec.Fields, &sqlgraph.FieldSpec{
- Type: field.TypeTime,
- Value: value,
- Column: car.FieldRegisteredAt,
- })
- c.RegisteredAt = value
- }
- if nodes := cc.mutation.OwnerIDs(); len(nodes) > 0 {
- edge := &sqlgraph.EdgeSpec{
- Rel: sqlgraph.M2O,
- Inverse: true,
- Table: car.OwnerTable,
- Columns: []string{car.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, cc.driver, _spec); err != nil {
- if cerr, ok := isSQLConstraintError(err); ok {
- err = cerr
- }
- return nil, err
- }
- id := _spec.ID.Value.(int64)
- c.ID = int(id)
- return c, nil
- }
|