// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../resource'; import * as Core from '../../core'; export class Content extends APIResource { /** * Fetches rendered HTML content from provided URL or HTML. Check available options * like `gotoOptions` and `waitFor*` to control page load behaviour. * * @example * ```ts * const content = * await client.browserRendering.content.create({ * account_id: 'account_id', * url: 'https://www.example.com/', * }); * ``` */ create(params: ContentCreateParams, options?: Core.RequestOptions): Core.APIPromise { const { account_id, cacheTTL, ...body } = params; return ( this._client.post(`/accounts/${account_id}/browser-rendering/content`, { query: { cacheTTL }, body, ...options, }) as Core.APIPromise<{ result: ContentCreateResponse }> )._thenUnwrap((obj) => obj.result); } } /** * HTML content. */ export type ContentCreateResponse = string; export type ContentCreateParams = ContentCreateParams.Variant0 | ContentCreateParams.Variant1; export declare namespace ContentCreateParams { export interface Variant0 { /** * Path param: Account ID. */ account_id: string; /** * Body param: URL to navigate to, eg. `https://example.com`. */ url: string; /** * Query param: Cache TTL default is 5s. Set to 0 to disable. */ cacheTTL?: number; /** * Body param: The maximum duration allowed for the browser action to complete * after the page has loaded (such as taking screenshots, extracting content, or * generating PDFs). If this time limit is exceeded, the action stops and returns a * timeout error. */ actionTimeout?: number; /** * Body param: Adds a `