type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Put configuration
* Adds or updates the configuration for a remotely-managed tunnel.
*/
export async function main(
auth: Cloudflare,
tunnel_id: string,
account_identifier: string,
body: {
config?: {
ingress?: {
hostname: string;
originRequest?: {
access?: {
audTag: string[];
required?: boolean;
teamName: string;
[k: string]: unknown;
};
caPool?: string;
connectTimeout?: number;
disableChunkedEncoding?: boolean;
http2Origin?: boolean;
httpHostHeader?: string;
keepAliveConnections?: number;
keepAliveTimeout?: number;
noHappyEyeballs?: boolean;
noTLSVerify?: boolean;
originServerName?: string;
proxyType?: string;
tcpKeepAlive?: number;
tlsTimeout?: number;
[k: string]: unknown;
};
path?: string;
service: string;
[k: string]: unknown;
}[];
originRequest?: {
access?: {
audTag: string[];
required?: boolean;
teamName: string;
[k: string]: unknown;
};
caPool?: string;
connectTimeout?: number;
disableChunkedEncoding?: boolean;
http2Origin?: boolean;
httpHostHeader?: string;
keepAliveConnections?: number;
keepAliveTimeout?: number;
noHappyEyeballs?: boolean;
noTLSVerify?: boolean;
originServerName?: string;
proxyType?: string;
tcpKeepAlive?: number;
tlsTimeout?: number;
[k: string]: unknown;
};
"warp-routing"?: { enabled?: boolean; [k: string]: unknown };
[k: string]: unknown;
};
[k: string]: unknown;
}
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/accounts/${account_identifier}/cfd_tunnel/${tunnel_id}/configurations`
);
const response = await fetch(url, {
method: "PUT",
headers: {
"X-AUTH-EMAIL": auth.email,
"X-AUTH-KEY": auth.key,
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
body: JSON.stringify(body),
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 383 days ago
type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Put configuration
* Adds or updates the configuration for a remotely-managed tunnel.
*/
export async function main(
auth: Cloudflare,
tunnel_id: string,
account_identifier: string,
body: {
config?: {
ingress?: {
hostname: string;
originRequest?: {
access?: {
audTag: string[];
required?: boolean;
teamName: string;
[k: string]: unknown;
};
caPool?: string;
connectTimeout?: number;
disableChunkedEncoding?: boolean;
http2Origin?: boolean;
httpHostHeader?: string;
keepAliveConnections?: number;
keepAliveTimeout?: number;
noHappyEyeballs?: boolean;
noTLSVerify?: boolean;
originServerName?: string;
proxyType?: string;
tcpKeepAlive?: number;
tlsTimeout?: number;
[k: string]: unknown;
};
path?: string;
service: string;
[k: string]: unknown;
}[];
originRequest?: {
access?: {
audTag: string[];
required?: boolean;
teamName: string;
[k: string]: unknown;
};
caPool?: string;
connectTimeout?: number;
disableChunkedEncoding?: boolean;
http2Origin?: boolean;
httpHostHeader?: string;
keepAliveConnections?: number;
keepAliveTimeout?: number;
noHappyEyeballs?: boolean;
noTLSVerify?: boolean;
originServerName?: string;
proxyType?: string;
tcpKeepAlive?: number;
tlsTimeout?: number;
[k: string]: unknown;
};
"warp-routing"?: { enabled?: boolean; [k: string]: unknown };
[k: string]: unknown;
};
[k: string]: unknown;
}
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/accounts/${account_identifier}/cfd_tunnel/${tunnel_id}/configurations`
);
const response = await fetch(url, {
method: "PUT",
headers: {
"X-AUTH-EMAIL": auth.email,
"X-AUTH-KEY": auth.key,
"Content-Type": "application/json",
Authorization: "Bearer " + auth.token,
},
body: JSON.stringify(body),
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 920 days ago