recker 1.0.2-0 → 1.0.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 (287) hide show
  1. package/LICENSE +0 -2
  2. package/README.md +121 -72
  3. package/dist/cache/memory-storage.d.ts.map +1 -1
  4. package/dist/cache/memory-storage.js +7 -1
  5. package/dist/constants/http-status.d.ts +74 -0
  6. package/dist/constants/http-status.d.ts.map +1 -0
  7. package/dist/constants/http-status.js +156 -0
  8. package/dist/constants.d.ts.map +1 -1
  9. package/dist/constants.js +6 -6
  10. package/dist/cookies/memory-cookie-jar.d.ts +31 -0
  11. package/dist/cookies/memory-cookie-jar.d.ts.map +1 -0
  12. package/dist/cookies/memory-cookie-jar.js +210 -0
  13. package/dist/core/client.d.ts +9 -0
  14. package/dist/core/client.d.ts.map +1 -1
  15. package/dist/core/client.js +252 -53
  16. package/dist/core/errors.d.ts +18 -2
  17. package/dist/core/errors.d.ts.map +1 -1
  18. package/dist/core/errors.js +66 -5
  19. package/dist/core/index.d.ts +6 -0
  20. package/dist/core/index.d.ts.map +1 -0
  21. package/dist/core/index.js +5 -0
  22. package/dist/core/request-promise.d.ts.map +1 -1
  23. package/dist/core/request-promise.js +8 -2
  24. package/dist/core/request.d.ts +7 -1
  25. package/dist/core/request.d.ts.map +1 -1
  26. package/dist/core/request.js +32 -0
  27. package/dist/core/response.d.ts +2 -0
  28. package/dist/core/response.d.ts.map +1 -1
  29. package/dist/core/response.js +44 -19
  30. package/dist/events/request-events.d.ts +48 -0
  31. package/dist/events/request-events.d.ts.map +1 -0
  32. package/dist/events/request-events.js +85 -0
  33. package/dist/index.d.ts +28 -2
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.js +28 -2
  36. package/dist/mcp/client.d.ts.map +1 -1
  37. package/dist/mcp/client.js +16 -5
  38. package/dist/mcp/contract.d.ts +77 -0
  39. package/dist/mcp/contract.d.ts.map +1 -0
  40. package/dist/mcp/contract.js +278 -0
  41. package/dist/mcp/types.d.ts +1 -0
  42. package/dist/mcp/types.d.ts.map +1 -1
  43. package/dist/plugins/auth.d.ts +45 -0
  44. package/dist/plugins/auth.d.ts.map +1 -0
  45. package/dist/plugins/auth.js +268 -0
  46. package/dist/plugins/cache.d.ts +7 -1
  47. package/dist/plugins/cache.d.ts.map +1 -1
  48. package/dist/plugins/cache.js +470 -49
  49. package/dist/plugins/circuit-breaker.js +1 -1
  50. package/dist/plugins/compression.d.ts.map +1 -1
  51. package/dist/plugins/compression.js +3 -3
  52. package/dist/plugins/dedup.d.ts.map +1 -1
  53. package/dist/plugins/dedup.js +2 -1
  54. package/dist/plugins/graphql.d.ts +4 -3
  55. package/dist/plugins/graphql.d.ts.map +1 -1
  56. package/dist/plugins/graphql.js +24 -5
  57. package/dist/plugins/grpc-web.d.ts +80 -0
  58. package/dist/plugins/grpc-web.d.ts.map +1 -0
  59. package/dist/plugins/grpc-web.js +261 -0
  60. package/dist/plugins/har-player.d.ts.map +1 -1
  61. package/dist/plugins/har-player.js +11 -2
  62. package/dist/plugins/hls.d.ts +33 -0
  63. package/dist/plugins/hls.d.ts.map +1 -0
  64. package/dist/plugins/hls.js +225 -0
  65. package/dist/plugins/http2-push.d.ts +64 -0
  66. package/dist/plugins/http2-push.d.ts.map +1 -0
  67. package/dist/plugins/http2-push.js +274 -0
  68. package/dist/plugins/http3.d.ts +76 -0
  69. package/dist/plugins/http3.d.ts.map +1 -0
  70. package/dist/plugins/http3.js +231 -0
  71. package/dist/plugins/interface-rotator.d.ts +10 -0
  72. package/dist/plugins/interface-rotator.d.ts.map +1 -0
  73. package/dist/plugins/interface-rotator.js +57 -0
  74. package/dist/plugins/jsonrpc.d.ts +76 -0
  75. package/dist/plugins/jsonrpc.d.ts.map +1 -0
  76. package/dist/plugins/jsonrpc.js +143 -0
  77. package/dist/plugins/logger.d.ts +8 -5
  78. package/dist/plugins/logger.d.ts.map +1 -1
  79. package/dist/plugins/logger.js +66 -30
  80. package/dist/plugins/odata.d.ts +182 -0
  81. package/dist/plugins/odata.d.ts.map +1 -0
  82. package/dist/plugins/odata.js +561 -0
  83. package/dist/plugins/retry.d.ts +1 -0
  84. package/dist/plugins/retry.d.ts.map +1 -1
  85. package/dist/plugins/retry.js +26 -2
  86. package/dist/plugins/scrape.d.ts +22 -0
  87. package/dist/plugins/scrape.d.ts.map +1 -0
  88. package/dist/plugins/scrape.js +87 -0
  89. package/dist/plugins/soap.d.ts +73 -0
  90. package/dist/plugins/soap.d.ts.map +1 -0
  91. package/dist/plugins/soap.js +347 -0
  92. package/dist/plugins/user-agent.d.ts +8 -0
  93. package/dist/plugins/user-agent.d.ts.map +1 -0
  94. package/dist/plugins/user-agent.js +46 -0
  95. package/dist/plugins/xml.d.ts +10 -0
  96. package/dist/plugins/xml.d.ts.map +1 -0
  97. package/dist/plugins/xml.js +194 -0
  98. package/dist/presets/anthropic.d.ts +7 -0
  99. package/dist/presets/anthropic.d.ts.map +1 -0
  100. package/dist/presets/anthropic.js +17 -0
  101. package/dist/presets/azure-openai.d.ts +9 -0
  102. package/dist/presets/azure-openai.d.ts.map +1 -0
  103. package/dist/presets/azure-openai.js +25 -0
  104. package/dist/presets/cloudflare.d.ts +13 -0
  105. package/dist/presets/cloudflare.d.ts.map +1 -0
  106. package/dist/presets/cloudflare.js +39 -0
  107. package/dist/presets/cohere.d.ts +6 -0
  108. package/dist/presets/cohere.d.ts.map +1 -0
  109. package/dist/presets/cohere.js +16 -0
  110. package/dist/presets/deepseek.d.ts +6 -0
  111. package/dist/presets/deepseek.d.ts.map +1 -0
  112. package/dist/presets/deepseek.js +16 -0
  113. package/dist/presets/digitalocean.d.ts +6 -0
  114. package/dist/presets/digitalocean.d.ts.map +1 -0
  115. package/dist/presets/digitalocean.js +16 -0
  116. package/dist/presets/discord.d.ts +7 -0
  117. package/dist/presets/discord.d.ts.map +1 -0
  118. package/dist/presets/discord.js +17 -0
  119. package/dist/presets/fireworks.d.ts +6 -0
  120. package/dist/presets/fireworks.d.ts.map +1 -0
  121. package/dist/presets/fireworks.js +16 -0
  122. package/dist/presets/gemini.d.ts +6 -0
  123. package/dist/presets/gemini.d.ts.map +1 -0
  124. package/dist/presets/gemini.js +16 -0
  125. package/dist/presets/github.d.ts +7 -0
  126. package/dist/presets/github.d.ts.map +1 -0
  127. package/dist/presets/github.js +17 -0
  128. package/dist/presets/gitlab.d.ts +7 -0
  129. package/dist/presets/gitlab.d.ts.map +1 -0
  130. package/dist/presets/gitlab.js +16 -0
  131. package/dist/presets/groq.d.ts +6 -0
  132. package/dist/presets/groq.d.ts.map +1 -0
  133. package/dist/presets/groq.js +16 -0
  134. package/dist/presets/huggingface.d.ts +6 -0
  135. package/dist/presets/huggingface.d.ts.map +1 -0
  136. package/dist/presets/huggingface.js +16 -0
  137. package/dist/presets/index.d.ts +28 -0
  138. package/dist/presets/index.d.ts.map +1 -0
  139. package/dist/presets/index.js +27 -0
  140. package/dist/presets/linear.d.ts +6 -0
  141. package/dist/presets/linear.d.ts.map +1 -0
  142. package/dist/presets/linear.js +16 -0
  143. package/dist/presets/mistral.d.ts +6 -0
  144. package/dist/presets/mistral.d.ts.map +1 -0
  145. package/dist/presets/mistral.js +16 -0
  146. package/dist/presets/notion.d.ts +7 -0
  147. package/dist/presets/notion.d.ts.map +1 -0
  148. package/dist/presets/notion.js +17 -0
  149. package/dist/presets/openai.d.ts +8 -0
  150. package/dist/presets/openai.d.ts.map +1 -0
  151. package/dist/presets/openai.js +23 -0
  152. package/dist/presets/perplexity.d.ts +6 -0
  153. package/dist/presets/perplexity.d.ts.map +1 -0
  154. package/dist/presets/perplexity.js +16 -0
  155. package/dist/presets/registry.d.ts +20 -0
  156. package/dist/presets/registry.d.ts.map +1 -0
  157. package/dist/presets/registry.js +311 -0
  158. package/dist/presets/replicate.d.ts +6 -0
  159. package/dist/presets/replicate.d.ts.map +1 -0
  160. package/dist/presets/replicate.js +16 -0
  161. package/dist/presets/slack.d.ts +6 -0
  162. package/dist/presets/slack.d.ts.map +1 -0
  163. package/dist/presets/slack.js +16 -0
  164. package/dist/presets/stripe.d.ts +8 -0
  165. package/dist/presets/stripe.d.ts.map +1 -0
  166. package/dist/presets/stripe.js +23 -0
  167. package/dist/presets/supabase.d.ts +7 -0
  168. package/dist/presets/supabase.d.ts.map +1 -0
  169. package/dist/presets/supabase.js +18 -0
  170. package/dist/presets/together.d.ts +6 -0
  171. package/dist/presets/together.d.ts.map +1 -0
  172. package/dist/presets/together.js +16 -0
  173. package/dist/presets/twilio.d.ts +7 -0
  174. package/dist/presets/twilio.d.ts.map +1 -0
  175. package/dist/presets/twilio.js +17 -0
  176. package/dist/presets/vercel.d.ts +7 -0
  177. package/dist/presets/vercel.d.ts.map +1 -0
  178. package/dist/presets/vercel.js +23 -0
  179. package/dist/presets/xai.d.ts +7 -0
  180. package/dist/presets/xai.d.ts.map +1 -0
  181. package/dist/presets/xai.js +17 -0
  182. package/dist/protocols/ftp.d.ts +63 -0
  183. package/dist/protocols/ftp.d.ts.map +1 -0
  184. package/dist/protocols/ftp.js +388 -0
  185. package/dist/protocols/index.d.ts +4 -0
  186. package/dist/protocols/index.d.ts.map +1 -0
  187. package/dist/protocols/index.js +3 -0
  188. package/dist/protocols/sftp.d.ts +65 -0
  189. package/dist/protocols/sftp.d.ts.map +1 -0
  190. package/dist/protocols/sftp.js +346 -0
  191. package/dist/protocols/telnet.d.ts +50 -0
  192. package/dist/protocols/telnet.d.ts.map +1 -0
  193. package/dist/protocols/telnet.js +139 -0
  194. package/dist/runner/request-runner.d.ts.map +1 -1
  195. package/dist/runner/request-runner.js +1 -0
  196. package/dist/scrape/document.d.ts +44 -0
  197. package/dist/scrape/document.d.ts.map +1 -0
  198. package/dist/scrape/document.js +198 -0
  199. package/dist/scrape/element.d.ts +50 -0
  200. package/dist/scrape/element.d.ts.map +1 -0
  201. package/dist/scrape/element.js +176 -0
  202. package/dist/scrape/extractors.d.ts +17 -0
  203. package/dist/scrape/extractors.d.ts.map +1 -0
  204. package/dist/scrape/extractors.js +356 -0
  205. package/dist/scrape/index.d.ts +5 -0
  206. package/dist/scrape/index.d.ts.map +1 -0
  207. package/dist/scrape/index.js +3 -0
  208. package/dist/scrape/types.d.ts +108 -0
  209. package/dist/scrape/types.d.ts.map +1 -0
  210. package/dist/scrape/types.js +1 -0
  211. package/dist/testing/index.d.ts +3 -0
  212. package/dist/testing/index.d.ts.map +1 -0
  213. package/dist/testing/index.js +1 -0
  214. package/dist/testing/mock.d.ts +58 -0
  215. package/dist/testing/mock.d.ts.map +1 -0
  216. package/dist/testing/mock.js +252 -0
  217. package/dist/transport/fetch.d.ts.map +1 -1
  218. package/dist/transport/fetch.js +12 -4
  219. package/dist/transport/undici.d.ts +17 -1
  220. package/dist/transport/undici.d.ts.map +1 -1
  221. package/dist/transport/undici.js +708 -47
  222. package/dist/types/index.d.ts +111 -10
  223. package/dist/types/index.d.ts.map +1 -1
  224. package/dist/types/index.js +1 -1
  225. package/dist/types/logger.d.ts +17 -0
  226. package/dist/types/logger.d.ts.map +1 -0
  227. package/dist/types/logger.js +66 -0
  228. package/dist/utils/agent-manager.d.ts.map +1 -1
  229. package/dist/utils/agent-manager.js +20 -4
  230. package/dist/utils/body.d.ts.map +1 -1
  231. package/dist/utils/body.js +14 -2
  232. package/dist/utils/charset.d.ts +16 -0
  233. package/dist/utils/charset.d.ts.map +1 -0
  234. package/dist/utils/charset.js +169 -0
  235. package/dist/utils/client-pool.d.ts +21 -0
  236. package/dist/utils/client-pool.d.ts.map +1 -0
  237. package/dist/utils/client-pool.js +49 -0
  238. package/dist/utils/concurrency.d.ts.map +1 -1
  239. package/dist/utils/concurrency.js +8 -4
  240. package/dist/utils/dns-toolkit.d.ts +13 -0
  241. package/dist/utils/dns-toolkit.d.ts.map +1 -0
  242. package/dist/utils/dns-toolkit.js +48 -0
  243. package/dist/utils/doh.d.ts.map +1 -1
  244. package/dist/utils/doh.js +16 -3
  245. package/dist/utils/download.d.ts +15 -0
  246. package/dist/utils/download.d.ts.map +1 -0
  247. package/dist/utils/download.js +44 -0
  248. package/dist/utils/env-proxy.d.ts +13 -0
  249. package/dist/utils/env-proxy.d.ts.map +1 -0
  250. package/dist/utils/env-proxy.js +105 -0
  251. package/dist/utils/header-parser.d.ts +15 -1
  252. package/dist/utils/header-parser.d.ts.map +1 -1
  253. package/dist/utils/header-parser.js +161 -1
  254. package/dist/utils/link-header.d.ts +70 -0
  255. package/dist/utils/link-header.d.ts.map +1 -0
  256. package/dist/utils/link-header.js +190 -0
  257. package/dist/utils/progress.d.ts +7 -2
  258. package/dist/utils/progress.d.ts.map +1 -1
  259. package/dist/utils/progress.js +48 -15
  260. package/dist/utils/rdap.d.ts +17 -0
  261. package/dist/utils/rdap.d.ts.map +1 -0
  262. package/dist/utils/rdap.js +32 -0
  263. package/dist/utils/request-pool.d.ts.map +1 -1
  264. package/dist/utils/request-pool.js +4 -3
  265. package/dist/utils/sse.d.ts.map +1 -1
  266. package/dist/utils/sse.js +8 -2
  267. package/dist/utils/status-codes.d.ts +84 -0
  268. package/dist/utils/status-codes.d.ts.map +1 -0
  269. package/dist/utils/status-codes.js +204 -0
  270. package/dist/utils/streaming.d.ts.map +1 -1
  271. package/dist/utils/streaming.js +1 -0
  272. package/dist/utils/tls-inspector.d.ts +21 -0
  273. package/dist/utils/tls-inspector.d.ts.map +1 -0
  274. package/dist/utils/tls-inspector.js +39 -0
  275. package/dist/utils/try-fn.d.ts.map +1 -1
  276. package/dist/utils/try-fn.js +11 -5
  277. package/dist/utils/upload.d.ts +1 -0
  278. package/dist/utils/upload.d.ts.map +1 -1
  279. package/dist/utils/upload.js +20 -3
  280. package/dist/utils/user-agent.d.ts +9 -9
  281. package/dist/utils/user-agent.js +9 -9
  282. package/dist/utils/whois.d.ts.map +1 -1
  283. package/dist/utils/whois.js +11 -2
  284. package/dist/websocket/client.d.ts +29 -1
  285. package/dist/websocket/client.d.ts.map +1 -1
  286. package/dist/websocket/client.js +145 -13
  287. package/package.json +45 -8
