failproofai 0.0.6-beta.2 → 0.0.6-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (511) hide show
  1. package/.next/standalone/.next/BUILD_ID +1 -1
  2. package/.next/standalone/.next/build-manifest.json +3 -3
  3. package/.next/standalone/.next/prerender-manifest.json +3 -3
  4. package/.next/standalone/.next/required-server-files.json +7 -1
  5. package/.next/standalone/.next/server/app/_global-error/page/server-reference-manifest.json +1 -1
  6. package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
  7. package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  8. package/.next/standalone/.next/server/app/_global-error.html +1 -1
  9. package/.next/standalone/.next/server/app/_global-error.rsc +7 -7
  10. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
  11. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
  12. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +3 -3
  13. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  14. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  15. package/.next/standalone/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
  16. package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  17. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  18. package/.next/standalone/.next/server/app/_not-found.html +2 -2
  19. package/.next/standalone/.next/server/app/_not-found.rsc +17 -17
  20. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +17 -17
  21. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  22. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +11 -11
  23. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  24. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  25. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  26. package/.next/standalone/.next/server/app/index.html +1 -1
  27. package/.next/standalone/.next/server/app/index.rsc +16 -16
  28. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  29. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +16 -16
  30. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
  31. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +11 -11
  32. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  33. package/.next/standalone/.next/server/app/page/server-reference-manifest.json +1 -1
  34. package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
  35. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  36. package/.next/standalone/.next/server/app/policies/page/server-reference-manifest.json +8 -8
  37. package/.next/standalone/.next/server/app/policies/page.js.nft.json +1 -1
  38. package/.next/standalone/.next/server/app/policies/page_client-reference-manifest.js +1 -1
  39. package/.next/standalone/.next/server/app/project/[name]/page/server-reference-manifest.json +1 -1
  40. package/.next/standalone/.next/server/app/project/[name]/page.js.nft.json +1 -1
  41. package/.next/standalone/.next/server/app/project/[name]/page_client-reference-manifest.js +1 -1
  42. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/react-loadable-manifest.json +2 -2
  43. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/server-reference-manifest.json +2 -2
  44. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js.nft.json +1 -1
  45. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page_client-reference-manifest.js +1 -1
  46. package/.next/standalone/.next/server/app/projects/page/server-reference-manifest.json +1 -1
  47. package/.next/standalone/.next/server/app/projects/page.js.nft.json +1 -1
  48. package/.next/standalone/.next/server/app/projects/page_client-reference-manifest.js +1 -1
  49. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0g72weg._.js +1 -1
  50. package/.next/standalone/.next/server/chunks/package_json_[json]_cjs_0z7w.hh._.js +1 -1
  51. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__092s1ta._.js +2 -2
  52. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__09icjsf._.js +2 -2
  53. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0g.lg8b._.js +2 -2
  54. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0h..k-e._.js +2 -2
  55. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0okos0k._.js +2 -2
  56. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0i5kvry._.js → [root-of-the-server]__0om-5pe._.js} +2 -2
  57. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0w6l33k._.js +2 -2
  58. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__05akje6._.js → [root-of-the-server]__111.vxi._.js} +2 -2
  59. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__11pa2ra._.js +2 -2
  60. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__12t-wym._.js +2 -2
  61. package/.next/standalone/.next/server/chunks/ssr/_10lm7or._.js +2 -2
  62. package/.next/standalone/.next/server/chunks/ssr/app_global-error_tsx_0xerkr6._.js +1 -1
  63. package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_0q-m0y-._.js +1 -1
  64. package/.next/standalone/.next/server/chunks/ssr/node_modules_posthog-node_dist_entrypoints_index_node_mjs_0mebn66._.js +1 -1
  65. package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
  66. package/.next/standalone/.next/server/pages/404.html +2 -2
  67. package/.next/standalone/.next/server/pages/500.html +1 -1
  68. package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
  69. package/.next/standalone/.next/server/server-reference-manifest.json +9 -9
  70. package/.next/standalone/.next/static/chunks/{05j1px0r8yzh6.js → 02dqjyv6_9mhq.js} +2 -2
  71. package/.next/standalone/.next/static/chunks/{14cl9poem30dq.js → 070orfsl6.xal.js} +1 -1
  72. package/.next/standalone/.next/static/chunks/0mir9jdxn35~s.css +1 -0
  73. package/.next/standalone/.next/static/chunks/{00j0rr7rh8ef8.js → 0o547jv-k_k35.js} +1 -1
  74. package/.next/standalone/.next/static/chunks/{0ijk_kek9_wyx.js → 0pk2h2.mjxy.m.js} +1 -1
  75. package/.next/standalone/.next/static/chunks/{0xpl.oscrakvx.js → 0rcwkbh24w38b.js} +1 -1
  76. package/.next/standalone/.next/static/chunks/{1052sguyd-.ka.js → 140xx_tfr~lm_.js} +1 -1
  77. package/.next/standalone/.next/static/chunks/{0npb~873.wvg3.js → 169_e4dq~1~b6.js} +1 -1
  78. package/.next/standalone/.next/static/chunks/{0badv41uxa56..js → 17ne4p.1sw1jy.js} +1 -1
  79. package/.next/standalone/next.config.ts +6 -0
  80. package/.next/standalone/package.json +2 -2
  81. package/.next/standalone/server.js +1 -1
  82. package/bin/failproofai.mjs +91 -4
  83. package/dist/cli.mjs +1155 -54
  84. package/package.json +2 -2
  85. package/scripts/prune-standalone.mjs +128 -0
  86. package/src/auth/login.ts +104 -0
  87. package/src/auth/logout.ts +50 -0
  88. package/src/auth/token-store.ts +64 -0
  89. package/src/hooks/builtin-policies.ts +22 -20
  90. package/src/hooks/handler.ts +35 -15
  91. package/src/relay/daemon.ts +362 -0
  92. package/src/relay/pid.ts +76 -0
  93. package/src/relay/queue.ts +225 -0
  94. package/.next/standalone/.claude/settings.json +0 -316
  95. package/.next/standalone/.failproofai/policies/review-policies.mjs +0 -113
  96. package/.next/standalone/.failproofai/policies/workflow-policies.mjs +0 -63
  97. package/.next/standalone/.failproofai/policies-config.json +0 -39
  98. package/.next/standalone/.next/static/chunks/0gu_a.a80ritd.css +0 -1
  99. package/.next/standalone/AGENTS.md +0 -80
  100. package/.next/standalone/CHANGELOG.md +0 -151
  101. package/.next/standalone/CLAUDE.md +0 -165
  102. package/.next/standalone/CONTRIBUTING.md +0 -76
  103. package/.next/standalone/Dockerfile.docs +0 -12
  104. package/.next/standalone/LICENSE +0 -42
  105. package/.next/standalone/README.md +0 -301
  106. package/.next/standalone/bin/failproofai.mjs +0 -352
  107. package/.next/standalone/bun.lock +0 -1119
  108. package/.next/standalone/components.json +0 -23
  109. package/.next/standalone/dist/cli.mjs +0 -3595
  110. package/.next/standalone/dist/index.js +0 -80
  111. package/.next/standalone/docs/ar/architecture.mdx +0 -334
  112. package/.next/standalone/docs/ar/built-in-policies.mdx +0 -574
  113. package/.next/standalone/docs/ar/cli/dashboard.mdx +0 -28
  114. package/.next/standalone/docs/ar/cli/environment-variables.mdx +0 -34
  115. package/.next/standalone/docs/ar/cli/hook.mdx +0 -31
  116. package/.next/standalone/docs/ar/cli/install-policies.mdx +0 -48
  117. package/.next/standalone/docs/ar/cli/list-policies.mdx +0 -31
  118. package/.next/standalone/docs/ar/cli/remove-policies.mdx +0 -43
  119. package/.next/standalone/docs/ar/cli/version.mdx +0 -13
  120. package/.next/standalone/docs/ar/configuration.mdx +0 -223
  121. package/.next/standalone/docs/ar/custom-policies.mdx +0 -354
  122. package/.next/standalone/docs/ar/dashboard.mdx +0 -142
  123. package/.next/standalone/docs/ar/examples.mdx +0 -307
  124. package/.next/standalone/docs/ar/for-agents.mdx +0 -39
  125. package/.next/standalone/docs/ar/getting-started.mdx +0 -187
  126. package/.next/standalone/docs/ar/introduction.mdx +0 -58
  127. package/.next/standalone/docs/ar/package-aliases.mdx +0 -82
  128. package/.next/standalone/docs/ar/testing.mdx +0 -261
  129. package/.next/standalone/docs/architecture.mdx +0 -332
  130. package/.next/standalone/docs/built-in-policies.mdx +0 -574
  131. package/.next/standalone/docs/cli/dashboard.mdx +0 -28
  132. package/.next/standalone/docs/cli/environment-variables.mdx +0 -34
  133. package/.next/standalone/docs/cli/hook.mdx +0 -30
  134. package/.next/standalone/docs/cli/install-policies.mdx +0 -47
  135. package/.next/standalone/docs/cli/list-policies.mdx +0 -31
  136. package/.next/standalone/docs/cli/remove-policies.mdx +0 -43
  137. package/.next/standalone/docs/cli/version.mdx +0 -12
  138. package/.next/standalone/docs/configuration.mdx +0 -222
  139. package/.next/standalone/docs/custom-policies.mdx +0 -353
  140. package/.next/standalone/docs/dashboard.mdx +0 -142
  141. package/.next/standalone/docs/de/architecture.mdx +0 -332
  142. package/.next/standalone/docs/de/built-in-policies.mdx +0 -574
  143. package/.next/standalone/docs/de/cli/dashboard.mdx +0 -28
  144. package/.next/standalone/docs/de/cli/environment-variables.mdx +0 -34
  145. package/.next/standalone/docs/de/cli/hook.mdx +0 -30
  146. package/.next/standalone/docs/de/cli/install-policies.mdx +0 -47
  147. package/.next/standalone/docs/de/cli/list-policies.mdx +0 -31
  148. package/.next/standalone/docs/de/cli/remove-policies.mdx +0 -43
  149. package/.next/standalone/docs/de/cli/version.mdx +0 -12
  150. package/.next/standalone/docs/de/configuration.mdx +0 -222
  151. package/.next/standalone/docs/de/custom-policies.mdx +0 -353
  152. package/.next/standalone/docs/de/dashboard.mdx +0 -142
  153. package/.next/standalone/docs/de/examples.mdx +0 -307
  154. package/.next/standalone/docs/de/for-agents.mdx +0 -38
  155. package/.next/standalone/docs/de/getting-started.mdx +0 -186
  156. package/.next/standalone/docs/de/introduction.mdx +0 -57
  157. package/.next/standalone/docs/de/package-aliases.mdx +0 -82
  158. package/.next/standalone/docs/de/testing.mdx +0 -260
  159. package/.next/standalone/docs/docs.json +0 -1002
  160. package/.next/standalone/docs/es/architecture.mdx +0 -332
  161. package/.next/standalone/docs/es/built-in-policies.mdx +0 -574
  162. package/.next/standalone/docs/es/cli/dashboard.mdx +0 -28
  163. package/.next/standalone/docs/es/cli/environment-variables.mdx +0 -34
  164. package/.next/standalone/docs/es/cli/hook.mdx +0 -30
  165. package/.next/standalone/docs/es/cli/install-policies.mdx +0 -47
  166. package/.next/standalone/docs/es/cli/list-policies.mdx +0 -31
  167. package/.next/standalone/docs/es/cli/remove-policies.mdx +0 -43
  168. package/.next/standalone/docs/es/cli/version.mdx +0 -12
  169. package/.next/standalone/docs/es/configuration.mdx +0 -222
  170. package/.next/standalone/docs/es/custom-policies.mdx +0 -353
  171. package/.next/standalone/docs/es/dashboard.mdx +0 -142
  172. package/.next/standalone/docs/es/examples.mdx +0 -307
  173. package/.next/standalone/docs/es/for-agents.mdx +0 -38
  174. package/.next/standalone/docs/es/getting-started.mdx +0 -186
  175. package/.next/standalone/docs/es/introduction.mdx +0 -57
  176. package/.next/standalone/docs/es/package-aliases.mdx +0 -82
  177. package/.next/standalone/docs/es/testing.mdx +0 -260
  178. package/.next/standalone/docs/examples.mdx +0 -307
  179. package/.next/standalone/docs/favicon.ico +0 -0
  180. package/.next/standalone/docs/for-agents.mdx +0 -38
  181. package/.next/standalone/docs/fr/architecture.mdx +0 -332
  182. package/.next/standalone/docs/fr/built-in-policies.mdx +0 -574
  183. package/.next/standalone/docs/fr/cli/dashboard.mdx +0 -28
  184. package/.next/standalone/docs/fr/cli/environment-variables.mdx +0 -34
  185. package/.next/standalone/docs/fr/cli/hook.mdx +0 -30
  186. package/.next/standalone/docs/fr/cli/install-policies.mdx +0 -47
  187. package/.next/standalone/docs/fr/cli/list-policies.mdx +0 -31
  188. package/.next/standalone/docs/fr/cli/remove-policies.mdx +0 -43
  189. package/.next/standalone/docs/fr/cli/version.mdx +0 -12
  190. package/.next/standalone/docs/fr/configuration.mdx +0 -222
  191. package/.next/standalone/docs/fr/custom-policies.mdx +0 -353
  192. package/.next/standalone/docs/fr/dashboard.mdx +0 -142
  193. package/.next/standalone/docs/fr/examples.mdx +0 -307
  194. package/.next/standalone/docs/fr/for-agents.mdx +0 -38
  195. package/.next/standalone/docs/fr/getting-started.mdx +0 -186
  196. package/.next/standalone/docs/fr/introduction.mdx +0 -57
  197. package/.next/standalone/docs/fr/package-aliases.mdx +0 -82
  198. package/.next/standalone/docs/fr/testing.mdx +0 -260
  199. package/.next/standalone/docs/getting-started.mdx +0 -186
  200. package/.next/standalone/docs/he/architecture.mdx +0 -333
  201. package/.next/standalone/docs/he/built-in-policies.mdx +0 -574
  202. package/.next/standalone/docs/he/cli/dashboard.mdx +0 -28
  203. package/.next/standalone/docs/he/cli/environment-variables.mdx +0 -34
  204. package/.next/standalone/docs/he/cli/hook.mdx +0 -30
  205. package/.next/standalone/docs/he/cli/install-policies.mdx +0 -47
  206. package/.next/standalone/docs/he/cli/list-policies.mdx +0 -32
  207. package/.next/standalone/docs/he/cli/remove-policies.mdx +0 -43
  208. package/.next/standalone/docs/he/cli/version.mdx +0 -12
  209. package/.next/standalone/docs/he/configuration.mdx +0 -223
  210. package/.next/standalone/docs/he/custom-policies.mdx +0 -353
  211. package/.next/standalone/docs/he/dashboard.mdx +0 -142
  212. package/.next/standalone/docs/he/examples.mdx +0 -307
  213. package/.next/standalone/docs/he/for-agents.mdx +0 -38
  214. package/.next/standalone/docs/he/getting-started.mdx +0 -186
  215. package/.next/standalone/docs/he/introduction.mdx +0 -57
  216. package/.next/standalone/docs/he/package-aliases.mdx +0 -82
  217. package/.next/standalone/docs/he/testing.mdx +0 -260
  218. package/.next/standalone/docs/hi/architecture.mdx +0 -334
  219. package/.next/standalone/docs/hi/built-in-policies.mdx +0 -576
  220. package/.next/standalone/docs/hi/cli/dashboard.mdx +0 -28
  221. package/.next/standalone/docs/hi/cli/environment-variables.mdx +0 -34
  222. package/.next/standalone/docs/hi/cli/hook.mdx +0 -30
  223. package/.next/standalone/docs/hi/cli/install-policies.mdx +0 -47
  224. package/.next/standalone/docs/hi/cli/list-policies.mdx +0 -31
  225. package/.next/standalone/docs/hi/cli/remove-policies.mdx +0 -43
  226. package/.next/standalone/docs/hi/cli/version.mdx +0 -12
  227. package/.next/standalone/docs/hi/configuration.mdx +0 -222
  228. package/.next/standalone/docs/hi/custom-policies.mdx +0 -354
  229. package/.next/standalone/docs/hi/dashboard.mdx +0 -142
  230. package/.next/standalone/docs/hi/examples.mdx +0 -309
  231. package/.next/standalone/docs/hi/for-agents.mdx +0 -38
  232. package/.next/standalone/docs/hi/getting-started.mdx +0 -187
  233. package/.next/standalone/docs/hi/introduction.mdx +0 -57
  234. package/.next/standalone/docs/hi/package-aliases.mdx +0 -82
  235. package/.next/standalone/docs/hi/testing.mdx +0 -260
  236. package/.next/standalone/docs/i18n/README.ar.md +0 -312
  237. package/.next/standalone/docs/i18n/README.de.md +0 -307
  238. package/.next/standalone/docs/i18n/README.es.md +0 -307
  239. package/.next/standalone/docs/i18n/README.fr.md +0 -307
  240. package/.next/standalone/docs/i18n/README.he.md +0 -312
  241. package/.next/standalone/docs/i18n/README.hi.md +0 -307
  242. package/.next/standalone/docs/i18n/README.it.md +0 -307
  243. package/.next/standalone/docs/i18n/README.ja.md +0 -307
  244. package/.next/standalone/docs/i18n/README.ko.md +0 -307
  245. package/.next/standalone/docs/i18n/README.pt-br.md +0 -307
  246. package/.next/standalone/docs/i18n/README.ru.md +0 -308
  247. package/.next/standalone/docs/i18n/README.tr.md +0 -307
  248. package/.next/standalone/docs/i18n/README.vi.md +0 -307
  249. package/.next/standalone/docs/i18n/README.zh.md +0 -307
  250. package/.next/standalone/docs/introduction.mdx +0 -57
  251. package/.next/standalone/docs/it/architecture.mdx +0 -334
  252. package/.next/standalone/docs/it/built-in-policies.mdx +0 -574
  253. package/.next/standalone/docs/it/cli/dashboard.mdx +0 -28
  254. package/.next/standalone/docs/it/cli/environment-variables.mdx +0 -34
  255. package/.next/standalone/docs/it/cli/hook.mdx +0 -30
  256. package/.next/standalone/docs/it/cli/install-policies.mdx +0 -47
  257. package/.next/standalone/docs/it/cli/list-policies.mdx +0 -31
  258. package/.next/standalone/docs/it/cli/remove-policies.mdx +0 -43
  259. package/.next/standalone/docs/it/cli/version.mdx +0 -12
  260. package/.next/standalone/docs/it/configuration.mdx +0 -222
  261. package/.next/standalone/docs/it/custom-policies.mdx +0 -353
  262. package/.next/standalone/docs/it/dashboard.mdx +0 -142
  263. package/.next/standalone/docs/it/examples.mdx +0 -307
  264. package/.next/standalone/docs/it/for-agents.mdx +0 -38
  265. package/.next/standalone/docs/it/getting-started.mdx +0 -186
  266. package/.next/standalone/docs/it/introduction.mdx +0 -57
  267. package/.next/standalone/docs/it/package-aliases.mdx +0 -82
  268. package/.next/standalone/docs/it/testing.mdx +0 -260
  269. package/.next/standalone/docs/ja/architecture.mdx +0 -332
  270. package/.next/standalone/docs/ja/built-in-policies.mdx +0 -572
  271. package/.next/standalone/docs/ja/cli/dashboard.mdx +0 -28
  272. package/.next/standalone/docs/ja/cli/environment-variables.mdx +0 -34
  273. package/.next/standalone/docs/ja/cli/hook.mdx +0 -30
  274. package/.next/standalone/docs/ja/cli/install-policies.mdx +0 -47
  275. package/.next/standalone/docs/ja/cli/list-policies.mdx +0 -31
  276. package/.next/standalone/docs/ja/cli/remove-policies.mdx +0 -43
  277. package/.next/standalone/docs/ja/cli/version.mdx +0 -12
  278. package/.next/standalone/docs/ja/configuration.mdx +0 -222
  279. package/.next/standalone/docs/ja/custom-policies.mdx +0 -353
  280. package/.next/standalone/docs/ja/dashboard.mdx +0 -142
  281. package/.next/standalone/docs/ja/examples.mdx +0 -307
  282. package/.next/standalone/docs/ja/for-agents.mdx +0 -38
  283. package/.next/standalone/docs/ja/getting-started.mdx +0 -186
  284. package/.next/standalone/docs/ja/introduction.mdx +0 -57
  285. package/.next/standalone/docs/ja/package-aliases.mdx +0 -82
  286. package/.next/standalone/docs/ja/testing.mdx +0 -260
  287. package/.next/standalone/docs/ko/architecture.mdx +0 -332
  288. package/.next/standalone/docs/ko/built-in-policies.mdx +0 -572
  289. package/.next/standalone/docs/ko/cli/dashboard.mdx +0 -28
  290. package/.next/standalone/docs/ko/cli/environment-variables.mdx +0 -34
  291. package/.next/standalone/docs/ko/cli/hook.mdx +0 -30
  292. package/.next/standalone/docs/ko/cli/install-policies.mdx +0 -47
  293. package/.next/standalone/docs/ko/cli/list-policies.mdx +0 -31
  294. package/.next/standalone/docs/ko/cli/remove-policies.mdx +0 -43
  295. package/.next/standalone/docs/ko/cli/version.mdx +0 -12
  296. package/.next/standalone/docs/ko/configuration.mdx +0 -222
  297. package/.next/standalone/docs/ko/custom-policies.mdx +0 -353
  298. package/.next/standalone/docs/ko/dashboard.mdx +0 -142
  299. package/.next/standalone/docs/ko/examples.mdx +0 -307
  300. package/.next/standalone/docs/ko/for-agents.mdx +0 -38
  301. package/.next/standalone/docs/ko/getting-started.mdx +0 -186
  302. package/.next/standalone/docs/ko/introduction.mdx +0 -57
  303. package/.next/standalone/docs/ko/package-aliases.mdx +0 -82
  304. package/.next/standalone/docs/ko/testing.mdx +0 -260
  305. package/.next/standalone/docs/logo/dark.svg +0 -21
  306. package/.next/standalone/docs/logo/exosphere-dark.png +0 -0
  307. package/.next/standalone/docs/logo/exosphere-light.png +0 -0
  308. package/.next/standalone/docs/logo/light.svg +0 -21
  309. package/.next/standalone/docs/package-aliases.mdx +0 -82
  310. package/.next/standalone/docs/pt-br/architecture.mdx +0 -332
  311. package/.next/standalone/docs/pt-br/built-in-policies.mdx +0 -574
  312. package/.next/standalone/docs/pt-br/cli/dashboard.mdx +0 -28
  313. package/.next/standalone/docs/pt-br/cli/environment-variables.mdx +0 -34
  314. package/.next/standalone/docs/pt-br/cli/hook.mdx +0 -30
  315. package/.next/standalone/docs/pt-br/cli/install-policies.mdx +0 -47
  316. package/.next/standalone/docs/pt-br/cli/list-policies.mdx +0 -31
  317. package/.next/standalone/docs/pt-br/cli/remove-policies.mdx +0 -43
  318. package/.next/standalone/docs/pt-br/cli/version.mdx +0 -12
  319. package/.next/standalone/docs/pt-br/configuration.mdx +0 -222
  320. package/.next/standalone/docs/pt-br/custom-policies.mdx +0 -353
  321. package/.next/standalone/docs/pt-br/dashboard.mdx +0 -142
  322. package/.next/standalone/docs/pt-br/examples.mdx +0 -307
  323. package/.next/standalone/docs/pt-br/for-agents.mdx +0 -38
  324. package/.next/standalone/docs/pt-br/getting-started.mdx +0 -186
  325. package/.next/standalone/docs/pt-br/introduction.mdx +0 -57
  326. package/.next/standalone/docs/pt-br/package-aliases.mdx +0 -82
  327. package/.next/standalone/docs/pt-br/testing.mdx +0 -260
  328. package/.next/standalone/docs/ru/architecture.mdx +0 -333
  329. package/.next/standalone/docs/ru/built-in-policies.mdx +0 -574
  330. package/.next/standalone/docs/ru/cli/dashboard.mdx +0 -28
  331. package/.next/standalone/docs/ru/cli/environment-variables.mdx +0 -34
  332. package/.next/standalone/docs/ru/cli/hook.mdx +0 -30
  333. package/.next/standalone/docs/ru/cli/install-policies.mdx +0 -48
  334. package/.next/standalone/docs/ru/cli/list-policies.mdx +0 -32
  335. package/.next/standalone/docs/ru/cli/remove-policies.mdx +0 -43
  336. package/.next/standalone/docs/ru/cli/version.mdx +0 -12
  337. package/.next/standalone/docs/ru/configuration.mdx +0 -222
  338. package/.next/standalone/docs/ru/custom-policies.mdx +0 -354
  339. package/.next/standalone/docs/ru/dashboard.mdx +0 -142
  340. package/.next/standalone/docs/ru/examples.mdx +0 -309
  341. package/.next/standalone/docs/ru/for-agents.mdx +0 -38
  342. package/.next/standalone/docs/ru/getting-started.mdx +0 -186
  343. package/.next/standalone/docs/ru/introduction.mdx +0 -57
  344. package/.next/standalone/docs/ru/package-aliases.mdx +0 -82
  345. package/.next/standalone/docs/ru/testing.mdx +0 -260
  346. package/.next/standalone/docs/testing.mdx +0 -260
  347. package/.next/standalone/docs/tr/architecture.mdx +0 -333
  348. package/.next/standalone/docs/tr/built-in-policies.mdx +0 -574
  349. package/.next/standalone/docs/tr/cli/dashboard.mdx +0 -28
  350. package/.next/standalone/docs/tr/cli/environment-variables.mdx +0 -34
  351. package/.next/standalone/docs/tr/cli/hook.mdx +0 -30
  352. package/.next/standalone/docs/tr/cli/install-policies.mdx +0 -47
  353. package/.next/standalone/docs/tr/cli/list-policies.mdx +0 -31
  354. package/.next/standalone/docs/tr/cli/remove-policies.mdx +0 -44
  355. package/.next/standalone/docs/tr/cli/version.mdx +0 -12
  356. package/.next/standalone/docs/tr/configuration.mdx +0 -222
  357. package/.next/standalone/docs/tr/custom-policies.mdx +0 -353
  358. package/.next/standalone/docs/tr/dashboard.mdx +0 -142
  359. package/.next/standalone/docs/tr/examples.mdx +0 -308
  360. package/.next/standalone/docs/tr/for-agents.mdx +0 -38
  361. package/.next/standalone/docs/tr/getting-started.mdx +0 -186
  362. package/.next/standalone/docs/tr/introduction.mdx +0 -57
  363. package/.next/standalone/docs/tr/package-aliases.mdx +0 -82
  364. package/.next/standalone/docs/tr/testing.mdx +0 -260
  365. package/.next/standalone/docs/vi/architecture.mdx +0 -334
  366. package/.next/standalone/docs/vi/built-in-policies.mdx +0 -575
  367. package/.next/standalone/docs/vi/cli/dashboard.mdx +0 -28
  368. package/.next/standalone/docs/vi/cli/environment-variables.mdx +0 -34
  369. package/.next/standalone/docs/vi/cli/hook.mdx +0 -30
  370. package/.next/standalone/docs/vi/cli/install-policies.mdx +0 -47
  371. package/.next/standalone/docs/vi/cli/list-policies.mdx +0 -31
  372. package/.next/standalone/docs/vi/cli/remove-policies.mdx +0 -43
  373. package/.next/standalone/docs/vi/cli/version.mdx +0 -13
  374. package/.next/standalone/docs/vi/configuration.mdx +0 -222
  375. package/.next/standalone/docs/vi/custom-policies.mdx +0 -353
  376. package/.next/standalone/docs/vi/dashboard.mdx +0 -142
  377. package/.next/standalone/docs/vi/examples.mdx +0 -308
  378. package/.next/standalone/docs/vi/for-agents.mdx +0 -38
  379. package/.next/standalone/docs/vi/getting-started.mdx +0 -186
  380. package/.next/standalone/docs/vi/introduction.mdx +0 -57
  381. package/.next/standalone/docs/vi/package-aliases.mdx +0 -82
  382. package/.next/standalone/docs/vi/testing.mdx +0 -260
  383. package/.next/standalone/docs/zh/architecture.mdx +0 -332
  384. package/.next/standalone/docs/zh/built-in-policies.mdx +0 -572
  385. package/.next/standalone/docs/zh/cli/dashboard.mdx +0 -28
  386. package/.next/standalone/docs/zh/cli/environment-variables.mdx +0 -34
  387. package/.next/standalone/docs/zh/cli/hook.mdx +0 -30
  388. package/.next/standalone/docs/zh/cli/install-policies.mdx +0 -47
  389. package/.next/standalone/docs/zh/cli/list-policies.mdx +0 -31
  390. package/.next/standalone/docs/zh/cli/remove-policies.mdx +0 -43
  391. package/.next/standalone/docs/zh/cli/version.mdx +0 -12
  392. package/.next/standalone/docs/zh/configuration.mdx +0 -222
  393. package/.next/standalone/docs/zh/custom-policies.mdx +0 -353
  394. package/.next/standalone/docs/zh/dashboard.mdx +0 -142
  395. package/.next/standalone/docs/zh/examples.mdx +0 -307
  396. package/.next/standalone/docs/zh/for-agents.mdx +0 -38
  397. package/.next/standalone/docs/zh/getting-started.mdx +0 -186
  398. package/.next/standalone/docs/zh/introduction.mdx +0 -57
  399. package/.next/standalone/docs/zh/package-aliases.mdx +0 -82
  400. package/.next/standalone/docs/zh/testing.mdx +0 -260
  401. package/.next/standalone/eslint.config.mjs +0 -15
  402. package/.next/standalone/examples/convention-policies/security-policies.mjs +0 -40
  403. package/.next/standalone/examples/convention-policies/workflow-policies.mjs +0 -41
  404. package/.next/standalone/examples/policies-advanced/index.js +0 -103
  405. package/.next/standalone/examples/policies-advanced/utils.js +0 -35
  406. package/.next/standalone/examples/policies-basic.js +0 -77
  407. package/.next/standalone/examples/policies-notification.js +0 -104
  408. package/.next/standalone/node_modules/@img/colour/color.cjs +0 -1594
  409. package/.next/standalone/node_modules/@img/colour/index.cjs +0 -1
  410. package/.next/standalone/node_modules/@img/colour/package.json +0 -45
  411. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/README.md +0 -46
  412. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/lib/glib-2.0/include/glibconfig.h +0 -221
  413. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/lib/index.js +0 -1
  414. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/lib/libvips-cpp.so.8.17.3 +0 -0
  415. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/package.json +0 -42
  416. package/.next/standalone/node_modules/@img/sharp-libvips-linux-x64/versions.json +0 -30
  417. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/README.md +0 -46
  418. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/lib/glib-2.0/include/glibconfig.h +0 -221
  419. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/lib/index.js +0 -1
  420. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/lib/libvips-cpp.so.8.17.3 +0 -0
  421. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/package.json +0 -42
  422. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/versions.json +0 -30
  423. package/.next/standalone/node_modules/@img/sharp-linux-x64/lib/sharp-linux-x64.node +0 -0
  424. package/.next/standalone/node_modules/@img/sharp-linux-x64/package.json +0 -46
  425. package/.next/standalone/node_modules/@img/sharp-linuxmusl-x64/lib/sharp-linuxmusl-x64.node +0 -0
  426. package/.next/standalone/node_modules/@img/sharp-linuxmusl-x64/package.json +0 -46
  427. package/.next/standalone/node_modules/detect-libc/lib/detect-libc.js +0 -313
  428. package/.next/standalone/node_modules/detect-libc/lib/elf.js +0 -39
  429. package/.next/standalone/node_modules/detect-libc/lib/filesystem.js +0 -51
  430. package/.next/standalone/node_modules/detect-libc/lib/process.js +0 -24
  431. package/.next/standalone/node_modules/detect-libc/package.json +0 -44
  432. package/.next/standalone/node_modules/sharp/lib/channel.js +0 -177
  433. package/.next/standalone/node_modules/sharp/lib/colour.js +0 -195
  434. package/.next/standalone/node_modules/sharp/lib/composite.js +0 -212
  435. package/.next/standalone/node_modules/sharp/lib/constructor.js +0 -499
  436. package/.next/standalone/node_modules/sharp/lib/index.js +0 -16
  437. package/.next/standalone/node_modules/sharp/lib/input.js +0 -809
  438. package/.next/standalone/node_modules/sharp/lib/is.js +0 -143
  439. package/.next/standalone/node_modules/sharp/lib/libvips.js +0 -207
  440. package/.next/standalone/node_modules/sharp/lib/operation.js +0 -1016
  441. package/.next/standalone/node_modules/sharp/lib/output.js +0 -1666
  442. package/.next/standalone/node_modules/sharp/lib/resize.js +0 -595
  443. package/.next/standalone/node_modules/sharp/lib/sharp.js +0 -121
  444. package/.next/standalone/node_modules/sharp/lib/utility.js +0 -291
  445. package/.next/standalone/node_modules/sharp/node_modules/semver/classes/comparator.js +0 -143
  446. package/.next/standalone/node_modules/sharp/node_modules/semver/classes/range.js +0 -557
  447. package/.next/standalone/node_modules/sharp/node_modules/semver/classes/semver.js +0 -333
  448. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/cmp.js +0 -54
  449. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/coerce.js +0 -62
  450. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/compare.js +0 -7
  451. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/eq.js +0 -5
  452. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/gt.js +0 -5
  453. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/gte.js +0 -5
  454. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/lt.js +0 -5
  455. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/lte.js +0 -5
  456. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/neq.js +0 -5
  457. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/parse.js +0 -18
  458. package/.next/standalone/node_modules/sharp/node_modules/semver/functions/satisfies.js +0 -12
  459. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/constants.js +0 -37
  460. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/debug.js +0 -11
  461. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/identifiers.js +0 -29
  462. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/lrucache.js +0 -42
  463. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/parse-options.js +0 -17
  464. package/.next/standalone/node_modules/sharp/node_modules/semver/internal/re.js +0 -223
  465. package/.next/standalone/node_modules/sharp/node_modules/semver/package.json +0 -78
  466. package/.next/standalone/node_modules/sharp/package.json +0 -202
  467. package/.next/standalone/scripts/alias-proxy.js +0 -18
  468. package/.next/standalone/scripts/dev.ts +0 -3
  469. package/.next/standalone/scripts/install-telemetry.mjs +0 -108
  470. package/.next/standalone/scripts/launch.ts +0 -83
  471. package/.next/standalone/scripts/parse-script-args.ts +0 -87
  472. package/.next/standalone/scripts/postinstall.mjs +0 -121
  473. package/.next/standalone/scripts/preuninstall.mjs +0 -131
  474. package/.next/standalone/scripts/publish-aliases.mjs +0 -87
  475. package/.next/standalone/scripts/start.ts +0 -3
  476. package/.next/standalone/scripts/sync-hook-events-prompt.md +0 -60
  477. package/.next/standalone/scripts/translate-docs/cache.ts +0 -62
  478. package/.next/standalone/scripts/translate-docs/cli.ts +0 -357
  479. package/.next/standalone/scripts/translate-docs/config.ts +0 -248
  480. package/.next/standalone/scripts/translate-docs/mdx-translator.ts +0 -153
  481. package/.next/standalone/scripts/translate-docs/mintlify-nav.ts +0 -107
  482. package/.next/standalone/scripts/translate-docs/readme-translator.ts +0 -154
  483. package/.next/standalone/scripts/translate-docs/translator.ts +0 -68
  484. package/.next/standalone/scripts/translate-docs/types.ts +0 -43
  485. package/.next/standalone/src/cli-error.ts +0 -18
  486. package/.next/standalone/src/hooks/builtin-policies.ts +0 -1613
  487. package/.next/standalone/src/hooks/custom-hooks-loader.ts +0 -205
  488. package/.next/standalone/src/hooks/custom-hooks-registry.ts +0 -30
  489. package/.next/standalone/src/hooks/handler.ts +0 -202
  490. package/.next/standalone/src/hooks/hook-activity-store.ts +0 -349
  491. package/.next/standalone/src/hooks/hook-logger.ts +0 -133
  492. package/.next/standalone/src/hooks/hook-telemetry.ts +0 -43
  493. package/.next/standalone/src/hooks/hooks-config.ts +0 -166
  494. package/.next/standalone/src/hooks/install-prompt.ts +0 -357
  495. package/.next/standalone/src/hooks/llm-client.ts +0 -90
  496. package/.next/standalone/src/hooks/loader-utils.ts +0 -178
  497. package/.next/standalone/src/hooks/manager.ts +0 -692
  498. package/.next/standalone/src/hooks/policy-evaluator.ts +0 -224
  499. package/.next/standalone/src/hooks/policy-helpers.ts +0 -16
  500. package/.next/standalone/src/hooks/policy-registry.ts +0 -90
  501. package/.next/standalone/src/hooks/policy-types.ts +0 -77
  502. package/.next/standalone/src/hooks/types.ts +0 -63
  503. package/.next/standalone/src/index.ts +0 -19
  504. package/.next/standalone/src/posthog-key.ts +0 -5
  505. package/.next/standalone/tailwind.config.ts +0 -11
  506. package/.next/standalone/tsconfig.json +0 -42
  507. package/.next/standalone/vitest.config.e2e.mts +0 -24
  508. package/.next/standalone/vitest.config.mts +0 -23
  509. /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → wOkJXoch1UmRAmyIuKZWc}/_buildManifest.js +0 -0
  510. /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → wOkJXoch1UmRAmyIuKZWc}/_clientMiddlewareManifest.js +0 -0
  511. /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → wOkJXoch1UmRAmyIuKZWc}/_ssgManifest.js +0 -0
