Admin.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. <?php
  2. namespace backendApi\modules\v1\models;
  3. use common\components\ActiveRecord;
  4. use common\libs\logging\operate\valueType\Config as ValueTypeConfig;
  5. /**
  6. * This is the model class for table "{{%ADMIN}}".
  7. *
  8. * @property string $ID
  9. * @property string $ADMIN_NAME 用户名
  10. * @property string $REAL_NAME 会员姓名
  11. * @property string $REMARK 备注
  12. * @property string $ROLE_ID 角色ID
  13. * @property int $IS_ENABLE 是否启用
  14. * @property string $AUTH_KEY 认证KEY
  15. * @property string $PASSWORD_HASH 密码
  16. * @property string $PASSWORD_RESET_TOKEN 重设密码TOKEN
  17. * @property int $DONT_DEL 不可删除
  18. * @property int $IS_DEL 是否删除
  19. * @property int $LOGIN_NUMS 登录次数
  20. * @property int $FAIL_NUMS 登录失败次数
  21. * @property string $LAST_LOGIN_IP 上次登录IP
  22. * @property int $LAST_LOGIN_AT 上次登录时间
  23. * @property string $BIND_IP 绑定IP
  24. * @property string EMAIL 邮箱
  25. * @property string $CREATE_ADMIN 创建管理员
  26. * @property string $UPDATE_ADMIN 更新管理员
  27. * @property int $CREATED_AT 创建时间
  28. * @property int $UPDATED_AT 更新时间
  29. * @property int $DELETED_AT 删除时间
  30. * @property int $IS_MODIFY_PASSWORD 是否修改密码
  31. */
  32. class Admin extends ActiveRecord
  33. {
  34. /**
  35. * @inheritdoc
  36. */
  37. public static function tableName()
  38. {
  39. return '{{%ADMIN}}';
  40. }
  41. /**
  42. * {@inheritdoc}
  43. */
  44. public function rules()
  45. {
  46. return [
  47. [['ADMIN_NAME', 'REAL_NAME', 'ROLE_ID', 'PASSWORD_HASH', 'CREATE_ADMIN', 'CREATED_AT'], 'required'],
  48. [['IS_ENABLE', 'DONT_DEL', 'IS_DEL', 'LOGIN_NUMS', 'FAIL_NUMS', 'LAST_LOGIN_AT', 'CREATED_AT', 'UPDATED_AT', 'DELETED_AT', 'IS_MODIFY_PASSWORD'], 'integer'],
  49. [['ID', 'ROLE_ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  50. [['ADMIN_NAME', 'REMARK', 'AUTH_KEY', 'PASSWORD_HASH', 'PASSWORD_RESET_TOKEN'], 'string', 'max' => 255],
  51. [['REAL_NAME'], 'string', 'max' => 128],
  52. [['LAST_LOGIN_IP'], 'string', 'max' => 16],
  53. [['BIND_IP'], 'string', 'max' => 4000],
  54. [['ADMIN_NAME'], 'unique'],
  55. [['ID'], 'unique'],
  56. ];
  57. }
  58. /**
  59. * {@inheritdoc}
  60. */
  61. public function attributeLabels()
  62. {
  63. return [
  64. 'ID' => 'ID',
  65. 'ADMIN_NAME' => '用户名',
  66. 'REAL_NAME' => '会员姓名',
  67. 'REMARK' => '备注',
  68. 'ROLE_ID' => '角色ID',
  69. 'IS_ENABLE' => '是否启用',
  70. 'AUTH_KEY' => '认证KEY',
  71. 'PASSWORD_HASH' => '密码',
  72. 'PASSWORD_RESET_TOKEN' => '重设密码TOKEN',
  73. 'DONT_DEL' => '不可删除',
  74. 'IS_DEL' => '是否删除',
  75. 'LOGIN_NUMS' => '登录次数',
  76. 'FAIL_NUMS' => '登录失败次数',
  77. 'LAST_LOGIN_IP' => '上次登录IP',
  78. 'LAST_LOGIN_AT' => '上次登录时间',
  79. 'BIND_IP' => '绑定IP',
  80. 'EMAIL' => '邮箱',
  81. 'CREATE_ADMIN' => '创建管理员',
  82. 'UPDATE_ADMIN' => '更新管理员',
  83. 'CREATED_AT' => '创建时间',
  84. 'UPDATED_AT' => '更新时间',
  85. 'DELETED_AT' => '删除时间',
  86. 'IS_MODIFY_PASSWORD' => '是否修改密码',
  87. ];
  88. }
  89. /**
  90. * Validates password
  91. *
  92. * @param string $password password to validate
  93. * @return bool if password provided is valid for current user
  94. */
  95. public function validatePassword($password) {
  96. return \Yii::$app->security->validatePassword($password, $this->PASSWORD_HASH);
  97. }
  98. /**
  99. * verificationPassword
  100. *
  101. * @param string $password password to validate
  102. * @return bool if password provided is valid for current user
  103. */
  104. public function verificationPassword($password,$scenario,$model)
  105. {
  106. // 判断密码长度不能少于8位
  107. if (strlen($password) < 8){
  108. return [ 'code' => 1000, 'type' => $scenario , 'message' => '登录密码不能小于8位' ];
  109. }
  110. // 判断密码中数字、大写字母、小写字母、特殊字符至少三种
  111. $symbol = '`~!@#$^&*()=|{}\'\":;\',\\[\\].<>\/?~!@#¥……&*()——|{}【】‘;:”。,、?';
  112. // $requiredRules = '/^(?![\d]+$)(?![a-z]+$)(?![A-Z]+$)(?!['.$symbol.']+$)[\da-zA-z'.$symbol.']{8,}$/'; // 这是两种的正则
  113. $requiredRules = '/^(?![\da-z]+$)(?![\dA-Z]+$)(?![\d'.$symbol.']+$)(?![a-zA-Z]+$)(?![a-z'.$symbol.']+$)(?![A-Z'.$symbol.']+$)[\da-zA-z'.$symbol.']{8,}$/';
  114. $requiredHandleResults = preg_match($requiredRules,$password);
  115. if (!$requiredHandleResults){
  116. return [ 'code' => 1000, 'type' => $scenario , 'message' => '登录密码中需要包含数字、大写字母、小写字母、特殊字符至少三种' ];
  117. }
  118. // 判断有三位以上重复性
  119. if(preg_match('/(\w)*(\w)\1{2}(\w)*/',$password)) {
  120. return [ 'code' => 1000, 'type' => $scenario , 'message' => '登录密码中数字、大写字母、小写字母不能连续重复三个以上' ];
  121. }
  122. // 判断密码中不能出现登录账号
  123. if (strpos($password, $model->ADMIN_NAME) !== false){
  124. return [ 'code' => 1000, 'type' => $scenario , 'message' => '登录密码中不允许出现管理员的登录账号信息' ];
  125. }
  126. return [ 'code' => 200, 'type' => $scenario , 'message' => '验证通过了' ];
  127. }
  128. /**
  129. * 根据用户名查找
  130. * @param $username
  131. * @return array|null|\yii\db\ActiveRecord
  132. */
  133. public static function findByUsername($username){
  134. $row = static::find()->selectNoText()->where('ADMIN_NAME=:ADMIN_NAME', [':ADMIN_NAME'=>trim($username)])->one();
  135. return $row;
  136. }
  137. /**
  138. * 获取ID
  139. * @param $adminName
  140. * @return string|null
  141. */
  142. public static function getIdByAdminName($adminName) {
  143. $data = self::findOneAsArray('ADMIN_NAME=:ADMIN_NAME', [':ADMIN_NAME' => $adminName], 'ID');
  144. return $data ? $data['ID'] : null;
  145. }
  146. /**
  147. * 获取管理员名通过ID
  148. * @param $id
  149. * @return string|null
  150. */
  151. public static function getAdminNameById($id){
  152. $data = self::findOneAsArray('ID=:ID', [':ID' => $id], 'ADMIN_NAME');
  153. return $data ? $data['ADMIN_NAME'] : null;
  154. }
  155. /**
  156. * 操作日志记录条件
  157. * @return array
  158. */
  159. public function attrLabelsWithLogType(){
  160. return [
  161. 'ADMIN_NAME' => '用户名',
  162. 'REAL_NAME' => '会员姓名',
  163. 'REMARK' => '备注',
  164. 'ROLE_ID' => [
  165. 'label' => '角色名称',
  166. 'type' => function($data){
  167. $value = isset($data['value']) ? $data['value'] : '';
  168. $result = AdminRole::findOneAsArray('ID=:ID', [':ID'=>$value], 'ROLE_NAME');
  169. return !empty($result) ? $result['ROLE_NAME'] : '';
  170. },
  171. ],
  172. 'IS_ENABLE' => [
  173. 'label' => '是否启用',
  174. 'type' => ValueTypeConfig::YES_NO_TYPE,
  175. ],
  176. 'BIND_IP' => '绑定IP',
  177. 'EMAIL' => '邮箱',
  178. 'CREATE_ADMIN' => [
  179. 'label' => '创建人',
  180. 'type' => function($data){
  181. $value = isset($data['value']) ? $data['value'] : '';
  182. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  183. return !empty($result) ? $result['ADMIN_NAME'] : '';
  184. },
  185. ],
  186. 'UPDATE_ADMIN' => [
  187. 'label' => '更新人',
  188. 'type' => function($data){
  189. $value = isset($data['value']) ? $data['value'] : '';
  190. $result = Admin::findOneAsArray('ID=:ID', [':ID'=>$value], 'ADMIN_NAME');
  191. return !empty($result) ? $result['ADMIN_NAME'] : '';
  192. },
  193. ],
  194. 'CREATED_AT' => [
  195. 'label' => '创建时间',
  196. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  197. ],
  198. 'UPDATED_AT' => [
  199. 'label' => '更新时间',
  200. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  201. ],
  202. 'IS_MODIFY_PASSWORD' => [
  203. 'label' => '是否修改密码',
  204. 'type' => ValueTypeConfig::YES_NO_TYPE,
  205. ],
  206. ];
  207. }
  208. }