make-fetch-happen.ts 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import path from 'node:path';
  2. import fsp from 'node:fs/promises';
  3. // import makeFetchHappen from 'make-fetch-happen';
  4. // import type { FetchOptions } from 'make-fetch-happen';
  5. // import cacache from 'cacache';
  6. // import picocolors from 'picocolors';
  7. import { task } from '../trace';
  8. // import { bytes } from 'xbits';
  9. const cachePath = path.resolve(__dirname, '../../.cache/__make_fetch_happen__');
  10. // fs.mkdirSync(cachePath, { recursive: true });
  11. // interface CacacheVerifyStats {
  12. // startTime: Date,
  13. // endTime: Date,
  14. // runTime: {
  15. // markStartTime: 0,
  16. // fixPerms: number,
  17. // garbageCollect: number,
  18. // rebuildIndex: number,
  19. // cleanTmp: number,
  20. // writeVerifile: number,
  21. // markEndTime: number,
  22. // total: number
  23. // },
  24. // verifiedContent: number,
  25. // reclaimedCount: number,
  26. // reclaimedSize: number,
  27. // badContentCount: number,
  28. // keptSize: number,
  29. // missingContent: number,
  30. // rejectedEntries: number,
  31. // totalEntries: number
  32. // }
  33. export const cacheGc = task(require.main === module, __filename)(
  34. () => fsp.rm(cachePath, { recursive: true, force: true })
  35. // span
  36. // .traceChildAsync('cacache gc', () => cacache.verify(cachePath, { concurrency: 64 }))
  37. // .then((stats: CacacheVerifyStats) => {
  38. // // console.log({ stats });
  39. // console.log(picocolors.green('[cacheGc] running gc on cache:'), cachePath);
  40. // console.log(picocolors.green('[cacheGc] content verified:'), stats.verifiedContent, '(' + bytes(stats.keptSize) + ')');
  41. // console.log(picocolors.green('[cacheGc] reclaimed:'), stats.reclaimedCount, '(' + bytes(stats.reclaimedSize) + ')');
  42. // });
  43. );
  44. // const _fetch = makeFetchHappen.defaults({
  45. // cachePath,
  46. // maxSockets: 32, /**
  47. // * They said 15 is a good default that prevents knocking out others' routers,
  48. // * I disagree. 32 is a good number.
  49. // */
  50. // headers: {
  51. // 'User-Agent': 'curl/8.9.1 (https://github.com/SukkaW/Surge)'
  52. // },
  53. // retry: {
  54. // retries: 5,
  55. // randomize: true
  56. // }
  57. // });
  58. // export function $fetch(uriOrRequest: string | Request, opts?: FetchOptions) {
  59. // return _fetch(uriOrRequest, opts).then((resp) => {
  60. // printResponseStatus(resp);
  61. // return resp;
  62. // });
  63. // }
  64. // export async function $delete(resp: NodeFetchResponse) {
  65. // const cacheKey = resp.headers.get('X-Local-Cache-Key');
  66. // if (cacheKey) {
  67. // await cacache.rm.entry(cachePath, cacheKey);
  68. // await cacache.verify(cachePath, { concurrency: 64 });
  69. // }
  70. // }
  71. // export function printResponseStatus(resp: NodeFetchResponse) {
  72. // const status = resp.headers.get('X-Local-Cache-Status');
  73. // if (status) {
  74. // console.log('[$fetch cache]', { status }, picocolors.gray(resp.url));
  75. // }
  76. // }
  77. // export { type Response as NodeFetchResponse } from 'node-fetch';