OcrApi.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use Yii;
  5. use yii\helpers\Json;
  6. /**
  7. * This is the model class for table "{{%OCR_API}}".
  8. *
  9. * @property string $ID
  10. * @property string $API_NAME 文件名称
  11. * @property string $DESCRIPTION 分类
  12. * @property string $CONFIG 备注
  13. * @property int $STATUS 文件路径
  14. * @property string $CREATE_ADMIN 创建管理员
  15. * @property string $UPDATE_ADMIN 更新管理员
  16. * @property int $CREATED_AT 创建时间
  17. * @property int $UPDATED_AT 更新时间
  18. */
  19. class OcrApi extends \common\components\ActiveRecord
  20. {
  21. /**
  22. * @inheritdoc
  23. */
  24. public static function tableName()
  25. {
  26. return '{{%OCR_API}}';
  27. }
  28. /**
  29. * @inheritdoc
  30. */
  31. public function rules()
  32. {
  33. return [
  34. [['API_NAME', 'DESCRIPTION', 'CREATE_ADMIN', 'CREATED_AT'], 'required'],
  35. [['STATUS', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  36. [['ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  37. [['API_NAME'], 'string', 'max' => 48],
  38. [['DESCRIPTION'], 'string', 'max' => 255],
  39. [['CONFIG'], 'string', 'max' => 4000],
  40. [['API_NAME'], 'unique'],
  41. [['ID'], 'unique'],
  42. ];
  43. }
  44. /**
  45. * @inheritdoc
  46. */
  47. public function attributeLabels()
  48. {
  49. return [
  50. 'ID' => 'ID',
  51. 'API_NAME' => '文件名称',
  52. 'DESCRIPTION' => '分类',
  53. 'CONFIG' => '备注',
  54. 'STATUS' => '文件路径',
  55. 'CREATE_ADMIN' => '创建管理员',
  56. 'UPDATE_ADMIN' => '更新管理员',
  57. 'CREATED_AT' => '创建时间',
  58. 'UPDATED_AT' => '更新时间',
  59. ];
  60. }
  61. /**
  62. * 获取全部数据
  63. * @return array|\yii\db\ActiveRecord[]
  64. */
  65. public static function getAllData(){
  66. $allData = static::find()->where('1=1')->orderBy('CREATED_AT ASC')->indexBy('API_NAME')->asArray()->all();
  67. foreach($allData as $key=>$data){
  68. if($data['CONFIG']){
  69. $allData[$key]['CONFIG'] = Json::decode($data['CONFIG']);
  70. } else{
  71. $allData[$key]['CONFIG'] = [];
  72. }
  73. }
  74. return $allData;
  75. }
  76. /**
  77. * 获取当前正在启用的接口
  78. * @return array
  79. */
  80. public static function getActiveData(){
  81. $data = static::find()->where('STATUS=:STATUS', [':STATUS' => 1])->orderBy('CREATED_AT ASC')->asArray()->one();
  82. if($data['CONFIG']){
  83. $data['CONFIG'] = Json::decode($data['CONFIG']);
  84. } else {
  85. $data['CONFIG'] = null;
  86. }
  87. return $data;
  88. }
  89. /**
  90. * 从缓存获取信息
  91. * @return array|mixed|\yii\db\ActiveRecord[]
  92. */
  93. public static function getFromCache(){
  94. $data = Yii::$app->cache->get(Cache::OCR_API_CONFIG_KEY);
  95. if(!$data){
  96. // 获取信息
  97. $data = self::getActiveData();
  98. Yii::$app->cache->set(Cache::OCR_API_CONFIG_KEY, $data);
  99. }
  100. return $data;
  101. }
  102. /**
  103. * 更新缓存
  104. * @return array|\yii\db\ActiveRecord[]
  105. */
  106. public static function updateToCache(){
  107. // 获取配置
  108. $data = self::getActiveData();
  109. Yii::$app->cache->set(Cache::OCR_API_CONFIG_KEY, $data);
  110. return $data;
  111. }
  112. /**
  113. * 按id获取配置
  114. * @param $id
  115. * @return array
  116. */
  117. public static function getConfigById($id) {
  118. $smsApi = self::findOneAsArray('ID=:ID',[':ID'=>$id],'CONFIG');
  119. $config = json_decode($smsApi['CONFIG'],true);
  120. $data = [];
  121. foreach ($config as $key=>$value){
  122. $data[$key]['label'] = $key;
  123. $data[$key]['value'] = $value;
  124. }
  125. return $data;
  126. }
  127. }