serviceWorker.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. const CHATGPT_NEXT_WEB_CACHE = "chatgpt-next-web-cache";
  2. const CHATGPT_NEXT_WEB_FILE_CACHE = "chatgpt-next-web-file";
  3. let a="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";let nanoid=(e=21)=>{let t="",r=crypto.getRandomValues(new Uint8Array(e));for(let n=0;n<e;n++)t+=a[63&r[n]];return t};
  4. self.addEventListener("activate", function (event) {
  5. console.log("ServiceWorker activated.");
  6. });
  7. self.addEventListener("install", function (event) {
  8. event.waitUntil(
  9. caches.open(CHATGPT_NEXT_WEB_CACHE).then(function (cache) {
  10. return cache.addAll([]);
  11. }),
  12. );
  13. });
  14. async function upload(request, url) {
  15. const formData = await request.formData()
  16. const file = formData.getAll('file')[0]
  17. let ext = file.name.split('.').pop()
  18. if (ext === 'blob') {
  19. ext = file.type.split('/').pop()
  20. }
  21. const fileUrl = `${url.origin}/api/cache/${nanoid()}.${ext}`
  22. // console.debug('file', file, fileUrl)
  23. const cache = await caches.open(CHATGPT_NEXT_WEB_FILE_CACHE)
  24. await cache.put(new Request(fileUrl), new Response(file))
  25. return Response.json({ code: 0, data: fileUrl })
  26. }
  27. async function remove(request, url) {
  28. const cache = await caches.open(CHATGPT_NEXT_WEB_FILE_CACHE)
  29. const res = await cache.delete(request.url)
  30. return Response.json({ code: 0 })
  31. }
  32. self.addEventListener("fetch", (e) => {
  33. const url = new URL(e.request.url);
  34. if (/^\/api\/cache/.test(url.pathname)) {
  35. if ('GET' == e.request.method) {
  36. e.respondWith(caches.match(e.request))
  37. }
  38. if ('POST' == e.request.method) {
  39. e.respondWith(upload(e.request, url))
  40. }
  41. if ('DELETE' == e.request.method) {
  42. e.respondWith(remove(e.request, url))
  43. }
  44. }
  45. });