cloudflare/cloudflare-typescript

Public

mirrored fromhttps://github.com/cloudflare/cloudflare-typescriptAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
v3.2.0

Branches

Tags

  • No tags available.
0Branches0Tags
Go to file
Add file
Code

Clone

HTTPS

Download ZIP

src/index.ts

575lines · modecode

1// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
3import * as Core from './core';
4import * as Errors from './error';
5import { type Agent } from './_shims/index';
6import * as Uploads from './uploads';
7import * as qs from 'qs';
8import * as Pagination from 'cloudflare/pagination';
9import * as API from 'cloudflare/resources/index';
10
11export interface ClientOptions {
12 /**
13 * Defaults to process.env['CLOUDFLARE_API_TOKEN'].
14 */
15 apiToken?: string | null | undefined;
16
17 /**
18 * Defaults to process.env['CLOUDFLARE_API_KEY'].
19 */
20 apiKey?: string | null | undefined;
21
22 /**
23 * Defaults to process.env['CLOUDFLARE_EMAIL'].
24 */
25 apiEmail?: string | null | undefined;
26
27 /**
28 * Defaults to process.env['CLOUDFLARE_API_USER_SERVICE_KEY'].
29 */
30 userServiceKey?: string | null | undefined;
31
32 /**
33 * Override the default base URL for the API, e.g., "https://api.example.com/v2/"
34 *
35 * Defaults to process.env['CLOUDFLARE_BASE_URL'].
36 */
37 baseURL?: string | null | undefined;
38
39 /**
40 * The maximum amount of time (in milliseconds) that the client should wait for a response
41 * from the server before timing out a single request.
42 *
43 * Note that request timeouts are retried by default, so in a worst-case scenario you may wait
44 * much longer than this timeout before the promise succeeds or fails.
45 */
46 timeout?: number;
47
48 /**
49 * An HTTP agent used to manage HTTP(S) connections.
50 *
51 * If not provided, an agent will be constructed by default in the Node.js environment,
52 * otherwise no agent is used.
53 */
54 httpAgent?: Agent;
55
56 /**
57 * Specify a custom `fetch` function implementation.
58 *
59 * If not provided, we use `node-fetch` on Node.js and otherwise expect that `fetch` is
60 * defined globally.
61 */
62 fetch?: Core.Fetch | undefined;
63
64 /**
65 * The maximum number of times that the client will retry a request in case of a
66 * temporary failure, like a network error or a 5XX error from the server.
67 *
68 * @default 2
69 */
70 maxRetries?: number;
71
72 /**
73 * Default headers to include with every request to the API.
74 *
75 * These can be removed in individual requests by explicitly setting the
76 * header to `undefined` or `null` in request options.
77 */
78 defaultHeaders?: Core.Headers;
79
80 /**
81 * Default query parameters to include with every request to the API.
82 *
83 * These can be removed in individual requests by explicitly setting the
84 * param to `undefined` in request options.
85 */
86 defaultQuery?: Core.DefaultQuery;
87}
88
89/** API Client for interfacing with the Cloudflare API. */
90export class Cloudflare extends Core.APIClient {
91 apiToken: string | null;
92 apiKey: string | null;
93 apiEmail: string | null;
94 userServiceKey: string | null;
95
96 private _options: ClientOptions;
97
98 /**
99 * API Client for interfacing with the Cloudflare API.
100 *
101 * @param {string | null | undefined} [opts.apiToken=process.env['CLOUDFLARE_API_TOKEN'] ?? null]
102 * @param {string | null | undefined} [opts.apiKey=process.env['CLOUDFLARE_API_KEY'] ?? null]
103 * @param {string | null | undefined} [opts.apiEmail=process.env['CLOUDFLARE_EMAIL'] ?? null]
104 * @param {string | null | undefined} [opts.userServiceKey=process.env['CLOUDFLARE_API_USER_SERVICE_KEY'] ?? null]
105 * @param {string} [opts.baseURL=process.env['CLOUDFLARE_BASE_URL'] ?? https://api.cloudflare.com/client/v4] - Override the default base URL for the API.
106 * @param {number} [opts.timeout=1 minute] - The maximum amount of time (in milliseconds) the client will wait for a response before timing out.
107 * @param {number} [opts.httpAgent] - An HTTP agent used to manage HTTP(s) connections.
108 * @param {Core.Fetch} [opts.fetch] - Specify a custom `fetch` function implementation.
109 * @param {number} [opts.maxRetries=2] - The maximum number of times the client will retry a request.
110 * @param {Core.Headers} opts.defaultHeaders - Default headers to include with every request to the API.
111 * @param {Core.DefaultQuery} opts.defaultQuery - Default query parameters to include with every request to the API.
112 */
113 constructor({
114 baseURL = Core.readEnv('CLOUDFLARE_BASE_URL'),
115 apiToken = Core.readEnv('CLOUDFLARE_API_TOKEN') ?? null,
116 apiKey = Core.readEnv('CLOUDFLARE_API_KEY') ?? null,
117 apiEmail = Core.readEnv('CLOUDFLARE_EMAIL') ?? null,
118 userServiceKey = Core.readEnv('CLOUDFLARE_API_USER_SERVICE_KEY') ?? null,
119 ...opts
120 }: ClientOptions = {}) {
121 const options: ClientOptions = {
122 apiToken,
123 apiKey,
124 apiEmail,
125 userServiceKey,
126 ...opts,
127 baseURL: baseURL || `https://api.cloudflare.com/client/v4`,
128 };
129
130 super({
131 baseURL: options.baseURL!,
132 timeout: options.timeout ?? 60000 /* 1 minute */,
133 httpAgent: options.httpAgent,
134 maxRetries: options.maxRetries,
135 fetch: options.fetch,
136 });
137 this._options = options;
138
139 this.apiToken = apiToken;
140 this.apiKey = apiKey;
141 this.apiEmail = apiEmail;
142 this.userServiceKey = userServiceKey;
143 }
144
145 accounts: API.Accounts = new API.Accounts(this);
146 originCACertificates: API.OriginCACertificates = new API.OriginCACertificates(this);
147 ips: API.IPs = new API.IPs(this);
148 memberships: API.Memberships = new API.Memberships(this);
149 user: API.User = new API.User(this);
150 zones: API.Zones = new API.Zones(this);
151 loadBalancers: API.LoadBalancers = new API.LoadBalancers(this);
152 cache: API.Cache = new API.Cache(this);
153 ssl: API.SSL = new API.SSL(this);
154 subscriptions: API.Subscriptions = new API.Subscriptions(this);
155 acm: API.ACM = new API.ACM(this);
156 argo: API.Argo = new API.Argo(this);
157 plans: API.Plans = new API.Plans(this);
158 ratePlans: API.RatePlans = new API.RatePlans(this);
159 certificateAuthorities: API.CertificateAuthorities = new API.CertificateAuthorities(this);
160 clientCertificates: API.ClientCertificates = new API.ClientCertificates(this);
161 customCertificates: API.CustomCertificates = new API.CustomCertificates(this);
162 customHostnames: API.CustomHostnames = new API.CustomHostnames(this);
163 customNameservers: API.CustomNameservers = new API.CustomNameservers(this);
164 dns: API.DNS = new API.DNS(this);
165 dnssec: API.DNSSECResource = new API.DNSSECResource(this);
166 emailRouting: API.EmailRouting = new API.EmailRouting(this);
167 filters: API.Filters = new API.Filters(this);
168 firewall: API.Firewall = new API.Firewall(this);
169 healthchecks: API.Healthchecks = new API.Healthchecks(this);
170 keylessCertificates: API.KeylessCertificates = new API.KeylessCertificates(this);
171 logpush: API.Logpush = new API.Logpush(this);
172 logs: API.Logs = new API.Logs(this);
173 originTLSClientAuth: API.OriginTLSClientAuth = new API.OriginTLSClientAuth(this);
174 pagerules: API.Pagerules = new API.Pagerules(this);
175 rateLimits: API.RateLimits = new API.RateLimits(this);
176 secondaryDNS: API.SecondaryDNS = new API.SecondaryDNS(this);
177 waitingRooms: API.WaitingRooms = new API.WaitingRooms(this);
178 web3: API.Web3 = new API.Web3(this);
179 workers: API.Workers = new API.Workers(this);
180 kv: API.KV = new API.KV(this);
181 durableObjects: API.DurableObjects = new API.DurableObjects(this);
182 queues: API.Queues = new API.Queues(this);
183 managedHeaders: API.ManagedHeaders = new API.ManagedHeaders(this);
184 pageShield: API.PageShield = new API.PageShield(this);
185 rulesets: API.Rulesets = new API.Rulesets(this);
186 urlNormalization: API.URLNormalization = new API.URLNormalization(this);
187 spectrum: API.Spectrum = new API.Spectrum(this);
188 addressing: API.Addressing = new API.Addressing(this);
189 auditLogs: API.AuditLogs = new API.AuditLogs(this);
190 billing: API.Billing = new API.Billing(this);
191 brandProtection: API.BrandProtection = new API.BrandProtection(this);
192 diagnostics: API.Diagnostics = new API.Diagnostics(this);
193 images: API.Images = new API.Images(this);
194 intel: API.Intel = new API.Intel(this);
195 magicTransit: API.MagicTransit = new API.MagicTransit(this);
196 magicNetworkMonitoring: API.MagicNetworkMonitoring = new API.MagicNetworkMonitoring(this);
197 mtlsCertificates: API.MTLSCertificates = new API.MTLSCertificates(this);
198 pages: API.Pages = new API.Pages(this);
199 pcaps: API.PCAPs = new API.PCAPs(this);
200 registrar: API.Registrar = new API.Registrar(this);
201 requestTracers: API.RequestTracers = new API.RequestTracers(this);
202 rules: API.Rules = new API.Rules(this);
203 storage: API.Storage = new API.Storage(this);
204 stream: API.Stream = new API.Stream(this);
205 alerting: API.Alerting = new API.Alerting(this);
206 d1: API.D1Resource = new API.D1Resource(this);
207 r2: API.R2 = new API.R2(this);
208 warpConnector: API.WARPConnector = new API.WARPConnector(this);
209 workersForPlatforms: API.WorkersForPlatforms = new API.WorkersForPlatforms(this);
210 zeroTrust: API.ZeroTrust = new API.ZeroTrust(this);
211 challenges: API.Challenges = new API.Challenges(this);
212 hyperdrive: API.HyperdriveResource = new API.HyperdriveResource(this);
213 rum: API.RUM = new API.RUM(this);
214 vectorize: API.Vectorize = new API.Vectorize(this);
215 urlScanner: API.URLScanner = new API.URLScanner(this);
216 radar: API.Radar = new API.Radar(this);
217 botManagement: API.BotManagement = new API.BotManagement(this);
218 originPostQuantumEncryption: API.OriginPostQuantumEncryption = new API.OriginPostQuantumEncryption(this);
219 speed: API.Speed = new API.Speed(this);
220 dcvDelegation: API.DCVDelegation = new API.DCVDelegation(this);
221 hostnames: API.Hostnames = new API.Hostnames(this);
222 snippets: API.Snippets = new API.Snippets(this);
223 calls: API.Calls = new API.Calls(this);
224 cloudforceOne: API.CloudforceOne = new API.CloudforceOne(this);
225 eventNotifications: API.EventNotifications = new API.EventNotifications(this);
226 aiGateway: API.AIGateway = new API.AIGateway(this);
227
228 protected override defaultQuery(): Core.DefaultQuery | undefined {
229 return this._options.defaultQuery;
230 }
231
232 protected override defaultHeaders(opts: Core.FinalRequestOptions): Core.Headers {
233 return {
234 ...super.defaultHeaders(opts),
235 'X-Auth-Key': this.apiKey,
236 'X-Auth-Email': this.apiEmail,
237 ...this._options.defaultHeaders,
238 };
239 }
240
241 protected override validateHeaders(headers: Core.Headers, customHeaders: Core.Headers) {
242 if (this.apiEmail && headers['x-auth-email']) {
243 return;
244 }
245 if (customHeaders['x-auth-email'] === null) {
246 return;
247 }
248
249 if (this.apiKey && headers['x-auth-key']) {
250 return;
251 }
252 if (customHeaders['x-auth-key'] === null) {
253 return;
254 }
255
256 if (this.apiToken && headers['authorization']) {
257 return;
258 }
259 if (customHeaders['authorization'] === null) {
260 return;
261 }
262
263 if (this.userServiceKey && headers['x-auth-user-service-key']) {
264 return;
265 }
266 if (customHeaders['x-auth-user-service-key'] === null) {
267 return;
268 }
269
270 throw new Error(
271 'Could not resolve authentication method. Expected one of apiEmail, apiKey, apiToken or userServiceKey to be set. Or for one of the "X-Auth-Email", "X-Auth-Key", "Authorization" or "X-Auth-User-Service-Key" headers to be explicitly omitted',
272 );
273 }
274
275 protected override authHeaders(opts: Core.FinalRequestOptions): Core.Headers {
276 const apiEmailAuth = this.apiEmailAuth(opts);
277 const apiKeyAuth = this.apiKeyAuth(opts);
278 const apiTokenAuth = this.apiTokenAuth(opts);
279 const userServiceKeyAuth = this.userServiceKeyAuth(opts);
280
281 if (
282 apiEmailAuth != null &&
283 !Core.isEmptyObj(apiEmailAuth) &&
284 apiKeyAuth != null &&
285 !Core.isEmptyObj(apiKeyAuth)
286 ) {
287 return { ...apiEmailAuth, ...apiKeyAuth };
288 }
289
290 if (apiTokenAuth != null && !Core.isEmptyObj(apiTokenAuth)) {
291 return apiTokenAuth;
292 }
293
294 if (userServiceKeyAuth != null && !Core.isEmptyObj(userServiceKeyAuth)) {
295 return userServiceKeyAuth;
296 }
297 return {};
298 }
299
300 protected apiEmailAuth(opts: Core.FinalRequestOptions): Core.Headers {
301 if (this.apiEmail == null) {
302 return {};
303 }
304 return { 'X-Auth-Email': this.apiEmail };
305 }
306
307 protected apiKeyAuth(opts: Core.FinalRequestOptions): Core.Headers {
308 if (this.apiKey == null) {
309 return {};
310 }
311 return { 'X-Auth-Key': this.apiKey };
312 }
313
314 protected apiTokenAuth(opts: Core.FinalRequestOptions): Core.Headers {
315 if (this.apiToken == null) {
316 return {};
317 }
318 return { Authorization: `Bearer ${this.apiToken}` };
319 }
320
321 protected userServiceKeyAuth(opts: Core.FinalRequestOptions): Core.Headers {
322 if (this.userServiceKey == null) {
323 return {};
324 }
325 return { 'X-Auth-User-Service-Key': this.userServiceKey };
326 }
327
328 protected override stringifyQuery(query: Record<string, unknown>): string {
329 return qs.stringify(query, { arrayFormat: 'repeat' });
330 }
331
332 static Cloudflare = this;
333
334 static CloudflareError = Errors.CloudflareError;
335 static APIError = Errors.APIError;
336 static APIConnectionError = Errors.APIConnectionError;
337 static APIConnectionTimeoutError = Errors.APIConnectionTimeoutError;
338 static APIUserAbortError = Errors.APIUserAbortError;
339 static NotFoundError = Errors.NotFoundError;
340 static ConflictError = Errors.ConflictError;
341 static RateLimitError = Errors.RateLimitError;
342 static BadRequestError = Errors.BadRequestError;
343 static AuthenticationError = Errors.AuthenticationError;
344 static InternalServerError = Errors.InternalServerError;
345 static PermissionDeniedError = Errors.PermissionDeniedError;
346 static UnprocessableEntityError = Errors.UnprocessableEntityError;
347
348 static toFile = Uploads.toFile;
349 static fileFromPath = Uploads.fileFromPath;
350}
351
352export const {
353 CloudflareError,
354 APIError,
355 APIConnectionError,
356 APIConnectionTimeoutError,
357 APIUserAbortError,
358 NotFoundError,
359 ConflictError,
360 RateLimitError,
361 BadRequestError,
362 AuthenticationError,
363 InternalServerError,
364 PermissionDeniedError,
365 UnprocessableEntityError,
366} = Errors;
367
368export import toFile = Uploads.toFile;
369export import fileFromPath = Uploads.fileFromPath;
370
371export namespace Cloudflare {
372 export import RequestOptions = Core.RequestOptions;
373
374 export import V4PagePagination = Pagination.V4PagePagination;
375 export import V4PagePaginationParams = Pagination.V4PagePaginationParams;
376 export import V4PagePaginationResponse = Pagination.V4PagePaginationResponse;
377
378 export import V4PagePaginationArray = Pagination.V4PagePaginationArray;
379 export import V4PagePaginationArrayParams = Pagination.V4PagePaginationArrayParams;
380 export import V4PagePaginationArrayResponse = Pagination.V4PagePaginationArrayResponse;
381
382 export import CursorPagination = Pagination.CursorPagination;
383 export import CursorPaginationParams = Pagination.CursorPaginationParams;
384 export import CursorPaginationResponse = Pagination.CursorPaginationResponse;
385
386 export import CursorLimitPagination = Pagination.CursorLimitPagination;
387 export import CursorLimitPaginationParams = Pagination.CursorLimitPaginationParams;
388 export import CursorLimitPaginationResponse = Pagination.CursorLimitPaginationResponse;
389
390 export import SinglePage = Pagination.SinglePage;
391 export import SinglePageResponse = Pagination.SinglePageResponse;
392
393 export import Accounts = API.Accounts;
394
395 export import OriginCACertificates = API.OriginCACertificates;
396
397 export import IPs = API.IPs;
398
399 export import Memberships = API.Memberships;
400
401 export import User = API.User;
402
403 export import Zones = API.Zones;
404
405 export import LoadBalancers = API.LoadBalancers;
406
407 export import Cache = API.Cache;
408
409 export import SSL = API.SSL;
410
411 export import Subscriptions = API.Subscriptions;
412
413 export import ACM = API.ACM;
414
415 export import Argo = API.Argo;
416
417 export import Plans = API.Plans;
418
419 export import RatePlans = API.RatePlans;
420
421 export import CertificateAuthorities = API.CertificateAuthorities;
422
423 export import ClientCertificates = API.ClientCertificates;
424
425 export import CustomCertificates = API.CustomCertificates;
426
427 export import CustomHostnames = API.CustomHostnames;
428
429 export import CustomNameservers = API.CustomNameservers;
430
431 export import DNS = API.DNS;
432
433 export import DNSSECResource = API.DNSSECResource;
434
435 export import EmailRouting = API.EmailRouting;
436
437 export import Filters = API.Filters;
438
439 export import Firewall = API.Firewall;
440
441 export import Healthchecks = API.Healthchecks;
442
443 export import KeylessCertificates = API.KeylessCertificates;
444
445 export import Logpush = API.Logpush;
446
447 export import Logs = API.Logs;
448
449 export import OriginTLSClientAuth = API.OriginTLSClientAuth;
450
451 export import Pagerules = API.Pagerules;
452
453 export import RateLimits = API.RateLimits;
454
455 export import SecondaryDNS = API.SecondaryDNS;
456
457 export import WaitingRooms = API.WaitingRooms;
458
459 export import Web3 = API.Web3;
460
461 export import Workers = API.Workers;
462
463 export import KV = API.KV;
464
465 export import DurableObjects = API.DurableObjects;
466
467 export import Queues = API.Queues;
468
469 export import ManagedHeaders = API.ManagedHeaders;
470
471 export import PageShield = API.PageShield;
472
473 export import Rulesets = API.Rulesets;
474
475 export import URLNormalization = API.URLNormalization;
476
477 export import Spectrum = API.Spectrum;
478
479 export import Addressing = API.Addressing;
480
481 export import AuditLogs = API.AuditLogs;
482
483 export import Billing = API.Billing;
484
485 export import BrandProtection = API.BrandProtection;
486
487 export import Diagnostics = API.Diagnostics;
488
489 export import Images = API.Images;
490
491 export import Intel = API.Intel;
492
493 export import MagicTransit = API.MagicTransit;
494
495 export import MagicNetworkMonitoring = API.MagicNetworkMonitoring;
496
497 export import MTLSCertificates = API.MTLSCertificates;
498
499 export import Pages = API.Pages;
500
501 export import PCAPs = API.PCAPs;
502
503 export import Registrar = API.Registrar;
504
505 export import RequestTracers = API.RequestTracers;
506
507 export import Rules = API.Rules;
508
509 export import Storage = API.Storage;
510
511 export import Stream = API.Stream;
512
513 export import Alerting = API.Alerting;
514
515 export import D1Resource = API.D1Resource;
516
517 export import R2 = API.R2;
518
519 export import WARPConnector = API.WARPConnector;
520
521 export import WorkersForPlatforms = API.WorkersForPlatforms;
522
523 export import ZeroTrust = API.ZeroTrust;
524
525 export import Challenges = API.Challenges;
526
527 export import HyperdriveResource = API.HyperdriveResource;
528
529 export import RUM = API.RUM;
530
531 export import Vectorize = API.Vectorize;
532
533 export import URLScanner = API.URLScanner;
534
535 export import Radar = API.Radar;
536
537 export import BotManagement = API.BotManagement;
538
539 export import OriginPostQuantumEncryption = API.OriginPostQuantumEncryption;
540
541 export import Speed = API.Speed;
542
543 export import DCVDelegation = API.DCVDelegation;
544
545 export import Hostnames = API.Hostnames;
546
547 export import Snippets = API.Snippets;
548
549 export import Calls = API.Calls;
550
551 export import CloudforceOne = API.CloudforceOne;
552
553 export import EventNotifications = API.EventNotifications;
554
555 export import AIGateway = API.AIGateway;
556
557 export import ASN = API.ASN;
558 export import AuditLog = API.AuditLog;
559 export import CertificateCA = API.CertificateCA;
560 export import CertificateRequestType = API.CertificateRequestType;
561 export import CloudflareTunnel = API.CloudflareTunnel;
562 export import ErrorData = API.ErrorData;
563 export import Identifier = API.Identifier;
564 export import LoadBalancerPreview = API.LoadBalancerPreview;
565 export import Member = API.Member;
566 export import PaginationInfo = API.PaginationInfo;
567 export import Permission = API.Permission;
568 export import PermissionGrant = API.PermissionGrant;
569 export import ResponseInfo = API.ResponseInfo;
570 export import Result = API.Result;
571 export import Role = API.Role;
572 export import SortDirection = API.SortDirection;
573}
574
575export default Cloudflare;
576