OfficialAccount.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <?php
  2. namespace App\Modules\OfficialAccount\Models;
  3. use DB;
  4. use Illuminate\Database\Eloquent\Model;
  5. class OfficialAccount extends Model
  6. {
  7. protected $tables = 'official_accounts';
  8. protected $fillable = ['distribution_channel_id', 'nickname', 'name', 'head_img', 'appid', 'appsecret', 'verify_txt', 'alias', 'qrcode_url', 'principal_name', 'service_type_info', 'func_info', 'authorizer_refresh_token', 'is_auth', 'cancel_auth_time', 'official_account_type', 'verify_type_info', 'subscribe_top_num', 'subscribe_day_maximum', 'sort_no', 'is_enabled'];
  9. /**
  10. * 根据appid获取公众号
  11. */
  12. static function officialAccountByAppid($appid)
  13. {
  14. return self::where('appid', isset($appid) ? $appid : '')->first();
  15. }
  16. /**
  17. * 根据appid获取公众号
  18. */
  19. static function officialAccountArrByAppid($appid) {
  20. $official_account = self::where('appid', isset($appid) ? $appid : '')->first();
  21. if(!empty($official_account)){
  22. return $official_account->toArray();
  23. }else{
  24. return null;
  25. }
  26. }
  27. /**
  28. * 获取所有公众号
  29. */
  30. static function getAllOfficialAccountDB()
  31. {
  32. return self::select()->get();
  33. }
  34. /**
  35. * 根据id获取公众号
  36. */
  37. static function officialAccountById($id)
  38. {
  39. return self::where('id', $id)->first();
  40. }
  41. /**
  42. * 根据appid和distribution_channel_id获取公众号
  43. */
  44. static function officialAccountByAppidAndChannelId($appid, $distribution_channel_id)
  45. {
  46. return self::where(['appid' => $appid, 'distribution_channel_id' => $distribution_channel_id])->first();
  47. }
  48. /**
  49. * 获取所有可用已授权公众号
  50. */
  51. static function officialAuthAccounts($is_auth, $is_enabled)
  52. {
  53. return self::where(['is_auth' => isset($is_auth) ? $is_auth : '', 'is_enabled' => isset($is_enabled) ? $is_enabled : ''])->groupBy('appid')->get();
  54. }
  55. /**
  56. * 获取1个可用已授权公众号
  57. */
  58. static function getOneOfficialAuthAccounts($distribution_channel_id,$is_auth, $is_enabled)
  59. {
  60. return self::where(['distribution_channel_id' =>$distribution_channel_id, 'is_auth' =>$is_auth, 'is_enabled' => $is_enabled])->first();
  61. }
  62. /**
  63. * 获取所有可用已授权强关类型的公众号
  64. */
  65. static function officialAuthSubscribeAccounts($is_auth, $is_enabled)
  66. {
  67. return self::where(['is_auth' => isset($is_auth) ? $is_auth : '', 'is_enabled' => isset($is_enabled) ? $is_enabled : '' ,'official_account_type' => 'force_subscribe'])->groupBy('appid')->get();
  68. }
  69. /**
  70. * 删除指定公众号
  71. */
  72. static function deleteOfficialAccount($id)
  73. {
  74. if(empty($id)) return false;
  75. return self::where(['id' => $id])->delete();
  76. }
  77. /**
  78. * 根据分销渠道号获取授权公众号
  79. */
  80. static function officialAuthAccountBydistributionChannelId($distribution_channel_id, $is_auth, $is_enabled)
  81. {
  82. return self::where(['distribution_channel_id' => isset($distribution_channel_id) ? $distribution_channel_id : '', 'is_auth' => isset($is_auth) ? $is_auth : '', 'is_enabled' => isset($is_enabled) ? $is_enabled : ''])->orderBy('sort_no', 'desc')->get();
  83. }
  84. /**
  85. * 根据distribution_channel_id获取公众号数量
  86. */
  87. static function officialAccountCountByChannelId($distribution_channel_id)
  88. {
  89. return self::where('distribution_channel_id', isset($distribution_channel_id) ? $distribution_channel_id : '')->count();
  90. }
  91. /**
  92. * 根据分销渠道号获取服务号列表
  93. */
  94. static function allOfficialAccountBydistributionChannelId($distribution_channel_id, $is_enabled)
  95. {
  96. return self::where(['distribution_channel_id' => isset($distribution_channel_id) ? $distribution_channel_id : '', 'is_enabled' => isset($is_enabled) ? $is_enabled : ''])->get();
  97. }
  98. /**
  99. * 根据分销渠道号获取服务号列表以及强关类型
  100. */
  101. static function allOfficialAccountBydistributionChannelIdAndGetForceType($distribution_channel_id, $is_enabled)
  102. {
  103. return self::LeftJoin('distribution_force_subscribe_setting', 'official_accounts.appid', '=', 'distribution_force_subscribe_setting.appid')
  104. ->select(DB::raw('official_accounts.*, distribution_force_subscribe_setting.force_subscribe_type,distribution_force_subscribe_setting.resource_url'))
  105. ->where(['official_accounts.distribution_channel_id' => isset($distribution_channel_id) ? $distribution_channel_id : '', 'official_accounts.is_enabled' => isset($is_enabled) ? $is_enabled : ''])->orderBy('official_accounts.sort_no', 'desc')->get();
  106. }
  107. /**
  108. * 根据托管获取服务号列表
  109. */
  110. static function getTrusteeshipOfficialAccounts()
  111. {
  112. return self::LeftJoin('custom_msg_switchs_msgs', 'official_accounts.distribution_channel_id', '=', 'custom_msg_switchs_msgs.distribution_channel_id')
  113. ->select(DB::raw('official_accounts.*, custom_msg_switchs_msgs.status,custom_msg_switchs_msgs.custom_category'))
  114. ->where('official_accounts.is_auth', 1)
  115. ->where('official_accounts.is_enabled', 1)
  116. ->where('custom_msg_switchs_msgs.status', 1)
  117. ->where('custom_msg_switchs_msgs.custom_category', 'auto_custom_trusteeship')
  118. ->groupBy('official_accounts.appid')
  119. ->get();
  120. }
  121. /**
  122. * 获取渠道粉丝阈值信息
  123. */
  124. static function getBusinessChannelData($channels = [], $distribution_channel_name = '',$official_account_name='', $isAll = false)
  125. {
  126. $total_sql = "(select COUNT(1) from force_subscribe_users WHERE force_subscribe_users.appid=official_accounts.appid) as day_total_fans_num";
  127. $sql = "(select COUNT(1) from force_subscribe_users WHERE force_subscribe_users.appid=official_accounts.appid and created_at>=curdate()) as day_fans_num";
  128. $obj = self::select('official_accounts.distribution_channel_id',
  129. "distribution_channels.nickname as distribution_channel_name",
  130. 'official_accounts.nickname as service_name',
  131. 'official_accounts.subscribe_day_maximum',
  132. 'official_accounts.subscribe_top_num',
  133. DB::raw($sql),
  134. DB::raw($total_sql))
  135. ->join("distribution_channels", 'official_accounts.distribution_channel_id', "=", "distribution_channels.id");
  136. if ($channels) {
  137. $obj = $obj->whereIn('official_accounts.distribution_channel_id', $channels);
  138. }
  139. if ($distribution_channel_name) {
  140. $obj = $obj->where('distribution_channels.nickname', 'like', '%' . $distribution_channel_name . '%');
  141. }
  142. if ($official_account_name) {
  143. $obj = $obj->where('official_accounts.nickname', 'like', '%' . $official_account_name . '%');
  144. }
  145. if ($isAll) {
  146. return $obj->get();
  147. } else {
  148. return $obj->paginate();
  149. }
  150. }
  151. }