Skip to content

Commit

Permalink
feat: OpenAPI spec update via Stainless API (#55)
Browse files Browse the repository at this point in the history
  • Loading branch information
stainless-app[bot] authored Feb 21, 2024
1 parent 1a9ffb0 commit 0bfd19f
Show file tree
Hide file tree
Showing 4 changed files with 135 additions and 29 deletions.
24 changes: 18 additions & 6 deletions src/resources/magics/gre-tunnels.ts
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,9 @@ export namespace GreTunnelCreateResponse {
* The direction of the flow of the healthcheck. Either unidirectional, where the
* probe comes to you via the tunnel and the result comes back to Cloudflare via
* the open Internet, or bidirectional where both the probe and result come and go
* via the tunnel.
* via the tunnel. Note in the case of bidirecitonal healthchecks, the target field
* in health_check is ignored as the interface_address is used to send traffic into
* the tunnel.
*/
direction?: 'unidirectional' | 'bidirectional';

Expand All @@ -171,7 +173,9 @@ export namespace GreTunnelCreateResponse {
/**
* The destination address in a request type health check. After the healthcheck is
* decapsulated at the customer end of the tunnel, the ICMP echo will be forwarded
* to this address. This field defaults to `customer_gre_endpoint address`.
* to this address. This field defaults to `customer_gre_endpoint address`. This
* field is ignored for bidirectional healthchecks as the interface_address (not
* assigned to the Cloudflare side of the tunnel) is used as the target.
*/
target?: string;

Expand Down Expand Up @@ -258,7 +262,9 @@ export namespace GreTunnelListResponse {
* The direction of the flow of the healthcheck. Either unidirectional, where the
* probe comes to you via the tunnel and the result comes back to Cloudflare via
* the open Internet, or bidirectional where both the probe and result come and go
* via the tunnel.
* via the tunnel. Note in the case of bidirecitonal healthchecks, the target field
* in health_check is ignored as the interface_address is used to send traffic into
* the tunnel.
*/
direction?: 'unidirectional' | 'bidirectional';

Expand All @@ -275,7 +281,9 @@ export namespace GreTunnelListResponse {
/**
* The destination address in a request type health check. After the healthcheck is
* decapsulated at the customer end of the tunnel, the ICMP echo will be forwarded
* to this address. This field defaults to `customer_gre_endpoint address`.
* to this address. This field defaults to `customer_gre_endpoint address`. This
* field is ignored for bidirectional healthchecks as the interface_address (not
* assigned to the Cloudflare side of the tunnel) is used as the target.
*/
target?: string;

Expand Down Expand Up @@ -348,7 +356,9 @@ export namespace GreTunnelUpdateParams {
* The direction of the flow of the healthcheck. Either unidirectional, where the
* probe comes to you via the tunnel and the result comes back to Cloudflare via
* the open Internet, or bidirectional where both the probe and result come and go
* via the tunnel.
* via the tunnel. Note in the case of bidirecitonal healthchecks, the target field
* in health_check is ignored as the interface_address is used to send traffic into
* the tunnel.
*/
direction?: 'unidirectional' | 'bidirectional';

Expand All @@ -365,7 +375,9 @@ export namespace GreTunnelUpdateParams {
/**
* The destination address in a request type health check. After the healthcheck is
* decapsulated at the customer end of the tunnel, the ICMP echo will be forwarded
* to this address. This field defaults to `customer_gre_endpoint address`.
* to this address. This field defaults to `customer_gre_endpoint address`. This
* field is ignored for bidirectional healthchecks as the interface_address (not
* assigned to the Cloudflare side of the tunnel) is used as the target.
*/
target?: string;

Expand Down
80 changes: 80 additions & 0 deletions src/resources/magics/ipsec-tunnels/ipsec-tunnels.ts
Original file line number Diff line number Diff line change
Expand Up @@ -345,6 +345,8 @@ export interface IpsecTunnelCreateParams {
*/
description?: string;

health_check?: IpsecTunnelCreateParams.HealthCheck;

/**
* A randomly generated or provided string for use in the IPsec tunnel.
*/
Expand All @@ -357,6 +359,44 @@ export interface IpsecTunnelCreateParams {
replay_protection?: boolean;
}

export namespace IpsecTunnelCreateParams {
export interface HealthCheck {
/**
* The direction of the flow of the healthcheck. Either unidirectional, where the
* probe comes to you via the tunnel and the result comes back to Cloudflare via
* the open Internet, or bidirectional where both the probe and result come and go
* via the tunnel. Note in the case of bidirecitonal healthchecks, the target field
* in health_check is ignored as the interface_address is used to send traffic into
* the tunnel.
*/
direction?: 'unidirectional' | 'bidirectional';

/**
* Determines whether to run healthchecks for a tunnel.
*/
enabled?: boolean;

/**
* How frequent the health check is run. The default value is `mid`.
*/
rate?: 'low' | 'mid' | 'high';

/**
* The destination address in a request type health check. After the healthcheck is
* decapsulated at the customer end of the tunnel, the ICMP echo will be forwarded
* to this address. This field defaults to `customer_gre_endpoint address`. This
* field is ignored for bidirectional healthchecks as the interface_address (not
* assigned to the Cloudflare side of the tunnel) is used as the target.
*/
target?: string;

/**
* The type of healthcheck to run, reply or request. The default value is `reply`.
*/
type?: 'reply' | 'request';
}
}

export interface IpsecTunnelUpdateParams {
/**
* The IP address assigned to the Cloudflare side of the IPsec tunnel.
Expand Down Expand Up @@ -385,6 +425,8 @@ export interface IpsecTunnelUpdateParams {
*/
description?: string;

health_check?: IpsecTunnelUpdateParams.HealthCheck;

/**
* A randomly generated or provided string for use in the IPsec tunnel.
*/
Expand All @@ -397,6 +439,44 @@ export interface IpsecTunnelUpdateParams {
replay_protection?: boolean;
}

export namespace IpsecTunnelUpdateParams {
export interface HealthCheck {
/**
* The direction of the flow of the healthcheck. Either unidirectional, where the
* probe comes to you via the tunnel and the result comes back to Cloudflare via
* the open Internet, or bidirectional where both the probe and result come and go
* via the tunnel. Note in the case of bidirecitonal healthchecks, the target field
* in health_check is ignored as the interface_address is used to send traffic into
* the tunnel.
*/
direction?: 'unidirectional' | 'bidirectional';

/**
* Determines whether to run healthchecks for a tunnel.
*/
enabled?: boolean;

/**
* How frequent the health check is run. The default value is `mid`.
*/
rate?: 'low' | 'mid' | 'high';

/**
* The destination address in a request type health check. After the healthcheck is
* decapsulated at the customer end of the tunnel, the ICMP echo will be forwarded
* to this address. This field defaults to `customer_gre_endpoint address`. This
* field is ignored for bidirectional healthchecks as the interface_address (not
* assigned to the Cloudflare side of the tunnel) is used as the target.
*/
target?: string;

/**
* The type of healthcheck to run, reply or request. The default value is `reply`.
*/
type?: 'reply' | 'request';
}
}

export namespace IpsecTunnels {
export import IpsecTunnelCreateResponse = IpsecTunnelsAPI.IpsecTunnelCreateResponse;
export import IpsecTunnelUpdateResponse = IpsecTunnelsAPI.IpsecTunnelUpdateResponse;
Expand Down
46 changes: 23 additions & 23 deletions src/resources/pcaps/pcaps.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,11 @@ export class Pcaps extends APIResource {
}

export type PcapCreateResponse =
| PcapCreateResponse.BvwDlDzxPcapsResponseSimple
| PcapCreateResponse.BvwDlDzxPcapsResponseFull;
| PcapCreateResponse._7WjqRy2XPcapsResponseSimple
| PcapCreateResponse._7WjqRy2XPcapsResponseFull;

export namespace PcapCreateResponse {
export interface BvwDlDzxPcapsResponseSimple {
export interface _7WjqRy2XPcapsResponseSimple {
/**
* The ID for the packet capture.
*/
Expand All @@ -66,7 +66,7 @@ export namespace PcapCreateResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseSimple.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseSimple.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -103,7 +103,7 @@ export namespace PcapCreateResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseSimple {
export namespace _7WjqRy2XPcapsResponseSimple {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down Expand Up @@ -135,7 +135,7 @@ export namespace PcapCreateResponse {
}
}

export interface BvwDlDzxPcapsResponseFull {
export interface _7WjqRy2XPcapsResponseFull {
/**
* The ID for the packet capture.
*/
Expand Down Expand Up @@ -168,7 +168,7 @@ export namespace PcapCreateResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseFull.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseFull.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -205,7 +205,7 @@ export namespace PcapCreateResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseFull {
export namespace _7WjqRy2XPcapsResponseFull {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down Expand Up @@ -239,11 +239,11 @@ export namespace PcapCreateResponse {
}

export type PcapListResponse = Array<
PcapListResponse.BvwDlDzxPcapsResponseSimple | PcapListResponse.BvwDlDzxPcapsResponseFull
PcapListResponse._7WjqRy2XPcapsResponseSimple | PcapListResponse._7WjqRy2XPcapsResponseFull
>;

export namespace PcapListResponse {
export interface BvwDlDzxPcapsResponseSimple {
export interface _7WjqRy2XPcapsResponseSimple {
/**
* The ID for the packet capture.
*/
Expand All @@ -252,7 +252,7 @@ export namespace PcapListResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseSimple.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseSimple.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -289,7 +289,7 @@ export namespace PcapListResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseSimple {
export namespace _7WjqRy2XPcapsResponseSimple {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down Expand Up @@ -321,7 +321,7 @@ export namespace PcapListResponse {
}
}

export interface BvwDlDzxPcapsResponseFull {
export interface _7WjqRy2XPcapsResponseFull {
/**
* The ID for the packet capture.
*/
Expand Down Expand Up @@ -354,7 +354,7 @@ export namespace PcapListResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseFull.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseFull.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -391,7 +391,7 @@ export namespace PcapListResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseFull {
export namespace _7WjqRy2XPcapsResponseFull {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down Expand Up @@ -425,11 +425,11 @@ export namespace PcapListResponse {
}

export type PcapGetResponse =
| PcapGetResponse.BvwDlDzxPcapsResponseSimple
| PcapGetResponse.BvwDlDzxPcapsResponseFull;
| PcapGetResponse._7WjqRy2XPcapsResponseSimple
| PcapGetResponse._7WjqRy2XPcapsResponseFull;

export namespace PcapGetResponse {
export interface BvwDlDzxPcapsResponseSimple {
export interface _7WjqRy2XPcapsResponseSimple {
/**
* The ID for the packet capture.
*/
Expand All @@ -438,7 +438,7 @@ export namespace PcapGetResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseSimple.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseSimple.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -475,7 +475,7 @@ export namespace PcapGetResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseSimple {
export namespace _7WjqRy2XPcapsResponseSimple {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down Expand Up @@ -507,7 +507,7 @@ export namespace PcapGetResponse {
}
}

export interface BvwDlDzxPcapsResponseFull {
export interface _7WjqRy2XPcapsResponseFull {
/**
* The ID for the packet capture.
*/
Expand Down Expand Up @@ -540,7 +540,7 @@ export namespace PcapGetResponse {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
filter_v1?: BvwDlDzxPcapsResponseFull.FilterV1;
filter_v1?: _7WjqRy2XPcapsResponseFull.FilterV1;

/**
* The status of the packet capture request.
Expand Down Expand Up @@ -577,7 +577,7 @@ export namespace PcapGetResponse {
type?: 'simple' | 'full';
}

export namespace BvwDlDzxPcapsResponseFull {
export namespace _7WjqRy2XPcapsResponseFull {
/**
* The packet capture filter. When this field is empty, all packets are captured.
*/
Expand Down
14 changes: 14 additions & 0 deletions tests/api-resources/magics/ipsec-tunnels/ipsec-tunnels.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,13 @@ describe('resource ipsecTunnels', () => {
name: 'IPsec_1',
customer_endpoint: '203.0.113.1',
description: 'Tunnel for ISP X',
health_check: {
direction: 'bidirectional',
enabled: true,
rate: 'low',
target: '203.0.113.1',
type: 'request',
},
psk: 'O3bwKSjnaoCxDoUxjcq4Rk8ZKkezQUiy',
replay_protection: false,
});
Expand Down Expand Up @@ -69,6 +76,13 @@ describe('resource ipsecTunnels', () => {
name: 'IPsec_1',
customer_endpoint: '203.0.113.1',
description: 'Tunnel for ISP X',
health_check: {
direction: 'bidirectional',
enabled: true,
rate: 'low',
target: '203.0.113.1',
type: 'request',
},
psk: 'O3bwKSjnaoCxDoUxjcq4Rk8ZKkezQUiy',
replay_protection: false,
},
Expand Down

0 comments on commit 0bfd19f

Please sign in to comment.