@kubernetes-models/gke
Version:
104 lines (103 loc) • 5.1 kB
TypeScript
import { IObjectMeta } from "@kubernetes-models/apimachinery/apis/meta/v1/ObjectMeta";
import { Model, ModelData } from "@kubernetes-models/base";
/**
* GCPSessionAffinityFilter provides a way to configure session affinity for a RouteAction.
*/
export interface IGCPSessionAffinityFilter {
/**
* APIVersion defines the versioned schema of this representation of an object.
* Servers should convert recognized schemas to the latest internal value, and
* may reject unrecognized values.
* More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
*/
"apiVersion": "networking.gke.io/v1";
/**
* Kind is a string value representing the REST resource this object represents.
* Servers may infer this from the endpoint the client submits requests to.
* Cannot be updated.
* In CamelCase.
* More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
*/
"kind": "GCPSessionAffinityFilter";
"metadata"?: IObjectMeta;
/**
* Spec defines the desired state of GCPSessionAffinityFilter.
*/
"spec": {
/**
* StatefulGeneratedCookieConfig defines cookie-based stateful session affinity where the date plane
* supplies a “session cookie” with the name "GSSA" which encodes a specific destination host and
* each request containing that cookie will be directed to that host as long as the destination host
* remains up and healthy.
* GCP will manage the session cookie but the client application code is responsible for copying the
* cookie from each RPC in the session to the next.
*/
"statefulGeneratedCookie"?: {
/**
* The cookie TTL value for the Set-Cookie header generated by the data plane. The lifetime of the
* cookie may be set to a value from 1 to 86400 seconds (24 hours) inclusive.
*/
"cookieTtlSeconds": number;
};
};
/**
* Status defines the current state of GCPSessionAffinityFilter.
*/
"status"?: {
/**
* Conditions describe the current conditions of the GCPSessionAffinityFilter.
*/
"conditions"?: Array<{
/**
* lastTransitionTime is the last time the condition transitioned from one status to another.
* This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.
*/
"lastTransitionTime": string;
/**
* message is a human readable message indicating details about the transition.
* This may be an empty string.
*/
"message": string;
/**
* observedGeneration represents the .metadata.generation that the condition was set based upon.
* For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date
* with respect to the current state of the instance.
*/
"observedGeneration"?: number;
/**
* reason contains a programmatic identifier indicating the reason for the condition's last transition.
* Producers of specific condition types may define expected values and meanings for this field,
* and whether the values are considered a guaranteed API.
* The value should be a CamelCase string.
* This field may not be empty.
*/
"reason": string;
/**
* status of the condition, one of True, False, Unknown.
*/
"status": "True" | "False" | "Unknown";
/**
* type of condition in CamelCase or in foo.example.com/CamelCase.
* ---
* Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be
* useful (see .node.status.conditions), the ability to deconflict is important.
* The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
*/
"type": string;
}>;
};
}
/**
* GCPSessionAffinityFilter provides a way to configure session affinity for a RouteAction.
*/
export declare class GCPSessionAffinityFilter extends Model<IGCPSessionAffinityFilter> implements IGCPSessionAffinityFilter {
"apiVersion": IGCPSessionAffinityFilter["apiVersion"];
"kind": IGCPSessionAffinityFilter["kind"];
"metadata"?: IGCPSessionAffinityFilter["metadata"];
"spec": IGCPSessionAffinityFilter["spec"];
"status"?: IGCPSessionAffinityFilter["status"];
static apiVersion: IGCPSessionAffinityFilter["apiVersion"];
static kind: IGCPSessionAffinityFilter["kind"];
static is: import("@kubernetes-models/base").TypeMetaGuard<IGCPSessionAffinityFilter>;
constructor(data?: ModelData<IGCPSessionAffinityFilter>);
}