BookService.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. <?php
  2. namespace App\Services\Book;
  3. use App\Consts\ErrorConst;
  4. use App\Facade\Site;
  5. use App\Libs\Utils;
  6. use GuzzleHttp\Client;
  7. use Illuminate\Support\Facades\DB;
  8. use Illuminate\Support\Facades\Redis;
  9. use OSS\Core\OssException;
  10. use OSS\OssClient;
  11. class BookService
  12. {
  13. public function __construct() {
  14. }
  15. public function getBookList($data) {
  16. $bid = getProp($data, 'bid');
  17. $book_name = getProp($data, 'book_name');
  18. $status = getProp($data, 'status');
  19. $query = DB::table('books as b')->leftJoin('book_configs as bc', 'b.id', '=', 'bc.bid')
  20. ->where('b.size', '<', 30000)->where('b.status', 1)
  21. ->whereIn('bc.cp_source', ['ycsd', 'yqsd'])->whereIn('bc.is_on_shelf', [1,2])->select('b.status', 'bc.*',
  22. DB::raw('(select count(id) from mp_book_version where bid = b.id) as version_count'));
  23. if ($bid) {
  24. $query->where('b.id', $bid);
  25. }
  26. if ($book_name) {
  27. $query->where('bc.book_name', 'like', "%{$book_name}%");
  28. }
  29. if ($status !== '') {
  30. $query->where('b.status', $status);
  31. }
  32. $result = $query->orderBy('b.id')->paginate();
  33. return $result;
  34. }
  35. public function getAllBooks($data) {
  36. $bid = getProp($data, 'bid');
  37. $book_name = getProp($data, 'book_name');
  38. $query = DB::table('book_configs')->whereIn('is_on_shelf', [1,2])->select('bid', 'book_name');
  39. if ($bid) {
  40. $query->where('bid', $bid);
  41. }
  42. if ($book_name) {
  43. $query->where('book_name', 'like', "%{$book_name}%");
  44. }
  45. return $query->orderBy('bid', 'desc')->get()->map(function($value) {
  46. return (array)$value;
  47. })->toArray();
  48. }
  49. public function getBookVersion($data) {
  50. $bid = getProp($data, 'bid');
  51. if (!$bid) Utils::throwError('20003:请选择书籍');
  52. return DB::table('mp_book_version')->where('bid', $bid)->orderBy('id', 'desc')->select('bid', 'book_name', 'id as version_id', 'version_name')
  53. ->get()->map(function($value) {
  54. $value = (array)$value;
  55. $value['version_name'] = $value['book_name']."【{$value['version_name']}】";
  56. return $value;
  57. })->toArray();
  58. }
  59. public function addBookVersion($data) {
  60. $bid = getProp($data, 'bid');
  61. if (!$bid) Utils::throwError('20003:请选择书籍');
  62. $version_name = trim(getProp($data, 'version_name'));
  63. if (!$version_name) Utils::throwError('20003:请填写版本名');
  64. $book_name = DB::table('book_configs')->where('bid', $bid)->value('book_name');
  65. if (DB::table('mp_book_version')->where('bid', $bid)->where('version_name', $version_name)->exists()) Utils::throwError('20003:版本名已存在');
  66. $all_chapters = DB::table('chapters')->where('bid', $bid)->where('is_check', 1)->where('is_deleted', 0)->select('id', 'name', 'sequence', 'size', 'chapter_content_id')->get();
  67. try {
  68. DB::beginTransaction();
  69. $version_id = DB::table('mp_book_version')->insertGetId([
  70. 'bid' => $bid,
  71. 'book_name' => $book_name,
  72. 'version_name' => $version_name,
  73. 'created_at' => date('Y-m-d H:i:s'),
  74. 'updated_at' => date('Y-m-d H:i:s'),
  75. ]);
  76. if (!$version_id) {
  77. DB::rollBack();
  78. Utils::throwError('20003:创建版本失败');
  79. }
  80. $insert_data = [];
  81. foreach ($all_chapters as $chapter) {
  82. $insert_data[] = [
  83. 'bid' => $bid,
  84. 'book_name' => $book_name,
  85. 'version_id' => $version_id,
  86. 'version_name' => $version_name,
  87. 'cid' => getProp($chapter, 'id'),
  88. 'chapter_name' => getProp($chapter, 'name'),
  89. 'sequence' => getProp($chapter, 'sequence'),
  90. 'size' => getProp($chapter, 'size'),
  91. 'generate_status' => '待制作',
  92. 'created_at' => date('Y-m-d H:i:s'),
  93. 'updated_at' => date('Y-m-d H:i:s'),
  94. ];
  95. }
  96. $boolen = DB::table('mp_chapter_audios')->insert($insert_data);
  97. if (!$boolen) {
  98. DB::rollBack();
  99. Utils::throwError('20003:带入章节失败');
  100. }
  101. }catch (\Exception $e) {
  102. DB::rollBack();
  103. Utils::throwError('20003:'.$e->getMessage());
  104. }
  105. DB::commit();
  106. return [
  107. 'bid' => $bid,
  108. 'version_id' => $version_id,
  109. 'version_name' => $book_name."【{$version_name}】",
  110. ];
  111. }
  112. public function getChapterList($data) {
  113. $bid = getProp($data, 'bid');
  114. $version_id = getProp($data, 'version_id');
  115. if (!$bid) Utils::throwError('20003:请选择书籍');
  116. if (!$version_id) Utils::throwError('20003:请选择版本');
  117. $book = DB::table('books as b')->leftJoin('book_configs as bc', 'b.id', '=', 'bc.bid')->where('b.id', $bid)->whereIn('bc.is_on_shelf', [1,2])
  118. ->select('bc.book_name', 'bc.cover', 'b.size', 'b.chapter_count', 'b.intro')->first();
  119. if (!$book) Utils::throwError('20003:书籍不存在');
  120. $header = (array)$book;
  121. $header['cover'] = addPrefix($header['cover']);
  122. $header['intro'] = filterIntro($header['intro']);
  123. $role_info = DB::table('mp_book_version')->where('id', $version_id)->where('bid', $bid)->value('role_info');
  124. if ($role_info) {
  125. foreach(json_decode($role_info, true) as $role => $timbre) {
  126. $header['role_info'][] = [
  127. 'role' => $role,
  128. 'voice_type' => getProp($timbre, 'timbre_type'),
  129. 'voice_name' => getProp($timbre, 'timbre_name'),
  130. ];
  131. }
  132. }else {
  133. $header['role_info'] = [];
  134. }
  135. $list = DB::table('mp_chapter_audios')->where('bid', $bid)->where('version_id', $version_id)->orderBy('sequence', 'asc')
  136. ->select('cid', 'chapter_name', 'sequence', 'size', 'generate_status', 'audio_url', 'remark')
  137. ->paginate();
  138. return ['header' => $header, 'list' => $list];
  139. }
  140. public function getChapterContent($data) {
  141. $cid = getProp($data, 'cid');
  142. if (!$cid) Utils::throwError('20003:请选择章节');
  143. $content = DB::table('chapters as c')->leftJoin('chapter_contents as cc', 'c.chapter_content_id', '=', 'cc.id')->where('c.id', $cid)->value('cc.content');
  144. if (!$content) Utils::throwError('20003:章节内容不存在');
  145. $content = filterContent($content);
  146. return $content;
  147. }
  148. public function getVersionList($data) {
  149. $version_id = getProp($data, 'version_id');
  150. $version_name = getProp($data, 'version_name');
  151. $book_name = getProp($data, 'book_name');
  152. $query = DB::table('mp_book_version as v')->leftJoin('book_configs as bc', 'v.bid', '=', 'bc.bid');
  153. if ($version_id) $query->where('v.id', $version_id);
  154. if ($version_name) $query->where('v.version_name', 'like', '%'.$version_name.'%');
  155. if ($book_name) $query->where('bc.book_name', 'like', '%'.$book_name.'%');
  156. $list = $query->select('v.*', 'bc.book_name')->paginate();
  157. return $list;
  158. }
  159. public function getTaskList($data) {
  160. $task_id = getProp($data, 'task_id');
  161. $task_name = getProp($data, 'task_name');
  162. $generate_status = getProp($data, 'generate_status');
  163. $query = DB::table('mp_audio_tasks')->select('id', 'task_name', 'generate_status', 'created_at');
  164. if ($task_id) $query->where('id', $task_id);
  165. if ($task_name) $query->where('task_name', 'like', '%'.$task_name.'%');
  166. if ($generate_status) $query->where('generate_status', $generate_status);
  167. $list = $query->orderBy('id', 'desc')->paginate();
  168. return $list;
  169. }
  170. public function getTaskDetail($data) {
  171. $task_id = getProp($data, 'task_id');
  172. $result = DB::table('mp_audio_tasks')->where('id', $task_id)->select('id as task_id', 'task_name', 'generate_status', 'generate_json')->first();
  173. if (!$result) Utils::throwError('20003:任务不存在');
  174. $result = (array)$result;
  175. $result['generate_json'] = json_decode($result['generate_json'], true);
  176. return $result;
  177. }
  178. }