OfflineIndexController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use Illuminate\Support\Facades\Cache;
  5. use App\Tools\RedisClusters;
  6. use Illuminate\Support\Facades\Redis;
  7. use Illuminate\Support\Facades\Log;
  8. use Illuminate\Support\Facades\Storage;
  9. use Illuminate\Support\Facades\App;
  10. class OfflineIndexController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Illuminate\Http\Response
  16. */
  17. public function index()
  18. {
  19. //
  20. if(RedisClusters::has('/offline/index')){
  21. $fileInfo = RedisClusters::get('/offline/index');
  22. foreach ($fileInfo as $key => $file) {
  23. $zipFile = $file['filename'];
  24. $url = array();
  25. foreach (config('mint.server.cdn_urls') as $key => $cdn) {
  26. $url[] = [
  27. 'link' => $cdn . '/' . $zipFile,
  28. 'hostname' =>'cdn-' . $key,
  29. ];
  30. }
  31. if (App::environment('local')) {
  32. $s3Link = Storage::url($zipFile);
  33. }else{
  34. try{
  35. $s3Link = Storage::temporaryUrl($zipFile, now()->addDays(1));
  36. }catch(\Exception $e){
  37. Log::error('offline-index {Exception}',['exception'=>$e]);
  38. continue;
  39. }
  40. }
  41. Log::info('offline-index: link='.$s3Link);
  42. $url[] = [
  43. 'link'=>$s3Link,
  44. 'hostname'=>'Amazon cloud storage(Hongkong)',
  45. ];
  46. $fileInfo[$key]['url'] = $url;
  47. }
  48. return response()->json($fileInfo,
  49. 200,
  50. [
  51. 'Content-Type' => 'application/json;charset=UTF-8',
  52. 'Charset' => 'utf-8'
  53. ],
  54. JSON_UNESCAPED_UNICODE
  55. );
  56. }else{
  57. return [];
  58. }
  59. }
  60. /**
  61. * Store a newly created resource in storage.
  62. *
  63. * @param \Illuminate\Http\Request $request
  64. * @return \Illuminate\Http\Response
  65. */
  66. public function store(Request $request)
  67. {
  68. //
  69. }
  70. /**
  71. * Display the specified resource.
  72. *
  73. * @param string $filename
  74. * @return \Illuminate\Http\Response
  75. */
  76. public function show($filename)
  77. {
  78. }
  79. /**
  80. * Update the specified resource in storage.
  81. *
  82. * @param \Illuminate\Http\Request $request
  83. * @param int $id
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function update(Request $request, $id)
  87. {
  88. //
  89. }
  90. /**
  91. * Remove the specified resource from storage.
  92. *
  93. * @param int $id
  94. * @return \Illuminate\Http\Response
  95. */
  96. public function destroy($id)
  97. {
  98. //
  99. }
  100. }