User.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package com.izouma.nineth.domain;
  2. import com.alibaba.excel.annotation.ExcelIgnore;
  3. import com.fasterxml.jackson.annotation.JsonIgnore;
  4. import com.fasterxml.jackson.annotation.JsonView;
  5. import com.fasterxml.jackson.databind.annotation.JsonSerialize;
  6. import com.izouma.nineth.JsonView.UserView;
  7. import com.izouma.nineth.annotations.Searchable;
  8. import com.izouma.nineth.enums.AuthStatus;
  9. import com.izouma.nineth.security.Authority;
  10. import com.izouma.nineth.utils.UserAuthoritySerializer;
  11. import io.swagger.annotations.ApiModel;
  12. import io.swagger.annotations.ApiModelProperty;
  13. import lombok.AllArgsConstructor;
  14. import lombok.Builder;
  15. import lombok.Data;
  16. import lombok.NoArgsConstructor;
  17. import org.hibernate.annotations.BatchSize;
  18. import javax.persistence.*;
  19. import javax.validation.constraints.Size;
  20. import java.io.Serializable;
  21. import java.math.BigDecimal;
  22. import java.util.HashSet;
  23. import java.util.Set;
  24. @Data
  25. @Entity
  26. @Table(indexes = {
  27. @Index(columnList = "phone", unique = true, name = "user_index_phone"),
  28. @Index(columnList = "collectionId"),
  29. @Index(columnList = "collectionInvitor"),
  30. @Index(columnList = "admin"),
  31. @Index(columnList = "minter"),
  32. @Index(columnList = "createdAt"),
  33. @Index(columnList = "settleAccountId")
  34. })
  35. @AllArgsConstructor
  36. @NoArgsConstructor
  37. @Builder
  38. @ApiModel(value = "用户", description = "用户")
  39. public class User extends BaseEntityNoID implements Serializable {
  40. @Id
  41. // @GenericGenerator(
  42. // name = "some_column_name_id_generator",
  43. // strategy = "com.github.marschall.hibernate.batchsequencegenerator.BatchSequenceGenerator",
  44. // parameters = {
  45. // @org.hibernate.annotations.Parameter(name = "sequence", value = "user_sequence"),
  46. // @org.hibernate.annotations.Parameter(name = "fetch_size", value = "50")
  47. // })
  48. // @GeneratedValue(generator = "user_id_generator")
  49. @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "user_seq")
  50. @SequenceGenerator(name = "user_seq", sequenceName = "user_seq", allocationSize = 100, initialValue = 1890000)
  51. // @GeneratedValue(strategy = GenerationType.IDENTITY)
  52. private Long id;
  53. // @Pattern(regexp = Constants.Regex.USERNAME)
  54. @Size(min = 1, max = 50)
  55. @Column(nullable = false, unique = true)
  56. @Searchable
  57. private String username;
  58. @Searchable
  59. private String nickname;
  60. private String avatar;
  61. @JsonView(UserView.Redis.class)
  62. private String password;
  63. private boolean del = false;
  64. @ManyToMany(fetch = FetchType.EAGER, cascade = {CascadeType.DETACH})
  65. @JoinTable(
  66. name = "user_authority",
  67. joinColumns = {@JoinColumn(name = "user_id", referencedColumnName = "id", foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT))},
  68. inverseJoinColumns = {@JoinColumn(name = "authority_name", referencedColumnName = "name", foreignKey = @ForeignKey(name = "none", value = ConstraintMode.NO_CONSTRAINT))})
  69. @BatchSize(size = 20)
  70. @ExcelIgnore
  71. @JsonSerialize(using = UserAuthoritySerializer.class, as = HashSet.class)
  72. private Set<Authority> authorities = new HashSet<>();
  73. private String openId;
  74. private String sex;
  75. private String language;
  76. private String city;
  77. private String province;
  78. private String country;
  79. @Searchable
  80. private String phone;
  81. private String email;
  82. @ApiModelProperty("关注数量")
  83. private int follows;
  84. @ApiModelProperty("粉丝数量")
  85. private int followers;
  86. private int sales;
  87. @Column(columnDefinition = "TEXT")
  88. private String intro;
  89. private String bg;
  90. private Long authId;
  91. @ApiModelProperty("实名审核状态")
  92. @Enumerated(EnumType.STRING)
  93. private AuthStatus authStatus;
  94. private String nftAccount;
  95. @JsonIgnore
  96. private String kmsId;
  97. @JsonIgnore
  98. private String publicKey;
  99. @JsonIgnore
  100. private String tradeCode;
  101. private boolean admin;
  102. @ApiModelProperty("分成比例")
  103. @Column(precision = 10, scale = 2)
  104. private BigDecimal shareRatio;
  105. private String memberId;
  106. private String settleAccountId;
  107. private String invitorName;
  108. private String invitorPhone;
  109. private String inviteCode;
  110. @ApiModelProperty("分享藏品邀请者")
  111. private Long collectionInvitor;
  112. @ApiModelProperty("藏品Id")
  113. private Long collectionId;
  114. @ApiModelProperty("勋章等级")
  115. private int level;
  116. @ApiModelProperty("优先购买")
  117. private int vipPurchase;
  118. private boolean minter;
  119. @Column(columnDefinition = "bit default false")
  120. @ApiModelProperty("使用藏品图片")
  121. private boolean useCollectionPic;
  122. @Column(columnDefinition = "int(11) default 0")
  123. @ApiModelProperty("白名单积分")
  124. private int vipPoint = 0;
  125. @ApiModelProperty(value = "风险提示")
  126. private Boolean riskWarning;
  127. }