// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import * as Core from 'cloudflare/core'; import { APIResource } from 'cloudflare/resource'; import * as TotalTLSAPI from 'cloudflare/resources/acm/total-tls'; export class TotalTLS extends APIResource { /** * Set Total TLS Settings or disable the feature for a Zone. */ create( params: TotalTLSCreateParams, options?: Core.RequestOptions, ): Core.APIPromise { 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 { const { zone_id } = params; return ( this._client.get(`/zones/${zone_id}/acm/total_tls`, options) as Core.APIPromise<{ result: TotalTLSGetResponse; }> )._thenUnwrap((obj) => obj.result); } } export interface TotalTLSCreateResponse { /** * The Certificate Authority that Total TLS certificates will be issued through. */ certificate_authority?: 'google' | 'lets_encrypt'; /** * 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_days?: 90; } export interface TotalTLSGetResponse { /** * The Certificate Authority that Total TLS certificates will be issued through. */ certificate_authority?: 'google' | 'lets_encrypt'; /** * 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_days?: 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?: 'google' | 'lets_encrypt'; } export interface TotalTLSGetParams { /** * Identifier */ zone_id: string; } export namespace TotalTLS { export import TotalTLSCreateResponse = TotalTLSAPI.TotalTLSCreateResponse; export import TotalTLSGetResponse = TotalTLSAPI.TotalTLSGetResponse; export import TotalTLSCreateParams = TotalTLSAPI.TotalTLSCreateParams; export import TotalTLSGetParams = TotalTLSAPI.TotalTLSGetParams; }