cloudflare
Version:
The official TypeScript library for the Cloudflare API
81 lines (69 loc) • 1.85 kB
text/typescript
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import * as Core from "../../../core";
import { APIResource } from "../../../resource";
import * as HTTP2API from "./http2";
export class HTTP2Resource extends APIResource {
/**
* Value of the HTTP2 setting.
*/
edit(params: HTTP2EditParams, options?: Core.RequestOptions): Core.APIPromise<HTTP2> {
const { zone_id, ...body } = params;
return (
this._client.patch(`/zones/${zone_id}/settings/http2`, { body, ...options }) as Core.APIPromise<{
result: HTTP2;
}>
)._thenUnwrap((obj) => obj.result);
}
/**
* Value of the HTTP2 setting.
*/
get(params: HTTP2GetParams, options?: Core.RequestOptions): Core.APIPromise<HTTP2> {
const { zone_id } = params;
return (
this._client.get(`/zones/${zone_id}/settings/http2`, options) as Core.APIPromise<{ result: HTTP2 }>
)._thenUnwrap((obj) => obj.result);
}
}
/**
* HTTP2 enabled for this zone.
*/
export interface HTTP2 {
/**
* ID of the zone setting.
*/
id: 'http2';
/**
* Current value of the zone setting.
*/
value: 'on' | 'off';
/**
* Whether or not this setting can be modified for this zone (based on your
* Cloudflare plan level).
*/
editable?: true | false;
/**
* last time this setting was modified.
*/
modified_on?: string | null;
}
export interface HTTP2EditParams {
/**
* Path param: Identifier
*/
zone_id: string;
/**
* Body param: Value of the HTTP2 setting.
*/
value: 'on' | 'off';
}
export interface HTTP2GetParams {
/**
* Identifier
*/
zone_id: string;
}
export namespace HTTP2Resource {
export import HTTP2 = HTTP2API.HTTP2;
export import HTTP2EditParams = HTTP2API.HTTP2EditParams;
export import HTTP2GetParams = HTTP2API.HTTP2GetParams;
}