cloudflare
Version:
The official TypeScript library for the Cloudflare API
116 lines (99 loc) • 3.18 kB
text/typescript
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { APIResource } from '../../resource';
import * as Core from '../../core';
export class TotalTLS extends APIResource {
/**
* Set Total TLS Settings or disable the feature for a Zone.
*/
create(
params: TotalTLSCreateParams,
options?: Core.RequestOptions,
): Core.APIPromise<TotalTLSCreateResponse> {
const { zone_id, ...body } = params;
return (
this._client.post(`/zones/${zone_id}/acm/total_tls`, { body, ...options }) as Core.APIPromise<{
result: TotalTLSCreateResponse;
}>
)._thenUnwrap((obj) => obj.result);
}
/**
* Get Total TLS Settings for a Zone.
*/
get(params: TotalTLSGetParams, options?: Core.RequestOptions): Core.APIPromise<TotalTLSGetResponse> {
const { zone_id } = params;
return (
this._client.get(`/zones/${zone_id}/acm/total_tls`, options) as Core.APIPromise<{
result: TotalTLSGetResponse;
}>
)._thenUnwrap((obj) => obj.result);
}
}
/**
* The Certificate Authority that Total TLS certificates will be issued through.
*/
export type CertificateAuthority = 'google' | 'lets_encrypt' | 'ssl_com';
/**
* The Certificate Authority that Total TLS certificates will be issued through.
*/
export type CertificateAuthorityParam = 'google' | 'lets_encrypt' | 'ssl_com';
export interface TotalTLSCreateResponse {
/**
* The Certificate Authority that Total TLS certificates will be issued through.
*/
certificate_authority?: CertificateAuthority;
/**
* If enabled, Total TLS will order a hostname specific TLS certificate for any
* proxied A, AAAA, or CNAME record in your zone.
*/
enabled?: boolean;
/**
* The validity period in days for the certificates ordered via Total TLS.
*/
validity_period?: 90;
}
export interface TotalTLSGetResponse {
/**
* The Certificate Authority that Total TLS certificates will be issued through.
*/
certificate_authority?: CertificateAuthority;
/**
* If enabled, Total TLS will order a hostname specific TLS certificate for any
* proxied A, AAAA, or CNAME record in your zone.
*/
enabled?: boolean;
/**
* The validity period in days for the certificates ordered via Total TLS.
*/
validity_period?: 90;
}
export interface TotalTLSCreateParams {
/**
* Path param: Identifier
*/
zone_id: string;
/**
* Body param: If enabled, Total TLS will order a hostname specific TLS certificate
* for any proxied A, AAAA, or CNAME record in your zone.
*/
enabled: boolean;
/**
* Body param: The Certificate Authority that Total TLS certificates will be issued
* through.
*/
certificate_authority?: CertificateAuthorityParam;
}
export interface TotalTLSGetParams {
/**
* Identifier
*/
zone_id: string;
}
export declare namespace TotalTLS {
export {
type CertificateAuthority as CertificateAuthority,
type TotalTLSCreateResponse as TotalTLSCreateResponse,
type TotalTLSGetResponse as TotalTLSGetResponse,
type TotalTLSCreateParams as TotalTLSCreateParams,
type TotalTLSGetParams as TotalTLSGetParams,
};
}