server_update.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647
  1. // Code generated by ent, DO NOT EDIT.
  2. package ent
  3. import (
  4. "context"
  5. "errors"
  6. "fmt"
  7. "time"
  8. "wechat-api/ent/predicate"
  9. "wechat-api/ent/server"
  10. "wechat-api/ent/wx"
  11. "entgo.io/ent/dialect/sql"
  12. "entgo.io/ent/dialect/sql/sqlgraph"
  13. "entgo.io/ent/schema/field"
  14. )
  15. // ServerUpdate is the builder for updating Server entities.
  16. type ServerUpdate struct {
  17. config
  18. hooks []Hook
  19. mutation *ServerMutation
  20. }
  21. // Where appends a list predicates to the ServerUpdate builder.
  22. func (su *ServerUpdate) Where(ps ...predicate.Server) *ServerUpdate {
  23. su.mutation.Where(ps...)
  24. return su
  25. }
  26. // SetUpdatedAt sets the "updated_at" field.
  27. func (su *ServerUpdate) SetUpdatedAt(t time.Time) *ServerUpdate {
  28. su.mutation.SetUpdatedAt(t)
  29. return su
  30. }
  31. // SetStatus sets the "status" field.
  32. func (su *ServerUpdate) SetStatus(u uint8) *ServerUpdate {
  33. su.mutation.ResetStatus()
  34. su.mutation.SetStatus(u)
  35. return su
  36. }
  37. // SetNillableStatus sets the "status" field if the given value is not nil.
  38. func (su *ServerUpdate) SetNillableStatus(u *uint8) *ServerUpdate {
  39. if u != nil {
  40. su.SetStatus(*u)
  41. }
  42. return su
  43. }
  44. // AddStatus adds u to the "status" field.
  45. func (su *ServerUpdate) AddStatus(u int8) *ServerUpdate {
  46. su.mutation.AddStatus(u)
  47. return su
  48. }
  49. // ClearStatus clears the value of the "status" field.
  50. func (su *ServerUpdate) ClearStatus() *ServerUpdate {
  51. su.mutation.ClearStatus()
  52. return su
  53. }
  54. // SetDeletedAt sets the "deleted_at" field.
  55. func (su *ServerUpdate) SetDeletedAt(t time.Time) *ServerUpdate {
  56. su.mutation.SetDeletedAt(t)
  57. return su
  58. }
  59. // SetNillableDeletedAt sets the "deleted_at" field if the given value is not nil.
  60. func (su *ServerUpdate) SetNillableDeletedAt(t *time.Time) *ServerUpdate {
  61. if t != nil {
  62. su.SetDeletedAt(*t)
  63. }
  64. return su
  65. }
  66. // ClearDeletedAt clears the value of the "deleted_at" field.
  67. func (su *ServerUpdate) ClearDeletedAt() *ServerUpdate {
  68. su.mutation.ClearDeletedAt()
  69. return su
  70. }
  71. // SetName sets the "name" field.
  72. func (su *ServerUpdate) SetName(s string) *ServerUpdate {
  73. su.mutation.SetName(s)
  74. return su
  75. }
  76. // SetNillableName sets the "name" field if the given value is not nil.
  77. func (su *ServerUpdate) SetNillableName(s *string) *ServerUpdate {
  78. if s != nil {
  79. su.SetName(*s)
  80. }
  81. return su
  82. }
  83. // SetPublicIP sets the "public_ip" field.
  84. func (su *ServerUpdate) SetPublicIP(s string) *ServerUpdate {
  85. su.mutation.SetPublicIP(s)
  86. return su
  87. }
  88. // SetNillablePublicIP sets the "public_ip" field if the given value is not nil.
  89. func (su *ServerUpdate) SetNillablePublicIP(s *string) *ServerUpdate {
  90. if s != nil {
  91. su.SetPublicIP(*s)
  92. }
  93. return su
  94. }
  95. // SetPrivateIP sets the "private_ip" field.
  96. func (su *ServerUpdate) SetPrivateIP(s string) *ServerUpdate {
  97. su.mutation.SetPrivateIP(s)
  98. return su
  99. }
  100. // SetNillablePrivateIP sets the "private_ip" field if the given value is not nil.
  101. func (su *ServerUpdate) SetNillablePrivateIP(s *string) *ServerUpdate {
  102. if s != nil {
  103. su.SetPrivateIP(*s)
  104. }
  105. return su
  106. }
  107. // SetAdminPort sets the "admin_port" field.
  108. func (su *ServerUpdate) SetAdminPort(s string) *ServerUpdate {
  109. su.mutation.SetAdminPort(s)
  110. return su
  111. }
  112. // SetNillableAdminPort sets the "admin_port" field if the given value is not nil.
  113. func (su *ServerUpdate) SetNillableAdminPort(s *string) *ServerUpdate {
  114. if s != nil {
  115. su.SetAdminPort(*s)
  116. }
  117. return su
  118. }
  119. // AddWxIDs adds the "wxs" edge to the Wx entity by IDs.
  120. func (su *ServerUpdate) AddWxIDs(ids ...uint64) *ServerUpdate {
  121. su.mutation.AddWxIDs(ids...)
  122. return su
  123. }
  124. // AddWxs adds the "wxs" edges to the Wx entity.
  125. func (su *ServerUpdate) AddWxs(w ...*Wx) *ServerUpdate {
  126. ids := make([]uint64, len(w))
  127. for i := range w {
  128. ids[i] = w[i].ID
  129. }
  130. return su.AddWxIDs(ids...)
  131. }
  132. // Mutation returns the ServerMutation object of the builder.
  133. func (su *ServerUpdate) Mutation() *ServerMutation {
  134. return su.mutation
  135. }
  136. // ClearWxs clears all "wxs" edges to the Wx entity.
  137. func (su *ServerUpdate) ClearWxs() *ServerUpdate {
  138. su.mutation.ClearWxs()
  139. return su
  140. }
  141. // RemoveWxIDs removes the "wxs" edge to Wx entities by IDs.
  142. func (su *ServerUpdate) RemoveWxIDs(ids ...uint64) *ServerUpdate {
  143. su.mutation.RemoveWxIDs(ids...)
  144. return su
  145. }
  146. // RemoveWxs removes "wxs" edges to Wx entities.
  147. func (su *ServerUpdate) RemoveWxs(w ...*Wx) *ServerUpdate {
  148. ids := make([]uint64, len(w))
  149. for i := range w {
  150. ids[i] = w[i].ID
  151. }
  152. return su.RemoveWxIDs(ids...)
  153. }
  154. // Save executes the query and returns the number of nodes affected by the update operation.
  155. func (su *ServerUpdate) Save(ctx context.Context) (int, error) {
  156. if err := su.defaults(); err != nil {
  157. return 0, err
  158. }
  159. return withHooks(ctx, su.sqlSave, su.mutation, su.hooks)
  160. }
  161. // SaveX is like Save, but panics if an error occurs.
  162. func (su *ServerUpdate) SaveX(ctx context.Context) int {
  163. affected, err := su.Save(ctx)
  164. if err != nil {
  165. panic(err)
  166. }
  167. return affected
  168. }
  169. // Exec executes the query.
  170. func (su *ServerUpdate) Exec(ctx context.Context) error {
  171. _, err := su.Save(ctx)
  172. return err
  173. }
  174. // ExecX is like Exec, but panics if an error occurs.
  175. func (su *ServerUpdate) ExecX(ctx context.Context) {
  176. if err := su.Exec(ctx); err != nil {
  177. panic(err)
  178. }
  179. }
  180. // defaults sets the default values of the builder before save.
  181. func (su *ServerUpdate) defaults() error {
  182. if _, ok := su.mutation.UpdatedAt(); !ok {
  183. if server.UpdateDefaultUpdatedAt == nil {
  184. return fmt.Errorf("ent: uninitialized server.UpdateDefaultUpdatedAt (forgotten import ent/runtime?)")
  185. }
  186. v := server.UpdateDefaultUpdatedAt()
  187. su.mutation.SetUpdatedAt(v)
  188. }
  189. return nil
  190. }
  191. func (su *ServerUpdate) sqlSave(ctx context.Context) (n int, err error) {
  192. _spec := sqlgraph.NewUpdateSpec(server.Table, server.Columns, sqlgraph.NewFieldSpec(server.FieldID, field.TypeUint64))
  193. if ps := su.mutation.predicates; len(ps) > 0 {
  194. _spec.Predicate = func(selector *sql.Selector) {
  195. for i := range ps {
  196. ps[i](selector)
  197. }
  198. }
  199. }
  200. if value, ok := su.mutation.UpdatedAt(); ok {
  201. _spec.SetField(server.FieldUpdatedAt, field.TypeTime, value)
  202. }
  203. if value, ok := su.mutation.Status(); ok {
  204. _spec.SetField(server.FieldStatus, field.TypeUint8, value)
  205. }
  206. if value, ok := su.mutation.AddedStatus(); ok {
  207. _spec.AddField(server.FieldStatus, field.TypeUint8, value)
  208. }
  209. if su.mutation.StatusCleared() {
  210. _spec.ClearField(server.FieldStatus, field.TypeUint8)
  211. }
  212. if value, ok := su.mutation.DeletedAt(); ok {
  213. _spec.SetField(server.FieldDeletedAt, field.TypeTime, value)
  214. }
  215. if su.mutation.DeletedAtCleared() {
  216. _spec.ClearField(server.FieldDeletedAt, field.TypeTime)
  217. }
  218. if value, ok := su.mutation.Name(); ok {
  219. _spec.SetField(server.FieldName, field.TypeString, value)
  220. }
  221. if value, ok := su.mutation.PublicIP(); ok {
  222. _spec.SetField(server.FieldPublicIP, field.TypeString, value)
  223. }
  224. if value, ok := su.mutation.PrivateIP(); ok {
  225. _spec.SetField(server.FieldPrivateIP, field.TypeString, value)
  226. }
  227. if value, ok := su.mutation.AdminPort(); ok {
  228. _spec.SetField(server.FieldAdminPort, field.TypeString, value)
  229. }
  230. if su.mutation.WxsCleared() {
  231. edge := &sqlgraph.EdgeSpec{
  232. Rel: sqlgraph.O2M,
  233. Inverse: false,
  234. Table: server.WxsTable,
  235. Columns: []string{server.WxsColumn},
  236. Bidi: false,
  237. Target: &sqlgraph.EdgeTarget{
  238. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  239. },
  240. }
  241. _spec.Edges.Clear = append(_spec.Edges.Clear, edge)
  242. }
  243. if nodes := su.mutation.RemovedWxsIDs(); len(nodes) > 0 && !su.mutation.WxsCleared() {
  244. edge := &sqlgraph.EdgeSpec{
  245. Rel: sqlgraph.O2M,
  246. Inverse: false,
  247. Table: server.WxsTable,
  248. Columns: []string{server.WxsColumn},
  249. Bidi: false,
  250. Target: &sqlgraph.EdgeTarget{
  251. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  252. },
  253. }
  254. for _, k := range nodes {
  255. edge.Target.Nodes = append(edge.Target.Nodes, k)
  256. }
  257. _spec.Edges.Clear = append(_spec.Edges.Clear, edge)
  258. }
  259. if nodes := su.mutation.WxsIDs(); len(nodes) > 0 {
  260. edge := &sqlgraph.EdgeSpec{
  261. Rel: sqlgraph.O2M,
  262. Inverse: false,
  263. Table: server.WxsTable,
  264. Columns: []string{server.WxsColumn},
  265. Bidi: false,
  266. Target: &sqlgraph.EdgeTarget{
  267. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  268. },
  269. }
  270. for _, k := range nodes {
  271. edge.Target.Nodes = append(edge.Target.Nodes, k)
  272. }
  273. _spec.Edges.Add = append(_spec.Edges.Add, edge)
  274. }
  275. if n, err = sqlgraph.UpdateNodes(ctx, su.driver, _spec); err != nil {
  276. if _, ok := err.(*sqlgraph.NotFoundError); ok {
  277. err = &NotFoundError{server.Label}
  278. } else if sqlgraph.IsConstraintError(err) {
  279. err = &ConstraintError{msg: err.Error(), wrap: err}
  280. }
  281. return 0, err
  282. }
  283. su.mutation.done = true
  284. return n, nil
  285. }
  286. // ServerUpdateOne is the builder for updating a single Server entity.
  287. type ServerUpdateOne struct {
  288. config
  289. fields []string
  290. hooks []Hook
  291. mutation *ServerMutation
  292. }
  293. // SetUpdatedAt sets the "updated_at" field.
  294. func (suo *ServerUpdateOne) SetUpdatedAt(t time.Time) *ServerUpdateOne {
  295. suo.mutation.SetUpdatedAt(t)
  296. return suo
  297. }
  298. // SetStatus sets the "status" field.
  299. func (suo *ServerUpdateOne) SetStatus(u uint8) *ServerUpdateOne {
  300. suo.mutation.ResetStatus()
  301. suo.mutation.SetStatus(u)
  302. return suo
  303. }
  304. // SetNillableStatus sets the "status" field if the given value is not nil.
  305. func (suo *ServerUpdateOne) SetNillableStatus(u *uint8) *ServerUpdateOne {
  306. if u != nil {
  307. suo.SetStatus(*u)
  308. }
  309. return suo
  310. }
  311. // AddStatus adds u to the "status" field.
  312. func (suo *ServerUpdateOne) AddStatus(u int8) *ServerUpdateOne {
  313. suo.mutation.AddStatus(u)
  314. return suo
  315. }
  316. // ClearStatus clears the value of the "status" field.
  317. func (suo *ServerUpdateOne) ClearStatus() *ServerUpdateOne {
  318. suo.mutation.ClearStatus()
  319. return suo
  320. }
  321. // SetDeletedAt sets the "deleted_at" field.
  322. func (suo *ServerUpdateOne) SetDeletedAt(t time.Time) *ServerUpdateOne {
  323. suo.mutation.SetDeletedAt(t)
  324. return suo
  325. }
  326. // SetNillableDeletedAt sets the "deleted_at" field if the given value is not nil.
  327. func (suo *ServerUpdateOne) SetNillableDeletedAt(t *time.Time) *ServerUpdateOne {
  328. if t != nil {
  329. suo.SetDeletedAt(*t)
  330. }
  331. return suo
  332. }
  333. // ClearDeletedAt clears the value of the "deleted_at" field.
  334. func (suo *ServerUpdateOne) ClearDeletedAt() *ServerUpdateOne {
  335. suo.mutation.ClearDeletedAt()
  336. return suo
  337. }
  338. // SetName sets the "name" field.
  339. func (suo *ServerUpdateOne) SetName(s string) *ServerUpdateOne {
  340. suo.mutation.SetName(s)
  341. return suo
  342. }
  343. // SetNillableName sets the "name" field if the given value is not nil.
  344. func (suo *ServerUpdateOne) SetNillableName(s *string) *ServerUpdateOne {
  345. if s != nil {
  346. suo.SetName(*s)
  347. }
  348. return suo
  349. }
  350. // SetPublicIP sets the "public_ip" field.
  351. func (suo *ServerUpdateOne) SetPublicIP(s string) *ServerUpdateOne {
  352. suo.mutation.SetPublicIP(s)
  353. return suo
  354. }
  355. // SetNillablePublicIP sets the "public_ip" field if the given value is not nil.
  356. func (suo *ServerUpdateOne) SetNillablePublicIP(s *string) *ServerUpdateOne {
  357. if s != nil {
  358. suo.SetPublicIP(*s)
  359. }
  360. return suo
  361. }
  362. // SetPrivateIP sets the "private_ip" field.
  363. func (suo *ServerUpdateOne) SetPrivateIP(s string) *ServerUpdateOne {
  364. suo.mutation.SetPrivateIP(s)
  365. return suo
  366. }
  367. // SetNillablePrivateIP sets the "private_ip" field if the given value is not nil.
  368. func (suo *ServerUpdateOne) SetNillablePrivateIP(s *string) *ServerUpdateOne {
  369. if s != nil {
  370. suo.SetPrivateIP(*s)
  371. }
  372. return suo
  373. }
  374. // SetAdminPort sets the "admin_port" field.
  375. func (suo *ServerUpdateOne) SetAdminPort(s string) *ServerUpdateOne {
  376. suo.mutation.SetAdminPort(s)
  377. return suo
  378. }
  379. // SetNillableAdminPort sets the "admin_port" field if the given value is not nil.
  380. func (suo *ServerUpdateOne) SetNillableAdminPort(s *string) *ServerUpdateOne {
  381. if s != nil {
  382. suo.SetAdminPort(*s)
  383. }
  384. return suo
  385. }
  386. // AddWxIDs adds the "wxs" edge to the Wx entity by IDs.
  387. func (suo *ServerUpdateOne) AddWxIDs(ids ...uint64) *ServerUpdateOne {
  388. suo.mutation.AddWxIDs(ids...)
  389. return suo
  390. }
  391. // AddWxs adds the "wxs" edges to the Wx entity.
  392. func (suo *ServerUpdateOne) AddWxs(w ...*Wx) *ServerUpdateOne {
  393. ids := make([]uint64, len(w))
  394. for i := range w {
  395. ids[i] = w[i].ID
  396. }
  397. return suo.AddWxIDs(ids...)
  398. }
  399. // Mutation returns the ServerMutation object of the builder.
  400. func (suo *ServerUpdateOne) Mutation() *ServerMutation {
  401. return suo.mutation
  402. }
  403. // ClearWxs clears all "wxs" edges to the Wx entity.
  404. func (suo *ServerUpdateOne) ClearWxs() *ServerUpdateOne {
  405. suo.mutation.ClearWxs()
  406. return suo
  407. }
  408. // RemoveWxIDs removes the "wxs" edge to Wx entities by IDs.
  409. func (suo *ServerUpdateOne) RemoveWxIDs(ids ...uint64) *ServerUpdateOne {
  410. suo.mutation.RemoveWxIDs(ids...)
  411. return suo
  412. }
  413. // RemoveWxs removes "wxs" edges to Wx entities.
  414. func (suo *ServerUpdateOne) RemoveWxs(w ...*Wx) *ServerUpdateOne {
  415. ids := make([]uint64, len(w))
  416. for i := range w {
  417. ids[i] = w[i].ID
  418. }
  419. return suo.RemoveWxIDs(ids...)
  420. }
  421. // Where appends a list predicates to the ServerUpdate builder.
  422. func (suo *ServerUpdateOne) Where(ps ...predicate.Server) *ServerUpdateOne {
  423. suo.mutation.Where(ps...)
  424. return suo
  425. }
  426. // Select allows selecting one or more fields (columns) of the returned entity.
  427. // The default is selecting all fields defined in the entity schema.
  428. func (suo *ServerUpdateOne) Select(field string, fields ...string) *ServerUpdateOne {
  429. suo.fields = append([]string{field}, fields...)
  430. return suo
  431. }
  432. // Save executes the query and returns the updated Server entity.
  433. func (suo *ServerUpdateOne) Save(ctx context.Context) (*Server, error) {
  434. if err := suo.defaults(); err != nil {
  435. return nil, err
  436. }
  437. return withHooks(ctx, suo.sqlSave, suo.mutation, suo.hooks)
  438. }
  439. // SaveX is like Save, but panics if an error occurs.
  440. func (suo *ServerUpdateOne) SaveX(ctx context.Context) *Server {
  441. node, err := suo.Save(ctx)
  442. if err != nil {
  443. panic(err)
  444. }
  445. return node
  446. }
  447. // Exec executes the query on the entity.
  448. func (suo *ServerUpdateOne) Exec(ctx context.Context) error {
  449. _, err := suo.Save(ctx)
  450. return err
  451. }
  452. // ExecX is like Exec, but panics if an error occurs.
  453. func (suo *ServerUpdateOne) ExecX(ctx context.Context) {
  454. if err := suo.Exec(ctx); err != nil {
  455. panic(err)
  456. }
  457. }
  458. // defaults sets the default values of the builder before save.
  459. func (suo *ServerUpdateOne) defaults() error {
  460. if _, ok := suo.mutation.UpdatedAt(); !ok {
  461. if server.UpdateDefaultUpdatedAt == nil {
  462. return fmt.Errorf("ent: uninitialized server.UpdateDefaultUpdatedAt (forgotten import ent/runtime?)")
  463. }
  464. v := server.UpdateDefaultUpdatedAt()
  465. suo.mutation.SetUpdatedAt(v)
  466. }
  467. return nil
  468. }
  469. func (suo *ServerUpdateOne) sqlSave(ctx context.Context) (_node *Server, err error) {
  470. _spec := sqlgraph.NewUpdateSpec(server.Table, server.Columns, sqlgraph.NewFieldSpec(server.FieldID, field.TypeUint64))
  471. id, ok := suo.mutation.ID()
  472. if !ok {
  473. return nil, &ValidationError{Name: "id", err: errors.New(`ent: missing "Server.id" for update`)}
  474. }
  475. _spec.Node.ID.Value = id
  476. if fields := suo.fields; len(fields) > 0 {
  477. _spec.Node.Columns = make([]string, 0, len(fields))
  478. _spec.Node.Columns = append(_spec.Node.Columns, server.FieldID)
  479. for _, f := range fields {
  480. if !server.ValidColumn(f) {
  481. return nil, &ValidationError{Name: f, err: fmt.Errorf("ent: invalid field %q for query", f)}
  482. }
  483. if f != server.FieldID {
  484. _spec.Node.Columns = append(_spec.Node.Columns, f)
  485. }
  486. }
  487. }
  488. if ps := suo.mutation.predicates; len(ps) > 0 {
  489. _spec.Predicate = func(selector *sql.Selector) {
  490. for i := range ps {
  491. ps[i](selector)
  492. }
  493. }
  494. }
  495. if value, ok := suo.mutation.UpdatedAt(); ok {
  496. _spec.SetField(server.FieldUpdatedAt, field.TypeTime, value)
  497. }
  498. if value, ok := suo.mutation.Status(); ok {
  499. _spec.SetField(server.FieldStatus, field.TypeUint8, value)
  500. }
  501. if value, ok := suo.mutation.AddedStatus(); ok {
  502. _spec.AddField(server.FieldStatus, field.TypeUint8, value)
  503. }
  504. if suo.mutation.StatusCleared() {
  505. _spec.ClearField(server.FieldStatus, field.TypeUint8)
  506. }
  507. if value, ok := suo.mutation.DeletedAt(); ok {
  508. _spec.SetField(server.FieldDeletedAt, field.TypeTime, value)
  509. }
  510. if suo.mutation.DeletedAtCleared() {
  511. _spec.ClearField(server.FieldDeletedAt, field.TypeTime)
  512. }
  513. if value, ok := suo.mutation.Name(); ok {
  514. _spec.SetField(server.FieldName, field.TypeString, value)
  515. }
  516. if value, ok := suo.mutation.PublicIP(); ok {
  517. _spec.SetField(server.FieldPublicIP, field.TypeString, value)
  518. }
  519. if value, ok := suo.mutation.PrivateIP(); ok {
  520. _spec.SetField(server.FieldPrivateIP, field.TypeString, value)
  521. }
  522. if value, ok := suo.mutation.AdminPort(); ok {
  523. _spec.SetField(server.FieldAdminPort, field.TypeString, value)
  524. }
  525. if suo.mutation.WxsCleared() {
  526. edge := &sqlgraph.EdgeSpec{
  527. Rel: sqlgraph.O2M,
  528. Inverse: false,
  529. Table: server.WxsTable,
  530. Columns: []string{server.WxsColumn},
  531. Bidi: false,
  532. Target: &sqlgraph.EdgeTarget{
  533. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  534. },
  535. }
  536. _spec.Edges.Clear = append(_spec.Edges.Clear, edge)
  537. }
  538. if nodes := suo.mutation.RemovedWxsIDs(); len(nodes) > 0 && !suo.mutation.WxsCleared() {
  539. edge := &sqlgraph.EdgeSpec{
  540. Rel: sqlgraph.O2M,
  541. Inverse: false,
  542. Table: server.WxsTable,
  543. Columns: []string{server.WxsColumn},
  544. Bidi: false,
  545. Target: &sqlgraph.EdgeTarget{
  546. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  547. },
  548. }
  549. for _, k := range nodes {
  550. edge.Target.Nodes = append(edge.Target.Nodes, k)
  551. }
  552. _spec.Edges.Clear = append(_spec.Edges.Clear, edge)
  553. }
  554. if nodes := suo.mutation.WxsIDs(); len(nodes) > 0 {
  555. edge := &sqlgraph.EdgeSpec{
  556. Rel: sqlgraph.O2M,
  557. Inverse: false,
  558. Table: server.WxsTable,
  559. Columns: []string{server.WxsColumn},
  560. Bidi: false,
  561. Target: &sqlgraph.EdgeTarget{
  562. IDSpec: sqlgraph.NewFieldSpec(wx.FieldID, field.TypeUint64),
  563. },
  564. }
  565. for _, k := range nodes {
  566. edge.Target.Nodes = append(edge.Target.Nodes, k)
  567. }
  568. _spec.Edges.Add = append(_spec.Edges.Add, edge)
  569. }
  570. _node = &Server{config: suo.config}
  571. _spec.Assign = _node.assignValues
  572. _spec.ScanValues = _node.scanValues
  573. if err = sqlgraph.UpdateNode(ctx, suo.driver, _spec); err != nil {
  574. if _, ok := err.(*sqlgraph.NotFoundError); ok {
  575. err = &NotFoundError{server.Label}
  576. } else if sqlgraph.IsConstraintError(err) {
  577. err = &ConstraintError{msg: err.Error(), wrap: err}
  578. }
  579. return nil, err
  580. }
  581. suo.mutation.done = true
  582. return _node, nil
  583. }