@@ -0,0 +1,16 @@
1
+ export function together(options) {
2
+ return {
3
+ baseUrl: 'https://api.together.xyz/v1',
4
+ headers: {
5
+ 'Authorization': `Bearer ${options.apiKey}`,
6
+ 'Content-Type': 'application/json',
7
+ },
8
+ timeout: 5 * 60 * 1000,
9
+ retry: {
10
+ maxAttempts: 5,
11
+ backoff: 'exponential',
12
+ delay: 1000,
13
+ statusCodes: [408, 429, 500, 502, 503, 504]
14
+ }
15
+ };
16
+ }
@@ -0,0 +1,7 @@
1
+ import { ClientOptions } from '../types/index.js';
2
+ export interface TwilioPresetOptions {
3
+ accountSid: string;
4
+ authToken: string;
5
+ }
6
+ export declare function twilio(options: TwilioPresetOptions): ClientOptions;
7
+ //# sourceMappingURL=twilio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"twilio.d.ts","sourceRoot":"","sources":["../../src/presets/twilio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,mBAAmB;IAIlC,UAAU,EAAE,MAAM,CAAC;IAInB,SAAS,EAAE,MAAM,CAAC;CACnB;AAMD,wBAAgB,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,aAAa,CAiBlE"}
@@ -0,0 +1,17 @@
1
+ export function twilio(options) {
2
+ const credentials = Buffer.from(`${options.accountSid}:${options.authToken}`).toString('base64');
3
+ return {
4
+ baseUrl: `https://api.twilio.com/2010-04-01/Accounts/${options.accountSid}`,
5
+ headers: {
6
+ 'Authorization': `Basic ${credentials}`,
7
+ 'Content-Type': 'application/x-www-form-urlencoded',
8
+ },
9
+ timeout: 30 * 1000,
10
+ retry: {
11
+ maxAttempts: 3,
12
+ backoff: 'exponential',
13
+ delay: 1000,
14
+ statusCodes: [408, 429, 500, 502, 503, 504]
15
+ }
16
+ };
17
+ }
@@ -0,0 +1,7 @@
1
+ import { ClientOptions } from '../types/index.js';
2
+ export interface VercelPresetOptions {
3
+ token: string;
4
+ teamId?: string;
5
+ }
6
+ export declare function vercel(options: VercelPresetOptions): ClientOptions;
7
+ //# sourceMappingURL=vercel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vercel.d.ts","sourceRoot":"","sources":["../../src/presets/vercel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,mBAAmB;IAIlC,KAAK,EAAE,MAAM,CAAC;IAId,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAMD,wBAAgB,MAAM,CAAC,OAAO,EAAE,mBAAmB,GAAG,aAAa,CAuBlE"}
@@ -0,0 +1,23 @@
1
+ export function vercel(options) {
2
+ const params = {};
3
+ if (options.teamId) {
4
+ params.teamId = options.teamId;
5
+ }
6
+ return {
7
+ baseUrl: 'https://api.vercel.com',
8
+ headers: {
9
+ 'Authorization': `Bearer ${options.token}`,
10
+ 'Content-Type': 'application/json',
11
+ },
12
+ defaults: {
13
+ params,
14
+ },
15
+ timeout: 30 * 1000,
16
+ retry: {
17
+ maxAttempts: 3,
18
+ backoff: 'exponential',
19
+ delay: 1000,
20
+ statusCodes: [408, 429, 500, 502, 503, 504]
21
+ }
22
+ };
23
+ }
@@ -0,0 +1,7 @@
1
+ import { ClientOptions } from '../types/index.js';
2
+ export interface XAIPresetOptions {
3
+ apiKey: string;
4
+ }
5
+ export declare function xai(options: XAIPresetOptions): ClientOptions;
6
+ export declare const grok: typeof xai;
7
+ //# sourceMappingURL=xai.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xai.d.ts","sourceRoot":"","sources":["../../src/presets/xai.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;CAChB;AAMD,wBAAgB,GAAG,CAAC,OAAO,EAAE,gBAAgB,GAAG,aAAa,CAe5D;AAMD,eAAO,MAAM,IAAI,YAAM,CAAC"}
@@ -0,0 +1,17 @@
1
+ export function xai(options) {
2
+ return {
3
+ baseUrl: 'https://api.x.ai/v1',
4
+ headers: {
5
+ 'Authorization': `Bearer ${options.apiKey}`,
6
+ 'Content-Type': 'application/json',
7
+ },
8
+ timeout: 5 * 60 * 1000,
9
+ retry: {
10
+ maxAttempts: 3,
11
+ backoff: 'exponential',
12
+ delay: 1000,
13
+ statusCodes: [408, 429, 500, 502, 503, 504]
14
+ }
15
+ };
16
+ }
17
+ export const grok = xai;
@@ -0,0 +1,63 @@
1
+ import { Client as FTPClient } from 'basic-ftp';
2
+ import { Readable, Writable } from 'node:stream';
3
+ export interface FTPConfig {
4
+ host: string;
5
+ port?: number;
6
+ user?: string;
7
+ password?: string;
8
+ secure?: boolean | 'implicit';
9
+ timeout?: number;
10
+ verbose?: boolean;
11
+ }
12
+ export interface FTPListItem {
13
+ name: string;
14
+ type: 'file' | 'directory' | 'link' | 'unknown';
15
+ size: number;
16
+ modifiedAt?: Date;
17
+ permissions?: string;
18
+ rawModifiedAt?: string;
19
+ }
20
+ export interface FTPTransferProgress {
21
+ bytes: number;
22
+ bytesOverall: number;
23
+ name: string;
24
+ type: 'upload' | 'download' | 'list';
25
+ }
26
+ export interface FTPResponse<T = void> {
27
+ success: boolean;
28
+ data?: T;
29
+ code?: number;
30
+ message?: string;
31
+ }
32
+ export declare class FTP {
33
+ private client;
34
+ private config;
35
+ private connected;
36
+ private onProgress?;
37
+ constructor(config: FTPConfig);
38
+ connect(): Promise<FTPResponse>;
39
+ isConnected(): boolean;
40
+ list(path?: string): Promise<FTPResponse<FTPListItem[]>>;
41
+ download(remotePath: string, localPath: string): Promise<FTPResponse>;
42
+ downloadToStream(remotePath: string, stream: Writable): Promise<FTPResponse>;
43
+ downloadToBuffer(remotePath: string): Promise<FTPResponse<Buffer>>;
44
+ upload(localPath: string, remotePath: string): Promise<FTPResponse>;
45
+ uploadFromStream(stream: Readable, remotePath: string): Promise<FTPResponse>;
46
+ uploadFromBuffer(data: Buffer | string, remotePath: string): Promise<FTPResponse>;
47
+ delete(remotePath: string): Promise<FTPResponse>;
48
+ mkdir(remotePath: string, recursive?: boolean): Promise<FTPResponse>;
49
+ rmdir(remotePath: string): Promise<FTPResponse>;
50
+ rename(oldPath: string, newPath: string): Promise<FTPResponse>;
51
+ pwd(): Promise<FTPResponse<string>>;
52
+ cd(remotePath: string): Promise<FTPResponse>;
53
+ size(remotePath: string): Promise<FTPResponse<number>>;
54
+ exists(remotePath: string): Promise<boolean>;
55
+ progress(callback: (progress: FTPTransferProgress) => void): this;
56
+ close(): Promise<void>;
57
+ getClient(): FTPClient;
58
+ private ensureConnected;
59
+ private mapFileType;
60
+ }
61
+ export declare function createFTP(config: FTPConfig): FTP;
62
+ export declare function ftp<T>(config: FTPConfig, operation: (client: FTP) => Promise<T>): Promise<T>;
63
+ //# sourceMappingURL=ftp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ftp.d.ts","sourceRoot":"","sources":["../../src/protocols/ftp.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,388 @@
1
+ import { Client as FTPClient } from 'basic-ftp';
2
+ import { Readable, Writable } from 'node:stream';
3
+ export class FTP {
4
+ client;
5
+ config;
6
+ connected = false;
7
+ onProgress;
8
+ constructor(config) {
9
+ this.config = config;
10
+ this.client = new FTPClient(config.timeout ?? 30000);
11
+ if (config.verbose) {
12
+ this.client.ftp.verbose = true;
13
+ }
14
+ }
15
+ async connect() {
16
+ try {
17
+ const accessOptions = {
18
+ host: this.config.host,
19
+ port: this.config.port ?? 21,
20
+ user: this.config.user ?? 'anonymous',
21
+ password: this.config.password ?? 'anonymous@',
22
+ secure: this.config.secure ?? false,
23
+ };
24
+ await this.client.access(accessOptions);
25
+ this.connected = true;
26
+ return {
27
+ success: true,
28
+ message: 'Connected successfully'
29
+ };
30
+ }
31
+ catch (error) {
32
+ return {
33
+ success: false,
34
+ message: error instanceof Error ? error.message : 'Connection failed'
35
+ };
36
+ }
37
+ }
38
+ isConnected() {
39
+ return this.connected && !this.client.closed;
40
+ }
41
+ async list(path = '/') {
42
+ this.ensureConnected();
43
+ try {
44
+ const files = await this.client.list(path);
45
+ const items = files.map((file) => ({
46
+ name: file.name,
47
+ type: this.mapFileType(file.type),
48
+ size: file.size,
49
+ modifiedAt: file.modifiedAt,
50
+ permissions: file.permissions?.toString(),
51
+ rawModifiedAt: file.rawModifiedAt
52
+ }));
53
+ return {
54
+ success: true,
55
+ data: items
56
+ };
57
+ }
58
+ catch (error) {
59
+ return {
60
+ success: false,
61
+ message: error instanceof Error ? error.message : 'List failed'
62
+ };
63
+ }
64
+ }
65
+ async download(remotePath, localPath) {
66
+ this.ensureConnected();
67
+ try {
68
+ if (this.onProgress) {
69
+ this.client.trackProgress((info) => {
70
+ this.onProgress?.({
71
+ bytes: info.bytes,
72
+ bytesOverall: info.bytesOverall,
73
+ name: info.name,
74
+ type: 'download'
75
+ });
76
+ });
77
+ }
78
+ await this.client.downloadTo(localPath, remotePath);
79
+ this.client.trackProgress();
80
+ return {
81
+ success: true,
82
+ message: `Downloaded ${remotePath} to ${localPath}`
83
+ };
84
+ }
85
+ catch (error) {
86
+ this.client.trackProgress();
87
+ return {
88
+ success: false,
89
+ message: error instanceof Error ? error.message : 'Download failed'
90
+ };
91
+ }
92
+ }
93
+ async downloadToStream(remotePath, stream) {
94
+ this.ensureConnected();
95
+ try {
96
+ if (this.onProgress) {
97
+ this.client.trackProgress((info) => {
98
+ this.onProgress?.({
99
+ bytes: info.bytes,
100
+ bytesOverall: info.bytesOverall,
101
+ name: info.name,
102
+ type: 'download'
103
+ });
104
+ });
105
+ }
106
+ await this.client.downloadTo(stream, remotePath);
107
+ this.client.trackProgress();
108
+ return {
109
+ success: true,
110
+ message: `Downloaded ${remotePath}`
111
+ };
112
+ }
113
+ catch (error) {
114
+ this.client.trackProgress();
115
+ return {
116
+ success: false,
117
+ message: error instanceof Error ? error.message : 'Download failed'
118
+ };
119
+ }
120
+ }
121
+ async downloadToBuffer(remotePath) {
122
+ this.ensureConnected();
123
+ try {
124
+ const chunks = [];
125
+ const stream = new Writable({
126
+ write(chunk, encoding, callback) {
127
+ chunks.push(Buffer.from(chunk));
128
+ callback();
129
+ }
130
+ });
131
+ await this.client.downloadTo(stream, remotePath);
132
+ return {
133
+ success: true,
134
+ data: Buffer.concat(chunks)
135
+ };
136
+ }
137
+ catch (error) {
138
+ return {
139
+ success: false,
140
+ message: error instanceof Error ? error.message : 'Download failed'
141
+ };
142
+ }
143
+ }
144
+ async upload(localPath, remotePath) {
145
+ this.ensureConnected();
146
+ try {
147
+ if (this.onProgress) {
148
+ this.client.trackProgress((info) => {
149
+ this.onProgress?.({
150
+ bytes: info.bytes,
151
+ bytesOverall: info.bytesOverall,
152
+ name: info.name,
153
+ type: 'upload'
154
+ });
155
+ });
156
+ }
157
+ await this.client.uploadFrom(localPath, remotePath);
158
+ this.client.trackProgress();
159
+ return {
160
+ success: true,
161
+ message: `Uploaded ${localPath} to ${remotePath}`
162
+ };
163
+ }
164
+ catch (error) {
165
+ this.client.trackProgress();
166
+ return {
167
+ success: false,
168
+ message: error instanceof Error ? error.message : 'Upload failed'
169
+ };
170
+ }
171
+ }
172
+ async uploadFromStream(stream, remotePath) {
173
+ this.ensureConnected();
174
+ try {
175
+ if (this.onProgress) {
176
+ this.client.trackProgress((info) => {
177
+ this.onProgress?.({
178
+ bytes: info.bytes,
179
+ bytesOverall: info.bytesOverall,
180
+ name: info.name,
181
+ type: 'upload'
182
+ });
183
+ });
184
+ }
185
+ await this.client.uploadFrom(stream, remotePath);
186
+ this.client.trackProgress();
187
+ return {
188
+ success: true,
189
+ message: `Uploaded to ${remotePath}`
190
+ };
191
+ }
192
+ catch (error) {
193
+ this.client.trackProgress();
194
+ return {
195
+ success: false,
196
+ message: error instanceof Error ? error.message : 'Upload failed'
197
+ };
198
+ }
199
+ }
200
+ async uploadFromBuffer(data, remotePath) {
201
+ this.ensureConnected();
202
+ try {
203
+ const buffer = typeof data === 'string' ? Buffer.from(data) : data;
204
+ const stream = Readable.from(buffer);
205
+ await this.client.uploadFrom(stream, remotePath);
206
+ return {
207
+ success: true,
208
+ message: `Uploaded to ${remotePath}`
209
+ };
210
+ }
211
+ catch (error) {
212
+ return {
213
+ success: false,
214
+ message: error instanceof Error ? error.message : 'Upload failed'
215
+ };
216
+ }
217
+ }
218
+ async delete(remotePath) {
219
+ this.ensureConnected();
220
+ try {
221
+ await this.client.remove(remotePath);
222
+ return {
223
+ success: true,
224
+ message: `Deleted ${remotePath}`
225
+ };
226
+ }
227
+ catch (error) {
228
+ return {
229
+ success: false,
230
+ message: error instanceof Error ? error.message : 'Delete failed'
231
+ };
232
+ }
233
+ }
234
+ async mkdir(remotePath, recursive = true) {
235
+ this.ensureConnected();
236
+ try {
237
+ await this.client.ensureDir(remotePath);
238
+ return {
239
+ success: true,
240
+ message: `Created directory ${remotePath}`
241
+ };
242
+ }
243
+ catch (error) {
244
+ return {
245
+ success: false,
246
+ message: error instanceof Error ? error.message : 'Mkdir failed'
247
+ };
248
+ }
249
+ }
250
+ async rmdir(remotePath) {
251
+ this.ensureConnected();
252
+ try {
253
+ await this.client.removeDir(remotePath);
254
+ return {
255
+ success: true,
256
+ message: `Removed directory ${remotePath}`
257
+ };
258
+ }
259
+ catch (error) {
260
+ return {
261
+ success: false,
262
+ message: error instanceof Error ? error.message : 'Rmdir failed'
263
+ };
264
+ }
265
+ }
266
+ async rename(oldPath, newPath) {
267
+ this.ensureConnected();
268
+ try {
269
+ await this.client.rename(oldPath, newPath);
270
+ return {
271
+ success: true,
272
+ message: `Renamed ${oldPath} to ${newPath}`
273
+ };
274
+ }
275
+ catch (error) {
276
+ return {
277
+ success: false,
278
+ message: error instanceof Error ? error.message : 'Rename failed'
279
+ };
280
+ }
281
+ }
282
+ async pwd() {
283
+ this.ensureConnected();
284
+ try {
285
+ const dir = await this.client.pwd();
286
+ return {
287
+ success: true,
288
+ data: dir
289
+ };
290
+ }
291
+ catch (error) {
292
+ return {
293
+ success: false,
294
+ message: error instanceof Error ? error.message : 'PWD failed'
295
+ };
296
+ }
297
+ }
298
+ async cd(remotePath) {
299
+ this.ensureConnected();
300
+ try {
301
+ await this.client.cd(remotePath);
302
+ return {
303
+ success: true,
304
+ message: `Changed to ${remotePath}`
305
+ };
306
+ }
307
+ catch (error) {
308
+ return {
309
+ success: false,
310
+ message: error instanceof Error ? error.message : 'CD failed'
311
+ };
312
+ }
313
+ }
314
+ async size(remotePath) {
315
+ this.ensureConnected();
316
+ try {
317
+ const size = await this.client.size(remotePath);
318
+ return {
319
+ success: true,
320
+ data: size
321
+ };
322
+ }
323
+ catch (error) {
324
+ return {
325
+ success: false,
326
+ message: error instanceof Error ? error.message : 'Size failed'
327
+ };
328
+ }
329
+ }
330
+ async exists(remotePath) {
331
+ this.ensureConnected();
332
+ try {
333
+ const parentPath = remotePath.split('/').slice(0, -1).join('/') || '/';
334
+ const fileName = remotePath.split('/').pop() || '';
335
+ const files = await this.client.list(parentPath);
336
+ return files.some((f) => f.name === fileName);
337
+ }
338
+ catch {
339
+ return false;
340
+ }
341
+ }
342
+ progress(callback) {
343
+ this.onProgress = callback;
344
+ return this;
345
+ }
346
+ async close() {
347
+ this.connected = false;
348
+ this.client.close();
349
+ }
350
+ getClient() {
351
+ return this.client;
352
+ }
353
+ ensureConnected() {
354
+ if (!this.connected || this.client.closed) {
355
+ throw new Error('Not connected to FTP server. Call connect() first.');
356
+ }
357
+ }
358
+ mapFileType(type) {
359
+ switch (type) {
360
+ case 0:
361
+ return 'unknown';
362
+ case 1:
363
+ return 'file';
364
+ case 2:
365
+ return 'directory';
366
+ case 3:
367
+ return 'link';
368
+ default:
369
+ return 'unknown';
370
+ }
371
+ }
372
+ }
373
+ export function createFTP(config) {
374
+ return new FTP(config);
375
+ }
376
+ export async function ftp(config, operation) {
377
+ const client = createFTP(config);
378
+ try {
379
+ const result = await client.connect();
380
+ if (!result.success) {
381
+ throw new Error(result.message || 'Failed to connect to FTP server');
382
+ }
383
+ return await operation(client);
384
+ }
385
+ finally {
386
+ await client.close();
387
+ }
388
+ }
@@ -0,0 +1,4 @@
1
+ export { FTP, createFTP, ftp, type FTPConfig, type FTPListItem, type FTPTransferProgress, type FTPResponse } from './ftp.js';
2
+ export { SFTP, createSFTP, sftp, type SFTPConfig, type SFTPListItem, type SFTPResponse } from './sftp.js';
3
+ export { Telnet, createTelnet, telnet, type TelnetConfig, type TelnetResponse, type TelnetExecOptions } from './telnet.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/protocols/index.ts"],"names":[],"mappings":"AAQA,OAAO,EACL,GAAG,EACH,SAAS,EACT,GAAG,EACH,KAAK,SAAS,EACd,KAAK,WAAW,EAChB,KAAK,mBAAmB,EACxB,KAAK,WAAW,EACjB,MAAM,UAAU,CAAC;AAGlB,OAAO,EACL,IAAI,EACJ,UAAU,EACV,IAAI,EACJ,KAAK,UAAU,EACf,KAAK,YAAY,EACjB,KAAK,YAAY,EAClB,MAAM,WAAW,CAAC;AAGnB,OAAO,EACL,MAAM,EACN,YAAY,EACZ,MAAM,EACN,KAAK,YAAY,EACjB,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACvB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { FTP, createFTP, ftp } from './ftp.js';
2
+ export { SFTP, createSFTP, sftp } from './sftp.js';
3
+ export { Telnet, createTelnet, telnet } from './telnet.js';
@@ -0,0 +1,65 @@
1
+ import SFTPClient from 'ssh2-sftp-client';
2
+ import type { FileStats } from 'ssh2-sftp-client';
3
+ import { Readable, Writable } from 'node:stream';
4
+ export interface SFTPConfig {
5
+ host: string;
6
+ port?: number;
7
+ username?: string;
8
+ password?: string;
9
+ privateKey?: string | Buffer;
10
+ passphrase?: string;
11
+ readyTimeout?: number;
12
+ retries?: number;
13
+ retry_factor?: number;
14
+ retry_minTimeout?: number;
15
+ }
16
+ export interface SFTPListItem {
17
+ name: string;
18
+ type: 'file' | 'directory' | 'link' | 'unknown';
19
+ size: number;
20
+ modifyTime: number;
21
+ accessTime: number;
22
+ rights: {
23
+ user: string;
24
+ group: string;
25
+ other: string;
26
+ };
27
+ owner: number;
28
+ group: number;
29
+ }
30
+ export interface SFTPResponse<T = void> {
31
+ success: boolean;
32
+ data?: T;
33
+ message?: string;
34
+ }
35
+ export declare class SFTP {
36
+ private client;
37
+ private config;
38
+ private connected;
39
+ constructor(config: SFTPConfig);
40
+ connect(): Promise<SFTPResponse>;
41
+ isConnected(): boolean;
42
+ list(remotePath?: string): Promise<SFTPResponse<SFTPListItem[]>>;
43
+ exists(remotePath: string): Promise<boolean | string>;
44
+ stat(remotePath: string): Promise<SFTPResponse<FileStats>>;
45
+ download(remotePath: string, localPath: string): Promise<SFTPResponse>;
46
+ downloadToStream(remotePath: string, stream: Writable): Promise<SFTPResponse>;
47
+ downloadToBuffer(remotePath: string): Promise<SFTPResponse<Buffer>>;
48
+ upload(localPath: string, remotePath: string): Promise<SFTPResponse>;
49
+ uploadFromStream(stream: Readable, remotePath: string): Promise<SFTPResponse>;
50
+ uploadFromBuffer(data: Buffer | string, remotePath: string): Promise<SFTPResponse>;
51
+ delete(remotePath: string): Promise<SFTPResponse>;
52
+ mkdir(remotePath: string, recursive?: boolean): Promise<SFTPResponse>;
53
+ rmdir(remotePath: string, recursive?: boolean): Promise<SFTPResponse>;
54
+ rename(oldPath: string, newPath: string): Promise<SFTPResponse>;
55
+ chmod(remotePath: string, mode: string | number): Promise<SFTPResponse>;
56
+ pwd(): Promise<SFTPResponse<string>>;
57
+ append(data: Buffer | string, remotePath: string): Promise<SFTPResponse>;
58
+ close(): Promise<void>;
59
+ getClient(): SFTPClient;
60
+ private ensureConnected;
61
+ private mapFileType;
62
+ }
63
+ export declare function createSFTP(config: SFTPConfig): SFTP;
64
+ export declare function sftp<T>(config: SFTPConfig, operation: (client: SFTP) => Promise<T>): Promise<T>;
65
+ //# sourceMappingURL=sftp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sftp.d.ts","sourceRoot":"","sources":["../../src/protocols/sftp.ts"],"names":[],"mappings":"AAKA,OAAO,UAAU,MAAM,kBAAkB,CAAC;AAC1C,OAAO,KAAK,EAA4B,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEjD,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,MAAM,GAAG,SAAS,CAAC;IAChD,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,IAAI;IACpC,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,CAAC,CAAC;IACT,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAmBD,qBAAa,IAAI;IACf,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,SAAS,CAAkB;gBAEvB,MAAM,EAAE,UAAU;IAQxB,OAAO,IAAI,OAAO,CAAC,YAAY,CAAC;IAiCtC,WAAW,IAAI,OAAO;IAOhB,IAAI,CAAC,UAAU,GAAE,MAAY,GAAG,OAAO,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC,CAAC;IAgCrE,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,MAAM,CAAC;IAarD,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAoB1D,QAAQ,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAqBtE,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAO,CAAC,YAAY,CAAC;IAqB7E,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IA6BnE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAqBpE,gBAAgB,CAAC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAqB7E,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAqBlF,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAoBjD,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,GAAE,OAAc,GAAG,OAAO,CAAC,YAAY,CAAC;IAoB3E,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,GAAE,OAAe,GAAG,OAAO,CAAC,YAAY,CAAC;IAoB5E,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAoB/D,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAoBvE,GAAG,IAAI,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAoBpC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAoBxE,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ5B,SAAS,IAAI,UAAU;IAIvB,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,WAAW;CAYpB;AAaD,wBAAgB,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI,CAEnD;AAkBD,wBAAsB,IAAI,CAAC,CAAC,EAC1B,MAAM,EAAE,UAAU,EAClB,SAAS,EAAE,CAAC,MAAM,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,GACtC,OAAO,CAAC,CAAC,CAAC,CAaZ"}