DecRole.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use Yii;
  5. /**
  6. * This is the model class for table "{{%DEC_ROLE}}".
  7. *
  8. * @property string $ID
  9. * @property string $ROLE_NAME 名称
  10. * @property string $FW_BONUS_PERCENT 店补比例
  11. * @property string $SORT 排序
  12. * @property int $CREATED_AT 创建时间
  13. * @property int $UPDATED_AT 更新时间
  14. * @property string $UPDATER 更新人
  15. * @property string $ADM_NAME 操作人
  16. */
  17. class DecRole extends \common\components\ActiveRecord
  18. {
  19. /**
  20. * @inheritdoc
  21. */
  22. public static function tableName()
  23. {
  24. return '{{%DEC_ROLE}}';
  25. }
  26. /**
  27. * @inheritdoc
  28. */
  29. public function rules()
  30. {
  31. return [
  32. [['ROLE_NAME', 'ADM_NAME'], 'required'],
  33. [['FW_BONUS_PERCENT'], 'number'],
  34. [['SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  35. [['ID'], 'string', 'max' => 32],
  36. [['ROLE_NAME'], 'string', 'max' => 255],
  37. [['UPDATER', 'ADM_NAME'], 'string', 'max' => 16],
  38. [['ID'], 'unique'],
  39. ];
  40. }
  41. /**
  42. * @inheritdoc
  43. */
  44. public function attributeLabels()
  45. {
  46. return [
  47. 'ID' => 'ID',
  48. 'ROLE_NAME' => '名称',
  49. 'FW_BONUS_PERCENT' => '推荐奖比例',
  50. 'SORT' => '排序',
  51. 'CREATED_AT' => '创建时间',
  52. 'UPDATED_AT' => '更新时间',
  53. 'UPDATER' => '更新人',
  54. 'ADM_NAME' => '操作人',
  55. ];
  56. }
  57. /**
  58. * 从缓存获取信息
  59. * @return array|mixed|\yii\db\ActiveRecord[]
  60. */
  61. public static function getFromCache(){
  62. $data = Yii::$app->cache->get(Cache::DEC_ROLE_CONFIG_KEY);
  63. if(!$data){
  64. // 获取信息
  65. $data = static::find()->where('1=1')->orderBy('SORT ASC')->indexBy('ID')->asArray()->all();
  66. Yii::$app->cache->set(Cache::DEC_ROLE_CONFIG_KEY, $data);
  67. }
  68. // i18n转换
  69. foreach ($data as &$item) {
  70. $item['ROLE_NAME'] = Yii::t('ctx', $item['LANGUAGE_KEY']);
  71. }
  72. return $data;
  73. }
  74. /**
  75. * 获取所有数据
  76. * @return array|\yii\db\ActiveRecord[]
  77. */
  78. public static function getAllData(){
  79. return static::find()->where('1=1')->indexBy('ID')->asArray()->all();
  80. }
  81. /**
  82. * 通过会员ID获取报单中心级别ID
  83. * @param $userId
  84. * @return mixed
  85. */
  86. public static function getRoleIdFromUserId($userId){
  87. $data = User::findOneAsArray('ID=:ID', [':ID'=>$userId], 'DEC_ROLE_ID');
  88. return $data['DEC_ROLE_ID'];
  89. }
  90. /**
  91. * 通过会员ID获得报单中心级别名称
  92. * @param $userId
  93. * @return string
  94. */
  95. public static function getRoleNameFromUserId($userId){
  96. $roleId = self::getRoleIdFromUserId($userId);
  97. if($roleId){
  98. $role = self::findOneAsArray('ID=:ID', [':ID'=>$roleId]);
  99. return $role ? $role['ROLE_NAME'] : '';
  100. } else {
  101. return null;
  102. }
  103. }
  104. /**
  105. * 报单级别名称
  106. * @param $roleId
  107. * @return string
  108. */
  109. public static function getRoleNameId($roleId){
  110. $role = self::findOneAsArray('ID=:ID', [':ID'=>$roleId]);
  111. return $role ? $role['ROLE_NAME'] : '';
  112. }
  113. /**
  114. * 更新缓存
  115. * @return array|\yii\db\ActiveRecord[]
  116. */
  117. public static function updateToCache(){
  118. // 获取配置
  119. $data = static::find()->where('1=1')->orderBy('SORT ASC')->asArray()->indexBy('ID')->all();
  120. Yii::$app->cache->set(Cache::DEC_ROLE_CONFIG_KEY, $data);
  121. return $data;
  122. }
  123. }