SmsTemplate.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use Yii;
  5. /**
  6. * This is the model class for table "{{%SMS_TEMPLATE}}".
  7. *
  8. * @property string $ID
  9. * @property string $TITLE 标题
  10. * @property string $DESCRIPTION 描述
  11. * @property string $FIELD 标题英文字段
  12. * @property string $DEC_LEVEL 报单级别
  13. * @property string $EMP_LEVEL 聘级
  14. * @property string $CONTENT 模板内容
  15. * @property int $CREATED_AT 创建时间
  16. */
  17. class SmsTemplate extends \common\components\ActiveRecord
  18. {
  19. /**
  20. * @inheritdoc
  21. */
  22. public static function tableName()
  23. {
  24. return '{{%SMS_TEMPLATE}}';
  25. }
  26. /**
  27. * @inheritdoc
  28. */
  29. public function rules()
  30. {
  31. return [
  32. [['TITLE', 'DESCRIPTION', 'FIELD', 'CONTENT', 'CREATED_AT'], 'required'],
  33. [['CREATED_AT'], 'integer'],
  34. [['ID', 'TITLE', 'DEC_LEVEL', 'EMP_LEVEL'], 'string', 'max' => 32],
  35. [['DESCRIPTION', 'FIELD', 'CONTENT'], 'string', 'max' => 255],
  36. [['ID'], 'unique'],
  37. ];
  38. }
  39. /**
  40. * @inheritdoc
  41. */
  42. public function attributeLabels()
  43. {
  44. return [
  45. 'ID' => 'ID',
  46. 'TITLE' => '标题',
  47. 'DESCRIPTION' => '描述',
  48. 'FIELD' => '标题英文字段',
  49. 'DEC_LEVEL' => '报单级别',
  50. 'EMP_LEVEL' => '聘级',
  51. 'CONTENT' => '模板内容',
  52. 'CREATED_AT' => '创建时间',
  53. ];
  54. }
  55. /**
  56. * 通过报单级别的索引来获取短信模板
  57. * @return array
  58. */
  59. public static function getTemplateByDecLevel(){
  60. $allDecLevelData = static::find()->select('DEC_LEVEL')->where('DEC_LEVEL IS NOT NULL')->asArray()->groupBy('DEC_LEVEL')->all();
  61. $result = [];
  62. foreach($allDecLevelData as $levelData){
  63. $result[$levelData['DEC_LEVEL']] = [];
  64. }
  65. $allData = static::find()->where('DEC_LEVEL IS NOT NULL')->asArray()->all();
  66. foreach ($allData as $data){
  67. if(isset($result[$data['DEC_LEVEL']])){
  68. $result[$data['DEC_LEVEL']][$data['FIELD']] = $data;
  69. }
  70. }
  71. return $result;
  72. }
  73. /**
  74. * 通过聘级的索引来获取短信模板
  75. * @return array
  76. */
  77. public static function getTemplateByEmpLevel(){
  78. $allEmpLevelData = static::find()->select('EMP_LEVEL')->where('EMP_LEVEL IS NOT NULL')->asArray()->groupBy('EMP_LEVEL')->all();
  79. $result = [];
  80. foreach($allEmpLevelData as $levelData){
  81. $result[$levelData['EMP_LEVEL']] = [];
  82. }
  83. $allData = static::find()->where('EMP_LEVEL IS NOT NULL')->asArray()->all();
  84. foreach ($allData as $data){
  85. if(isset($result[$data['EMP_LEVEL']])){
  86. $result[$data['EMP_LEVEL']][] = $data;
  87. }
  88. }
  89. return $result;
  90. }
  91. /**
  92. * 从缓存获取报单级别的短信模板
  93. * @return array|mixed
  94. */
  95. public static function getDecFromCache(){
  96. $data = Yii::$app->cache->get(Cache::SMS_TEMPLATE_DEC_KEY);
  97. if(!$data){
  98. // 获取信息
  99. $data = self::getTemplateByDecLevel();
  100. Yii::$app->cache->set(Cache::SMS_TEMPLATE_DEC_KEY, $data);
  101. }
  102. return $data;
  103. }
  104. /**
  105. * 从缓存获取报单级别的短信模板
  106. * @return array|mixed
  107. */
  108. public static function getEmpFromCache(){
  109. $data = Yii::$app->cache->get(Cache::SMS_TEMPLATE_EMP_KEY);
  110. if(!$data){
  111. // 获取信息
  112. $data = self::getTemplateByEmpLevel();
  113. Yii::$app->cache->set(Cache::SMS_TEMPLATE_EMP_KEY, $data);
  114. }
  115. return $data;
  116. }
  117. /**
  118. * 更新报单级别的短信模板
  119. * @return array
  120. */
  121. public static function updateDecToCache(){
  122. // 获取配置
  123. $data = self::getTemplateByDecLevel();
  124. Yii::$app->cache->set(Cache::SMS_TEMPLATE_DEC_KEY, $data);
  125. return $data;
  126. }
  127. /**
  128. * 更新聘级的短信模板
  129. * @return array
  130. */
  131. public static function updateEmpToCache(){
  132. // 获取配置
  133. $data = self::getTemplateByEmpLevel();
  134. Yii::$app->cache->set(Cache::SMS_TEMPLATE_EMP_KEY, $data);
  135. return $data;
  136. }
  137. }