config.ts 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. import { z } from 'zod';
  2. import type { Page } from "playwright";
  3. const Page: z.ZodType<Page> = z.any();
  4. export const configSchema = z.object({
  5. /**
  6. * URL to start the crawl, if url is a sitemap, it will crawl all pages in the sitemap
  7. * @example "https://www.builder.io/c/docs/developers"
  8. * @example "https://www.builder.io/sitemap.xml"
  9. * @default ""
  10. */
  11. url: z.string(),
  12. /**
  13. * Pattern to match against for links on a page to subsequently crawl
  14. * @example "https://www.builder.io/c/docs/**"
  15. * @default ""
  16. */
  17. match: z.string().or(z.array(z.string())),
  18. /**
  19. * Selector to grab the inner text from
  20. * @example ".docs-builder-container"
  21. * @default ""
  22. */
  23. selector: z.string().optional(),
  24. /**
  25. * Don't crawl more than this many pages
  26. * @default 50
  27. */
  28. maxPagesToCrawl: z.number().int().positive(),
  29. /**
  30. * File name for the finished data
  31. * @default "output.json"
  32. */
  33. outputFileName: z.string(),
  34. /** Optional cookie to be set. E.g. for Cookie Consent */
  35. cookie: z.object({
  36. name: z.string(),
  37. value: z.string(),
  38. }).optional(),
  39. /** Optional function to run for each page found */
  40. onVisitPage: z.function()
  41. .args(z.object({
  42. page: Page,
  43. pushData: z.function()
  44. .args(z.any())
  45. .returns(z.promise(z.void()))
  46. }))
  47. .returns(z.promise(z.void()))
  48. .optional(),
  49. /** Optional timeout for waiting for a selector to appear */
  50. waitForSelectorTimeout: z.number().int().nonnegative().optional(),
  51. /** Optional resources to exclude
  52. *
  53. * @example
  54. * ['png','jpg','jpeg','gif','svg','css','js','ico','woff','woff2','ttf','eot','otf','mp4','mp3','webm','ogg','wav','flac','aac','zip','tar','gz','rar','7z','exe','dmg','apk','csv','xls','xlsx','doc','docx','pdf','epub','iso','dmg','bin','ppt','pptx','odt','avi','mkv','xml','json','yml','yaml','rss','atom','swf','txt','dart','webp','bmp','tif','psd','ai','indd','eps','ps','zipx','srt','wasm','m4v','m4a','webp','weba','m4b','opus','ogv','ogm','oga','spx','ogx','flv','3gp','3g2','jxr','wdp','jng','hief','avif','apng','avifs','heif','heic','cur','ico','ani','jp2','jpm','jpx','mj2','wmv','wma','aac','tif','tiff','mpg','mpeg','mov','avi','wmv','flv','swf','mkv','m4v','m4p','m4b','m4r','m4a','mp3','wav','wma','ogg','oga','webm','3gp','3g2','flac','spx','amr','mid','midi','mka','dts','ac3','eac3','weba','m3u','m3u8','ts','wpl','pls','vob','ifo','bup','svcd','drc','dsm','dsv','dsa','dss','vivo','ivf','dvd','fli','flc','flic','flic','mng','asf','m2v','asx','ram','ra','rm','rpm','roq','smi','smil','wmf','wmz','wmd','wvx','wmx','movie','wri','ins','isp','acsm','djvu','fb2','xps','oxps','ps','eps','ai','prn','svg','dwg','dxf','ttf','fnt','fon','otf','cab']
  55. */
  56. resourceExclusions: z.array(z.string()).optional(),
  57. });
  58. export type Config = z.infer<typeof configSchema>;