@@ -1,1016 +0,0 @@
1
- /*!
2
- Copyright 2013 Lovell Fuller and others.
3
- SPDX-License-Identifier: Apache-2.0
4
- */
5
-
6
- const is = require('./is');
7
-
8
- /**
9
- * How accurate an operation should be.
10
- * @member
11
- * @private
12
- */
13
- const vipsPrecision = {
14
- integer: 'integer',
15
- float: 'float',
16
- approximate: 'approximate'
17
- };
18
-
19
- /**
20
- * Rotate the output image.
21
- *
22
- * The provided angle is converted to a valid positive degree rotation.
23
- * For example, `-450` will produce a 270 degree rotation.
24
- *
25
- * When rotating by an angle other than a multiple of 90,
26
- * the background colour can be provided with the `background` option.
27
- *
28
- * For backwards compatibility, if no angle is provided, `.autoOrient()` will be called.
29
- *
30
- * Only one rotation can occur per pipeline (aside from an initial call without
31
- * arguments to orient via EXIF data). Previous calls to `rotate` in the same
32
- * pipeline will be ignored.
33
- *
34
- * Multi-page images can only be rotated by 180 degrees.
35
- *
36
- * Method order is important when rotating, resizing and/or extracting regions,
37
- * for example `.rotate(x).extract(y)` will produce a different result to `.extract(y).rotate(x)`.
38
- *
39
- * @example
40
- * const rotateThenResize = await sharp(input)
41
- * .rotate(90)
42
- * .resize({ width: 16, height: 8, fit: 'fill' })
43
- * .toBuffer();
44
- * const resizeThenRotate = await sharp(input)
45
- * .resize({ width: 16, height: 8, fit: 'fill' })
46
- * .rotate(90)
47
- * .toBuffer();
48
- *
49
- * @param {number} [angle=auto] angle of rotation.
50
- * @param {Object} [options] - if present, is an Object with optional attributes.
51
- * @param {string|Object} [options.background="#000000"] parsed by the [color](https://www.npmjs.org/package/color) module to extract values for red, green, blue and alpha.
52
- * @returns {Sharp}
53
- * @throws {Error} Invalid parameters
54
- */
55
- function rotate (angle, options) {
56
- if (!is.defined(angle)) {
57
- return this.autoOrient();
58
- }
59
- if (this.options.angle || this.options.rotationAngle) {
60
- this.options.debuglog('ignoring previous rotate options');
61
- this.options.angle = 0;
62
- this.options.rotationAngle = 0;
63
- }
64
- if (is.integer(angle) && !(angle % 90)) {
65
- this.options.angle = angle;
66
- } else if (is.number(angle)) {
67
- this.options.rotationAngle = angle;
68
- if (is.object(options) && options.background) {
69
- this._setBackgroundColourOption('rotationBackground', options.background);
70
- }
71
- } else {
72
- throw is.invalidParameterError('angle', 'numeric', angle);
73
- }
74
- return this;
75
- }
76
-
77
- /**
78
- * Auto-orient based on the EXIF `Orientation` tag, then remove the tag.
79
- * Mirroring is supported and may infer the use of a flip operation.
80
- *
81
- * Previous or subsequent use of `rotate(angle)` and either `flip()` or `flop()`
82
- * will logically occur after auto-orientation, regardless of call order.
83
- *
84
- * @example
85
- * const output = await sharp(input).autoOrient().toBuffer();
86
- *
87
- * @example
88
- * const pipeline = sharp()
89
- * .autoOrient()
90
- * .resize(null, 200)
91
- * .toBuffer(function (err, outputBuffer, info) {
92
- * // outputBuffer contains 200px high JPEG image data,
93
- * // auto-oriented using EXIF Orientation tag
94
- * // info.width and info.height contain the dimensions of the resized image
95
- * });
96
- * readableStream.pipe(pipeline);
97
- *
98
- * @returns {Sharp}
99
- */
100
- function autoOrient () {
101
- this.options.input.autoOrient = true;
102
- return this;
103
- }
104
-
105
- /**
106
- * Mirror the image vertically (up-down) about the x-axis.
107
- * This always occurs before rotation, if any.
108
- *
109
- * This operation does not work correctly with multi-page images.
110
- *
111
- * @example
112
- * const output = await sharp(input).flip().toBuffer();
113
- *
114
- * @param {Boolean} [flip=true]
115
- * @returns {Sharp}
116
- */
117
- function flip (flip) {
118
- this.options.flip = is.bool(flip) ? flip : true;
119
- return this;
120
- }
121
-
122
- /**
123
- * Mirror the image horizontally (left-right) about the y-axis.
124
- * This always occurs before rotation, if any.
125
- *
126
- * @example
127
- * const output = await sharp(input).flop().toBuffer();
128
- *
129
- * @param {Boolean} [flop=true]
130
- * @returns {Sharp}
131
- */
132
- function flop (flop) {
133
- this.options.flop = is.bool(flop) ? flop : true;
134
- return this;
135
- }
136
-
137
- /**
138
- * Perform an affine transform on an image. This operation will always occur after resizing, extraction and rotation, if any.
139
- *
140
- * You must provide an array of length 4 or a 2x2 affine transformation matrix.
141
- * By default, new pixels are filled with a black background. You can provide a background colour with the `background` option.
142
- * A particular interpolator may also be specified. Set the `interpolator` option to an attribute of the `sharp.interpolators` Object e.g. `sharp.interpolators.nohalo`.
143
- *
144
- * In the case of a 2x2 matrix, the transform is:
145
- * - X = `matrix[0, 0]` \* (x + `idx`) + `matrix[0, 1]` \* (y + `idy`) + `odx`
146
- * - Y = `matrix[1, 0]` \* (x + `idx`) + `matrix[1, 1]` \* (y + `idy`) + `ody`
147
- *
148
- * where:
149
- * - x and y are the coordinates in input image.
150
- * - X and Y are the coordinates in output image.
151
- * - (0,0) is the upper left corner.
152
- *
153
- * @since 0.27.0
154
- *
155
- * @example
156
- * const pipeline = sharp()
157
- * .affine([[1, 0.3], [0.1, 0.7]], {
158
- * background: 'white',
159
- * interpolator: sharp.interpolators.nohalo
160
- * })
161
- * .toBuffer((err, outputBuffer, info) => {
162
- * // outputBuffer contains the transformed image
163
- * // info.width and info.height contain the new dimensions
164
- * });
165
- *
166
- * inputStream
167
- * .pipe(pipeline);
168
- *
169
- * @param {Array<Array<number>>|Array<number>} matrix - affine transformation matrix
170
- * @param {Object} [options] - if present, is an Object with optional attributes.
171
- * @param {String|Object} [options.background="#000000"] - parsed by the [color](https://www.npmjs.org/package/color) module to extract values for red, green, blue and alpha.
172
- * @param {Number} [options.idx=0] - input horizontal offset
173
- * @param {Number} [options.idy=0] - input vertical offset
174
- * @param {Number} [options.odx=0] - output horizontal offset
175
- * @param {Number} [options.ody=0] - output vertical offset
176
- * @param {String} [options.interpolator=sharp.interpolators.bicubic] - interpolator
177
- * @returns {Sharp}
178
- * @throws {Error} Invalid parameters
179
- */
180
- function affine (matrix, options) {
181
- const flatMatrix = [].concat(...matrix);
182
- if (flatMatrix.length === 4 && flatMatrix.every(is.number)) {
183
- this.options.affineMatrix = flatMatrix;
184
- } else {
185
- throw is.invalidParameterError('matrix', '1x4 or 2x2 array', matrix);
186
- }
187
-
188
- if (is.defined(options)) {
189
- if (is.object(options)) {
190
- this._setBackgroundColourOption('affineBackground', options.background);
191
- if (is.defined(options.idx)) {
192
- if (is.number(options.idx)) {
193
- this.options.affineIdx = options.idx;
194
- } else {
195
- throw is.invalidParameterError('options.idx', 'number', options.idx);
196
- }
197
- }
198
- if (is.defined(options.idy)) {
199
- if (is.number(options.idy)) {
200
- this.options.affineIdy = options.idy;
201
- } else {
202
- throw is.invalidParameterError('options.idy', 'number', options.idy);
203
- }
204
- }
205
- if (is.defined(options.odx)) {
206
- if (is.number(options.odx)) {
207
- this.options.affineOdx = options.odx;
208
- } else {
209
- throw is.invalidParameterError('options.odx', 'number', options.odx);
210
- }
211
- }
212
- if (is.defined(options.ody)) {
213
- if (is.number(options.ody)) {
214
- this.options.affineOdy = options.ody;
215
- } else {
216
- throw is.invalidParameterError('options.ody', 'number', options.ody);
217
- }
218
- }
219
- if (is.defined(options.interpolator)) {
220
- if (is.inArray(options.interpolator, Object.values(this.constructor.interpolators))) {
221
- this.options.affineInterpolator = options.interpolator;
222
- } else {
223
- throw is.invalidParameterError('options.interpolator', 'valid interpolator name', options.interpolator);
224
- }
225
- }
226
- } else {
227
- throw is.invalidParameterError('options', 'object', options);
228
- }
229
- }
230
-
231
- return this;
232
- }
233
-
234
- /**
235
- * Sharpen the image.
236
- *
237
- * When used without parameters, performs a fast, mild sharpen of the output image.
238
- *
239
- * When a `sigma` is provided, performs a slower, more accurate sharpen of the L channel in the LAB colour space.
240
- * Fine-grained control over the level of sharpening in "flat" (m1) and "jagged" (m2) areas is available.
241
- *
242
- * See {@link https://www.libvips.org/API/current/method.Image.sharpen.html libvips sharpen} operation.
243
- *
244
- * @example
245
- * const data = await sharp(input).sharpen().toBuffer();
246
- *
247
- * @example
248
- * const data = await sharp(input).sharpen({ sigma: 2 }).toBuffer();
249
- *
250
- * @example
251
- * const data = await sharp(input)
252
- * .sharpen({
253
- * sigma: 2,
254
- * m1: 0,
255
- * m2: 3,
256
- * x1: 3,
257
- * y2: 15,
258
- * y3: 15,
259
- * })
260
- * .toBuffer();
261
- *
262
- * @param {Object|number} [options] - if present, is an Object with attributes
263
- * @param {number} [options.sigma] - the sigma of the Gaussian mask, where `sigma = 1 + radius / 2`, between 0.000001 and 10
264
- * @param {number} [options.m1=1.0] - the level of sharpening to apply to "flat" areas, between 0 and 1000000
265
- * @param {number} [options.m2=2.0] - the level of sharpening to apply to "jagged" areas, between 0 and 1000000
266
- * @param {number} [options.x1=2.0] - threshold between "flat" and "jagged", between 0 and 1000000
267
- * @param {number} [options.y2=10.0] - maximum amount of brightening, between 0 and 1000000
268
- * @param {number} [options.y3=20.0] - maximum amount of darkening, between 0 and 1000000
269
- * @param {number} [flat] - (deprecated) see `options.m1`.
270
- * @param {number} [jagged] - (deprecated) see `options.m2`.
271
- * @returns {Sharp}
272
- * @throws {Error} Invalid parameters
273
- */
274
- function sharpen (options, flat, jagged) {
275
- if (!is.defined(options)) {
276
- // No arguments: default to mild sharpen
277
- this.options.sharpenSigma = -1;
278
- } else if (is.bool(options)) {
279
- // Deprecated boolean argument: apply mild sharpen?
280
- this.options.sharpenSigma = options ? -1 : 0;
281
- } else if (is.number(options) && is.inRange(options, 0.01, 10000)) {
282
- // Deprecated numeric argument: specific sigma
283
- this.options.sharpenSigma = options;
284
- // Deprecated control over flat areas
285
- if (is.defined(flat)) {
286
- if (is.number(flat) && is.inRange(flat, 0, 10000)) {
287
- this.options.sharpenM1 = flat;
288
- } else {
289
- throw is.invalidParameterError('flat', 'number between 0 and 10000', flat);
290
- }
291
- }
292
- // Deprecated control over jagged areas
293
- if (is.defined(jagged)) {
294
- if (is.number(jagged) && is.inRange(jagged, 0, 10000)) {
295
- this.options.sharpenM2 = jagged;
296
- } else {
297
- throw is.invalidParameterError('jagged', 'number between 0 and 10000', jagged);
298
- }
299
- }
300
- } else if (is.plainObject(options)) {
301
- if (is.number(options.sigma) && is.inRange(options.sigma, 0.000001, 10)) {
302
- this.options.sharpenSigma = options.sigma;
303
- } else {
304
- throw is.invalidParameterError('options.sigma', 'number between 0.000001 and 10', options.sigma);
305
- }
306
- if (is.defined(options.m1)) {
307
- if (is.number(options.m1) && is.inRange(options.m1, 0, 1000000)) {
308
- this.options.sharpenM1 = options.m1;
309
- } else {
310
- throw is.invalidParameterError('options.m1', 'number between 0 and 1000000', options.m1);
311
- }
312
- }
313
- if (is.defined(options.m2)) {
314
- if (is.number(options.m2) && is.inRange(options.m2, 0, 1000000)) {
315
- this.options.sharpenM2 = options.m2;
316
- } else {
317
- throw is.invalidParameterError('options.m2', 'number between 0 and 1000000', options.m2);
318
- }
319
- }
320
- if (is.defined(options.x1)) {
321
- if (is.number(options.x1) && is.inRange(options.x1, 0, 1000000)) {
322
- this.options.sharpenX1 = options.x1;
323
- } else {
324
- throw is.invalidParameterError('options.x1', 'number between 0 and 1000000', options.x1);
325
- }
326
- }
327
- if (is.defined(options.y2)) {
328
- if (is.number(options.y2) && is.inRange(options.y2, 0, 1000000)) {
329
- this.options.sharpenY2 = options.y2;
330
- } else {
331
- throw is.invalidParameterError('options.y2', 'number between 0 and 1000000', options.y2);
332
- }
333
- }
334
- if (is.defined(options.y3)) {
335
- if (is.number(options.y3) && is.inRange(options.y3, 0, 1000000)) {
336
- this.options.sharpenY3 = options.y3;
337
- } else {
338
- throw is.invalidParameterError('options.y3', 'number between 0 and 1000000', options.y3);
339
- }
340
- }
341
- } else {
342
- throw is.invalidParameterError('sigma', 'number between 0.01 and 10000', options);
343
- }
344
- return this;
345
- }
346
-
347
- /**
348
- * Apply median filter.
349
- * When used without parameters the default window is 3x3.
350
- *
351
- * @example
352
- * const output = await sharp(input).median().toBuffer();
353
- *
354
- * @example
355
- * const output = await sharp(input).median(5).toBuffer();
356
- *
357
- * @param {number} [size=3] square mask size: size x size
358
- * @returns {Sharp}
359
- * @throws {Error} Invalid parameters
360
- */
361
- function median (size) {
362
- if (!is.defined(size)) {
363
- // No arguments: default to 3x3
364
- this.options.medianSize = 3;
365
- } else if (is.integer(size) && is.inRange(size, 1, 1000)) {
366
- // Numeric argument: specific sigma
367
- this.options.medianSize = size;
368
- } else {
369
- throw is.invalidParameterError('size', 'integer between 1 and 1000', size);
370
- }
371
- return this;
372
- }
373
-
374
- /**
375
- * Blur the image.
376
- *
377
- * When used without parameters, performs a fast 3x3 box blur (equivalent to a box linear filter).
378
- *
379
- * When a `sigma` is provided, performs a slower, more accurate Gaussian blur.
380
- *
381
- * @example
382
- * const boxBlurred = await sharp(input)
383
- * .blur()
384
- * .toBuffer();
385
- *
386
- * @example
387
- * const gaussianBlurred = await sharp(input)
388
- * .blur(5)
389
- * .toBuffer();
390
- *
391
- * @param {Object|number|Boolean} [options]
392
- * @param {number} [options.sigma] a value between 0.3 and 1000 representing the sigma of the Gaussian mask, where `sigma = 1 + radius / 2`.
393
- * @param {string} [options.precision='integer'] How accurate the operation should be, one of: integer, float, approximate.
394
- * @param {number} [options.minAmplitude=0.2] A value between 0.001 and 1. A smaller value will generate a larger, more accurate mask.
395
- * @returns {Sharp}
396
- * @throws {Error} Invalid parameters
397
- */
398
- function blur (options) {
399
- let sigma;
400
- if (is.number(options)) {
401
- sigma = options;
402
- } else if (is.plainObject(options)) {
403
- if (!is.number(options.sigma)) {
404
- throw is.invalidParameterError('options.sigma', 'number between 0.3 and 1000', sigma);
405
- }
406
- sigma = options.sigma;
407
- if ('precision' in options) {
408
- if (is.string(vipsPrecision[options.precision])) {
409
- this.options.precision = vipsPrecision[options.precision];
410
- } else {
411
- throw is.invalidParameterError('precision', 'one of: integer, float, approximate', options.precision);
412
- }
413
- }
414
- if ('minAmplitude' in options) {
415
- if (is.number(options.minAmplitude) && is.inRange(options.minAmplitude, 0.001, 1)) {
416
- this.options.minAmpl = options.minAmplitude;
417
- } else {
418
- throw is.invalidParameterError('minAmplitude', 'number between 0.001 and 1', options.minAmplitude);
419
- }
420
- }
421
- }
422
-
423
- if (!is.defined(options)) {
424
- // No arguments: default to mild blur
425
- this.options.blurSigma = -1;
426
- } else if (is.bool(options)) {
427
- // Boolean argument: apply mild blur?
428
- this.options.blurSigma = options ? -1 : 0;
429
- } else if (is.number(sigma) && is.inRange(sigma, 0.3, 1000)) {
430
- // Numeric argument: specific sigma
431
- this.options.blurSigma = sigma;
432
- } else {
433
- throw is.invalidParameterError('sigma', 'number between 0.3 and 1000', sigma);
434
- }
435
-
436
- return this;
437
- }
438
-
439
- /**
440
- * Expand foreground objects using the dilate morphological operator.
441
- *
442
- * @example
443
- * const output = await sharp(input)
444
- * .dilate()
445
- * .toBuffer();
446
- *
447
- * @param {Number} [width=1] dilation width in pixels.
448
- * @returns {Sharp}
449
- * @throws {Error} Invalid parameters
450
- */
451
- function dilate (width) {
452
- if (!is.defined(width)) {
453
- this.options.dilateWidth = 1;
454
- } else if (is.integer(width) && width > 0) {
455
- this.options.dilateWidth = width;
456
- } else {
457
- throw is.invalidParameterError('dilate', 'positive integer', dilate);
458
- }
459
- return this;
460
- }
461
-
462
- /**
463
- * Shrink foreground objects using the erode morphological operator.
464
- *
465
- * @example
466
- * const output = await sharp(input)
467
- * .erode()
468
- * .toBuffer();
469
- *
470
- * @param {Number} [width=1] erosion width in pixels.
471
- * @returns {Sharp}
472
- * @throws {Error} Invalid parameters
473
- */
474
- function erode (width) {
475
- if (!is.defined(width)) {
476
- this.options.erodeWidth = 1;
477
- } else if (is.integer(width) && width > 0) {
478
- this.options.erodeWidth = width;
479
- } else {
480
- throw is.invalidParameterError('erode', 'positive integer', erode);
481
- }
482
- return this;
483
- }
484
-
485
- /**
486
- * Merge alpha transparency channel, if any, with a background, then remove the alpha channel.
487
- *
488
- * See also {@link /api-channel#removealpha removeAlpha}.
489
- *
490
- * @example
491
- * await sharp(rgbaInput)
492
- * .flatten({ background: '#F0A703' })
493
- * .toBuffer();
494
- *
495
- * @param {Object} [options]
496
- * @param {string|Object} [options.background={r: 0, g: 0, b: 0}] - background colour, parsed by the [color](https://www.npmjs.org/package/color) module, defaults to black.
497
- * @returns {Sharp}
498
- */
499
- function flatten (options) {
500
- this.options.flatten = is.bool(options) ? options : true;
501
- if (is.object(options)) {
502
- this._setBackgroundColourOption('flattenBackground', options.background);
503
- }
504
- return this;
505
- }
506
-
507
- /**
508
- * Ensure the image has an alpha channel
509
- * with all white pixel values made fully transparent.
510
- *
511
- * Existing alpha channel values for non-white pixels remain unchanged.
512
- *
513
- * This feature is experimental and the API may change.
514
- *
515
- * @since 0.32.1
516
- *
517
- * @example
518
- * await sharp(rgbInput)
519
- * .unflatten()
520
- * .toBuffer();
521
- *
522
- * @example
523
- * await sharp(rgbInput)
524
- * .threshold(128, { grayscale: false }) // converter bright pixels to white
525
- * .unflatten()
526
- * .toBuffer();
527
- */
528
- function unflatten () {
529
- this.options.unflatten = true;
530
- return this;
531
- }
532
-
533
- /**
534
- * Apply a gamma correction by reducing the encoding (darken) pre-resize at a factor of `1/gamma`
535
- * then increasing the encoding (brighten) post-resize at a factor of `gamma`.
536
- * This can improve the perceived brightness of a resized image in non-linear colour spaces.
537
- * JPEG and WebP input images will not take advantage of the shrink-on-load performance optimisation
538
- * when applying a gamma correction.
539
- *
540
- * Supply a second argument to use a different output gamma value, otherwise the first value is used in both cases.
541
- *
542
- * @param {number} [gamma=2.2] value between 1.0 and 3.0.
543
- * @param {number} [gammaOut] value between 1.0 and 3.0. (optional, defaults to same as `gamma`)
544
- * @returns {Sharp}
545
- * @throws {Error} Invalid parameters
546
- */
547
- function gamma (gamma, gammaOut) {
548
- if (!is.defined(gamma)) {
549
- // Default gamma correction of 2.2 (sRGB)
550
- this.options.gamma = 2.2;
551
- } else if (is.number(gamma) && is.inRange(gamma, 1, 3)) {
552
- this.options.gamma = gamma;
553
- } else {
554
- throw is.invalidParameterError('gamma', 'number between 1.0 and 3.0', gamma);
555
- }
556
- if (!is.defined(gammaOut)) {
557
- // Default gamma correction for output is same as input
558
- this.options.gammaOut = this.options.gamma;
559
- } else if (is.number(gammaOut) && is.inRange(gammaOut, 1, 3)) {
560
- this.options.gammaOut = gammaOut;
561
- } else {
562
- throw is.invalidParameterError('gammaOut', 'number between 1.0 and 3.0', gammaOut);
563
- }
564
- return this;
565
- }
566
-
567
- /**
568
- * Produce the "negative" of the image.
569
- *
570
- * @example
571
- * const output = await sharp(input)
572
- * .negate()
573
- * .toBuffer();
574
- *
575
- * @example
576
- * const output = await sharp(input)
577
- * .negate({ alpha: false })
578
- * .toBuffer();
579
- *
580
- * @param {Object} [options]
581
- * @param {Boolean} [options.alpha=true] Whether or not to negate any alpha channel
582
- * @returns {Sharp}
583
- */
584
- function negate (options) {
585
- this.options.negate = is.bool(options) ? options : true;
586
- if (is.plainObject(options) && 'alpha' in options) {
587
- if (!is.bool(options.alpha)) {
588
- throw is.invalidParameterError('alpha', 'should be boolean value', options.alpha);
589
- } else {
590
- this.options.negateAlpha = options.alpha;
591
- }
592
- }
593
- return this;
594
- }
595
-
596
- /**
597
- * Enhance output image contrast by stretching its luminance to cover a full dynamic range.
598
- *
599
- * Uses a histogram-based approach, taking a default range of 1% to 99% to reduce sensitivity to noise at the extremes.
600
- *
601
- * Luminance values below the `lower` percentile will be underexposed by clipping to zero.
602
- * Luminance values above the `upper` percentile will be overexposed by clipping to the max pixel value.
603
- *
604
- * @example
605
- * const output = await sharp(input)
606
- * .normalise()
607
- * .toBuffer();
608
- *
609
- * @example
610
- * const output = await sharp(input)
611
- * .normalise({ lower: 0, upper: 100 })
612
- * .toBuffer();
613
- *
614
- * @param {Object} [options]
615
- * @param {number} [options.lower=1] - Percentile below which luminance values will be underexposed.
616
- * @param {number} [options.upper=99] - Percentile above which luminance values will be overexposed.
617
- * @returns {Sharp}
618
- */
619
- function normalise (options) {
620
- if (is.plainObject(options)) {
621
- if (is.defined(options.lower)) {
622
- if (is.number(options.lower) && is.inRange(options.lower, 0, 99)) {
623
- this.options.normaliseLower = options.lower;
624
- } else {
625
- throw is.invalidParameterError('lower', 'number between 0 and 99', options.lower);
626
- }
627
- }
628
- if (is.defined(options.upper)) {
629
- if (is.number(options.upper) && is.inRange(options.upper, 1, 100)) {
630
- this.options.normaliseUpper = options.upper;
631
- } else {
632
- throw is.invalidParameterError('upper', 'number between 1 and 100', options.upper);
633
- }
634
- }
635
- }
636
- if (this.options.normaliseLower >= this.options.normaliseUpper) {
637
- throw is.invalidParameterError('range', 'lower to be less than upper',
638
- `${this.options.normaliseLower} >= ${this.options.normaliseUpper}`);
639
- }
640
- this.options.normalise = true;
641
- return this;
642
- }
643
-
644
- /**
645
- * Alternative spelling of normalise.
646
- *
647
- * @example
648
- * const output = await sharp(input)
649
- * .normalize()
650
- * .toBuffer();
651
- *
652
- * @param {Object} [options]
653
- * @param {number} [options.lower=1] - Percentile below which luminance values will be underexposed.
654
- * @param {number} [options.upper=99] - Percentile above which luminance values will be overexposed.
655
- * @returns {Sharp}
656
- */
657
- function normalize (options) {
658
- return this.normalise(options);
659
- }
660
-
661
- /**
662
- * Perform contrast limiting adaptive histogram equalization
663
- * {@link https://en.wikipedia.org/wiki/Adaptive_histogram_equalization#Contrast_Limited_AHE CLAHE}.
664
- *
665
- * This will, in general, enhance the clarity of the image by bringing out darker details.
666
- *
667
- * @since 0.28.3
668
- *
669
- * @example
670
- * const output = await sharp(input)
671
- * .clahe({
672
- * width: 3,
673
- * height: 3,
674
- * })
675
- * .toBuffer();
676
- *
677
- * @param {Object} options
678
- * @param {number} options.width - Integral width of the search window, in pixels.
679
- * @param {number} options.height - Integral height of the search window, in pixels.
680
- * @param {number} [options.maxSlope=3] - Integral level of brightening, between 0 and 100, where 0 disables contrast limiting.
681
- * @returns {Sharp}
682
- * @throws {Error} Invalid parameters
683
- */
684
- function clahe (options) {
685
- if (is.plainObject(options)) {
686
- if (is.integer(options.width) && options.width > 0) {
687
- this.options.claheWidth = options.width;
688
- } else {
689
- throw is.invalidParameterError('width', 'integer greater than zero', options.width);
690
- }
691
- if (is.integer(options.height) && options.height > 0) {
692
- this.options.claheHeight = options.height;
693
- } else {
694
- throw is.invalidParameterError('height', 'integer greater than zero', options.height);
695
- }
696
- if (is.defined(options.maxSlope)) {
697
- if (is.integer(options.maxSlope) && is.inRange(options.maxSlope, 0, 100)) {
698
- this.options.claheMaxSlope = options.maxSlope;
699
- } else {
700
- throw is.invalidParameterError('maxSlope', 'integer between 0 and 100', options.maxSlope);
701
- }
702
- }
703
- } else {
704
- throw is.invalidParameterError('options', 'plain object', options);
705
- }
706
- return this;
707
- }
708
-
709
- /**
710
- * Convolve the image with the specified kernel.
711
- *
712
- * @example
713
- * sharp(input)
714
- * .convolve({
715
- * width: 3,
716
- * height: 3,
717
- * kernel: [-1, 0, 1, -2, 0, 2, -1, 0, 1]
718
- * })
719
- * .raw()
720
- * .toBuffer(function(err, data, info) {
721
- * // data contains the raw pixel data representing the convolution
722
- * // of the input image with the horizontal Sobel operator
723
- * });
724
- *
725
- * @param {Object} kernel
726
- * @param {number} kernel.width - width of the kernel in pixels.
727
- * @param {number} kernel.height - height of the kernel in pixels.
728
- * @param {Array<number>} kernel.kernel - Array of length `width*height` containing the kernel values.
729
- * @param {number} [kernel.scale=sum] - the scale of the kernel in pixels.
730
- * @param {number} [kernel.offset=0] - the offset of the kernel in pixels.
731
- * @returns {Sharp}
732
- * @throws {Error} Invalid parameters
733
- */
734
- function convolve (kernel) {
735
- if (!is.object(kernel) || !Array.isArray(kernel.kernel) ||
736
- !is.integer(kernel.width) || !is.integer(kernel.height) ||
737
- !is.inRange(kernel.width, 3, 1001) || !is.inRange(kernel.height, 3, 1001) ||
738
- kernel.height * kernel.width !== kernel.kernel.length
739
- ) {
740
- // must pass in a kernel
741
- throw new Error('Invalid convolution kernel');
742
- }
743
- // Default scale is sum of kernel values
744
- if (!is.integer(kernel.scale)) {
745
- kernel.scale = kernel.kernel.reduce((a, b) => a + b, 0);
746
- }
747
- // Clip scale to a minimum value of 1
748
- if (kernel.scale < 1) {
749
- kernel.scale = 1;
750
- }
751
- if (!is.integer(kernel.offset)) {
752
- kernel.offset = 0;
753
- }
754
- this.options.convKernel = kernel;
755
- return this;
756
- }
757
-
758
- /**
759
- * Any pixel value greater than or equal to the threshold value will be set to 255, otherwise it will be set to 0.
760
- * @param {number} [threshold=128] - a value in the range 0-255 representing the level at which the threshold will be applied.
761
- * @param {Object} [options]
762
- * @param {Boolean} [options.greyscale=true] - convert to single channel greyscale.
763
- * @param {Boolean} [options.grayscale=true] - alternative spelling for greyscale.
764
- * @returns {Sharp}
765
- * @throws {Error} Invalid parameters
766
- */
767
- function threshold (threshold, options) {
768
- if (!is.defined(threshold)) {
769
- this.options.threshold = 128;
770
- } else if (is.bool(threshold)) {
771
- this.options.threshold = threshold ? 128 : 0;
772
- } else if (is.integer(threshold) && is.inRange(threshold, 0, 255)) {
773
- this.options.threshold = threshold;
774
- } else {
775
- throw is.invalidParameterError('threshold', 'integer between 0 and 255', threshold);
776
- }
777
- if (!is.object(options) || options.greyscale === true || options.grayscale === true) {
778
- this.options.thresholdGrayscale = true;
779
- } else {
780
- this.options.thresholdGrayscale = false;
781
- }
782
- return this;
783
- }
784
-
785
- /**
786
- * Perform a bitwise boolean operation with operand image.
787
- *
788
- * This operation creates an output image where each pixel is the result of
789
- * the selected bitwise boolean `operation` between the corresponding pixels of the input images.
790
- *
791
- * @param {Buffer|string} operand - Buffer containing image data or string containing the path to an image file.
792
- * @param {string} operator - one of `and`, `or` or `eor` to perform that bitwise operation, like the C logic operators `&`, `|` and `^` respectively.
793
- * @param {Object} [options]
794
- * @param {Object} [options.raw] - describes operand when using raw pixel data.
795
- * @param {number} [options.raw.width]
796
- * @param {number} [options.raw.height]
797
- * @param {number} [options.raw.channels]
798
- * @returns {Sharp}
799
- * @throws {Error} Invalid parameters
800
- */
801
- function boolean (operand, operator, options) {
802
- this.options.boolean = this._createInputDescriptor(operand, options);
803
- if (is.string(operator) && is.inArray(operator, ['and', 'or', 'eor'])) {
804
- this.options.booleanOp = operator;
805
- } else {
806
- throw is.invalidParameterError('operator', 'one of: and, or, eor', operator);
807
- }
808
- return this;
809
- }
810
-
811
- /**
812
- * Apply the linear formula `a` * input + `b` to the image to adjust image levels.
813
- *
814
- * When a single number is provided, it will be used for all image channels.
815
- * When an array of numbers is provided, the array length must match the number of channels.
816
- *
817
- * @example
818
- * await sharp(input)
819
- * .linear(0.5, 2)
820
- * .toBuffer();
821
- *
822
- * @example
823
- * await sharp(rgbInput)
824
- * .linear(
825
- * [0.25, 0.5, 0.75],
826
- * [150, 100, 50]
827
- * )
828
- * .toBuffer();
829
- *
830
- * @param {(number|number[])} [a=[]] multiplier
831
- * @param {(number|number[])} [b=[]] offset
832
- * @returns {Sharp}
833
- * @throws {Error} Invalid parameters
834
- */
835
- function linear (a, b) {
836
- if (!is.defined(a) && is.number(b)) {
837
- a = 1.0;
838
- } else if (is.number(a) && !is.defined(b)) {
839
- b = 0.0;
840
- }
841
- if (!is.defined(a)) {
842
- this.options.linearA = [];
843
- } else if (is.number(a)) {
844
- this.options.linearA = [a];
845
- } else if (Array.isArray(a) && a.length && a.every(is.number)) {
846
- this.options.linearA = a;
847
- } else {
848
- throw is.invalidParameterError('a', 'number or array of numbers', a);
849
- }
850
- if (!is.defined(b)) {
851
- this.options.linearB = [];
852
- } else if (is.number(b)) {
853
- this.options.linearB = [b];
854
- } else if (Array.isArray(b) && b.length && b.every(is.number)) {
855
- this.options.linearB = b;
856
- } else {
857
- throw is.invalidParameterError('b', 'number or array of numbers', b);
858
- }
859
- if (this.options.linearA.length !== this.options.linearB.length) {
860
- throw new Error('Expected a and b to be arrays of the same length');
861
- }
862
- return this;
863
- }
864
-
865
- /**
866
- * Recombine the image with the specified matrix.
867
- *
868
- * @since 0.21.1
869
- *
870
- * @example
871
- * sharp(input)
872
- * .recomb([
873
- * [0.3588, 0.7044, 0.1368],
874
- * [0.2990, 0.5870, 0.1140],
875
- * [0.2392, 0.4696, 0.0912],
876
- * ])
877
- * .raw()
878
- * .toBuffer(function(err, data, info) {
879
- * // data contains the raw pixel data after applying the matrix
880
- * // With this example input, a sepia filter has been applied
881
- * });
882
- *
883
- * @param {Array<Array<number>>} inputMatrix - 3x3 or 4x4 Recombination matrix
884
- * @returns {Sharp}
885
- * @throws {Error} Invalid parameters
886
- */
887
- function recomb (inputMatrix) {
888
- if (!Array.isArray(inputMatrix)) {
889
- throw is.invalidParameterError('inputMatrix', 'array', inputMatrix);
890
- }
891
- if (inputMatrix.length !== 3 && inputMatrix.length !== 4) {
892
- throw is.invalidParameterError('inputMatrix', '3x3 or 4x4 array', inputMatrix.length);
893
- }
894
- const recombMatrix = inputMatrix.flat().map(Number);
895
- if (recombMatrix.length !== 9 && recombMatrix.length !== 16) {
896
- throw is.invalidParameterError('inputMatrix', 'cardinality of 9 or 16', recombMatrix.length);
897
- }
898
- this.options.recombMatrix = recombMatrix;
899
- return this;
900
- }
901
-
902
- /**
903
- * Transforms the image using brightness, saturation, hue rotation, and lightness.
904
- * Brightness and lightness both operate on luminance, with the difference being that
905
- * brightness is multiplicative whereas lightness is additive.
906
- *
907
- * @since 0.22.1
908
- *
909
- * @example
910
- * // increase brightness by a factor of 2
911
- * const output = await sharp(input)
912
- * .modulate({
913
- * brightness: 2
914
- * })
915
- * .toBuffer();
916
- *
917
- * @example
918
- * // hue-rotate by 180 degrees
919
- * const output = await sharp(input)
920
- * .modulate({
921
- * hue: 180
922
- * })
923
- * .toBuffer();
924
- *
925
- * @example
926
- * // increase lightness by +50
927
- * const output = await sharp(input)
928
- * .modulate({
929
- * lightness: 50
930
- * })
931
- * .toBuffer();
932
- *
933
- * @example
934
- * // decrease brightness and saturation while also hue-rotating by 90 degrees
935
- * const output = await sharp(input)
936
- * .modulate({
937
- * brightness: 0.5,
938
- * saturation: 0.5,
939
- * hue: 90,
940
- * })
941
- * .toBuffer();
942
- *
943
- * @param {Object} [options]
944
- * @param {number} [options.brightness] Brightness multiplier
945
- * @param {number} [options.saturation] Saturation multiplier
946
- * @param {number} [options.hue] Degrees for hue rotation
947
- * @param {number} [options.lightness] Lightness addend
948
- * @returns {Sharp}
949
- */
950
- function modulate (options) {
951
- if (!is.plainObject(options)) {
952
- throw is.invalidParameterError('options', 'plain object', options);
953
- }
954
- if ('brightness' in options) {
955
- if (is.number(options.brightness) && options.brightness >= 0) {
956
- this.options.brightness = options.brightness;
957
- } else {
958
- throw is.invalidParameterError('brightness', 'number above zero', options.brightness);
959
- }
960
- }
961
- if ('saturation' in options) {
962
- if (is.number(options.saturation) && options.saturation >= 0) {
963
- this.options.saturation = options.saturation;
964
- } else {
965
- throw is.invalidParameterError('saturation', 'number above zero', options.saturation);
966
- }
967
- }
968
- if ('hue' in options) {
969
- if (is.integer(options.hue)) {
970
- this.options.hue = options.hue % 360;
971
- } else {
972
- throw is.invalidParameterError('hue', 'number', options.hue);
973
- }
974
- }
975
- if ('lightness' in options) {
976
- if (is.number(options.lightness)) {
977
- this.options.lightness = options.lightness;
978
- } else {
979
- throw is.invalidParameterError('lightness', 'number', options.lightness);
980
- }
981
- }
982
- return this;
983
- }
984
-
985
- /**
986
- * Decorate the Sharp prototype with operation-related functions.
987
- * @module Sharp
988
- * @private
989
- */
990
- module.exports = (Sharp) => {
991
- Object.assign(Sharp.prototype, {
992
- autoOrient,
993
- rotate,
994
- flip,
995
- flop,
996
- affine,
997
- sharpen,
998
- erode,
999
- dilate,
1000
- median,
1001
- blur,
1002
- flatten,
1003
- unflatten,
1004
- gamma,
1005
- negate,
1006
- normalise,
1007
- normalize,
1008
- clahe,
1009
- convolve,
1010
- threshold,
1011
- boolean,
1012
- linear,
1013
- recomb,
1014
- modulate
1015
- });
1016
- };