Documentation ¶
Index ¶
- Constants
- func AddManagementApiServerSecurity(dc *api.CassandraDatacenter, pod *corev1.PodTemplateSpec) error
- func BuildPodHostFromPod(pod *corev1.Pod) (string, error)
- func FakeExecutorServerWithDetails(callDetails *CallDetails) (*httptest.Server, error)
- func FakeExecutorServerWithDetailsFails(callDetails *CallDetails) (*httptest.Server, error)
- func FakeMgmtApiServer(callDetails *CallDetails, handlerFunc http.HandlerFunc) (*httptest.Server, error)
- func FakeServerWithoutFeaturesEndpoint(callDetails *CallDetails) (*httptest.Server, error)
- func GetManagementApiProtocol(dc *api.CassandraDatacenter) (string, error)
- func GetMgmtApiWgetAction(dc *api.CassandraDatacenter, endpoint string) (*corev1.ExecAction, error)
- func GetMgmtApiWgetPostAction(dc *api.CassandraDatacenter, endpoint string, postData string) (*corev1.ExecAction, error)
- func GetPodHost(podName, clusterName, dcName, namespace string) string
- func ValidateManagementApiConfig(dc *api.CassandraDatacenter, client client.Client, ctx context.Context) []error
- type CallDetails
- type CassMetadataEndpoints
- type ClusteringOrder
- type ColumnDefinition
- func NewClusteringColumn(name string, dataType string, position int, order ClusteringOrder) *ColumnDefinition
- func NewPartitionKeyColumn(name string, dataType string, position int) *ColumnDefinition
- func NewRegularColumn(name string, dataType string) *ColumnDefinition
- func NewStaticColumn(name string, dataType string) *ColumnDefinition
- type ColumnKind
- type EndpointState
- type EndpointStateStatus
- type Feature
- type FeatureSet
- type HttpClient
- type InsecureManagementApiSecurityProvider
- func (provider *InsecureManagementApiSecurityProvider) AddServerSecurity(pod *corev1.PodTemplateSpec) error
- func (provider *InsecureManagementApiSecurityProvider) BuildHttpClient(client client.Client, ctx context.Context) (HttpClient, error)
- func (provider *InsecureManagementApiSecurityProvider) BuildMgmtApiWgetAction(endpoint string) *corev1.ExecAction
- func (provider *InsecureManagementApiSecurityProvider) BuildMgmtApiWgetPostAction(endpoint string, postData string) *corev1.ExecAction
- func (provider *InsecureManagementApiSecurityProvider) GetProtocol() string
- func (provider *InsecureManagementApiSecurityProvider) ValidateConfig(client client.Client, ctx context.Context) []error
- type JobDetails
- type ManagementApiSecurityProvider
- type ManualManagementApiSecurityProvider
- func (provider *ManualManagementApiSecurityProvider) AddServerSecurity(pod *corev1.PodTemplateSpec) error
- func (provider *ManualManagementApiSecurityProvider) BuildHttpClient(client client.Client, ctx context.Context) (HttpClient, error)
- func (provider *ManualManagementApiSecurityProvider) BuildMgmtApiWgetAction(endpoint string) *corev1.ExecAction
- func (provider *ManualManagementApiSecurityProvider) BuildMgmtApiWgetPostAction(endpoint string, postData string) *corev1.ExecAction
- func (provider *ManualManagementApiSecurityProvider) GetProtocol() string
- func (provider *ManualManagementApiSecurityProvider) ValidateConfig(client client.Client, ctx context.Context) []error
- type NoPodIPError
- type NodeMgmtClient
- func (client *NodeMgmtClient) AlterKeyspace(pod *corev1.Pod, keyspaceName string, replicationSettings []map[string]string) error
- func (client *NodeMgmtClient) CallCreateRoleEndpoint(pod *corev1.Pod, username string, password string, superuser bool) error
- func (client *NodeMgmtClient) CallDatacenterRebuild(pod *corev1.Pod, sourceDatacenter string) (string, error)
- func (client *NodeMgmtClient) CallDecommissionNode(pod *corev1.Pod, force bool) (string, error)
- func (client *NodeMgmtClient) CallDecommissionNodeEndpoint(pod *corev1.Pod) error
- func (client *NodeMgmtClient) CallDrainEndpoint(pod *corev1.Pod) error
- func (client *NodeMgmtClient) CallIsFullQueryLogEnabledEndpoint(pod *corev1.Pod) (bool, error)
- func (client *NodeMgmtClient) CallKeyspaceCleanup(pod *corev1.Pod, jobs int, keyspaceName string, tables []string) (string, error)
- func (client *NodeMgmtClient) CallKeyspaceCleanupEndpoint(pod *corev1.Pod, jobs int, keyspaceName string, tables []string) error
- func (client *NodeMgmtClient) CallLifecycleStartEndpoint(pod *corev1.Pod) error
- func (client *NodeMgmtClient) CallLifecycleStartEndpointWithReplaceIp(pod *corev1.Pod, replaceIp string) error
- func (client *NodeMgmtClient) CallMetadataEndpointsEndpoint(pod *corev1.Pod) (CassMetadataEndpoints, error)
- func (client *NodeMgmtClient) CallProbeClusterEndpoint(pod *corev1.Pod, consistencyLevel string, rfPerDc int) error
- func (client *NodeMgmtClient) CallReloadSeedsEndpoint(pod *corev1.Pod) error
- func (client *NodeMgmtClient) CallSchemaVersionsEndpoint(pod *corev1.Pod) (map[string][]string, error)
- func (client *NodeMgmtClient) CallSetFullQueryLog(pod *corev1.Pod, enableFullQueryLogging bool) error
- func (client *NodeMgmtClient) CreateKeyspace(pod *corev1.Pod, keyspaceName string, replicationSettings []map[string]string) error
- func (client *NodeMgmtClient) CreateTable(pod *corev1.Pod, table *TableDefinition) error
- func (client *NodeMgmtClient) FeatureSet(pod *corev1.Pod) (*FeatureSet, error)
- func (client *NodeMgmtClient) GetKeyspace(pod *corev1.Pod, keyspaceName string) ([]string, error)
- func (client *NodeMgmtClient) GetKeyspaceReplication(pod *corev1.Pod, keyspaceName string) (map[string]string, error)
- func (client *NodeMgmtClient) JobDetails(pod *corev1.Pod, jobId string) (*JobDetails, error)
- func (client *NodeMgmtClient) ListKeyspaces(pod *corev1.Pod) ([]string, error)
- func (client *NodeMgmtClient) ListTables(pod *corev1.Pod, keyspaceName string) ([]string, error)
- type RequestError
- type TableDefinition
Constants ¶
const (
WgetNodeDrainEndpoint = "localhost:8080/api/v0/ops/node/drain"
)
Variables ¶
This section is empty.
Functions ¶
func AddManagementApiServerSecurity ¶
func AddManagementApiServerSecurity(dc *api.CassandraDatacenter, pod *corev1.PodTemplateSpec) error
func FakeExecutorServerWithDetails ¶ added in v1.10.0
func FakeExecutorServerWithDetails(callDetails *CallDetails) (*httptest.Server, error)
func FakeExecutorServerWithDetailsFails ¶ added in v1.10.0
func FakeExecutorServerWithDetailsFails(callDetails *CallDetails) (*httptest.Server, error)
func FakeMgmtApiServer ¶ added in v1.10.0
func FakeMgmtApiServer(callDetails *CallDetails, handlerFunc http.HandlerFunc) (*httptest.Server, error)
func FakeServerWithoutFeaturesEndpoint ¶ added in v1.10.0
func FakeServerWithoutFeaturesEndpoint(callDetails *CallDetails) (*httptest.Server, error)
func GetManagementApiProtocol ¶
func GetManagementApiProtocol(dc *api.CassandraDatacenter) (string, error)
API for Node Management mAuth Config
func GetMgmtApiWgetAction ¶
func GetMgmtApiWgetAction(dc *api.CassandraDatacenter, endpoint string) (*corev1.ExecAction, error)
func GetMgmtApiWgetPostAction ¶
func GetMgmtApiWgetPostAction(dc *api.CassandraDatacenter, endpoint string, postData string) (*corev1.ExecAction, error)
func GetPodHost ¶
Types ¶
type CallDetails ¶ added in v1.10.0
func NewCallDetails ¶ added in v1.10.0
func NewCallDetails() *CallDetails
type CassMetadataEndpoints ¶
type CassMetadataEndpoints struct {
Entity []EndpointState `json:"entity"`
}
type ClusteringOrder ¶ added in v1.9.0
type ClusteringOrder string
const ( ClusteringOrderAsc ClusteringOrder = "ASC" ClusteringOrderDesc ClusteringOrder = "DESC" )
type ColumnDefinition ¶ added in v1.9.0
type ColumnDefinition struct { Name string `json:"name"` Type string `json:"type"` Kind ColumnKind `json:"kind"` Position int `json:"position"` Order ClusteringOrder `json:"order,omitempty"` }
func NewClusteringColumn ¶ added in v1.9.0
func NewClusteringColumn(name string, dataType string, position int, order ClusteringOrder) *ColumnDefinition
func NewPartitionKeyColumn ¶ added in v1.9.0
func NewPartitionKeyColumn(name string, dataType string, position int) *ColumnDefinition
func NewRegularColumn ¶ added in v1.9.0
func NewRegularColumn(name string, dataType string) *ColumnDefinition
func NewStaticColumn ¶ added in v1.9.0
func NewStaticColumn(name string, dataType string) *ColumnDefinition
type ColumnKind ¶ added in v1.9.0
type ColumnKind string
const ( ColumnKindPartitionKey ColumnKind = "PARTITION_KEY" ColumnKindClusteringColumn ColumnKind = "CLUSTERING_COLUMN" ColumnKindRegular ColumnKind = "REGULAR" ColumnKindStatic ColumnKind = "STATIC" )
type EndpointState ¶
type EndpointState struct { Datacenter string `json:"DC,omitempty"` Rack string `json:"RACK,omitempty"` ReleaseVersion string `json:"RELEASE_VERSION,omitempty"` SchemaVersion string `json:"SCHEMA,omitempty"` SSTableVersion string `json:"SSTABLE_VERSIONS,omitempty"` HostID string `json:"HOST_ID,omitempty"` IsAlive string `json:"IS_ALIVE,omitempty"` EndpointIP string `json:"ENDPOINT_IP,omitempty"` NativeTransportAddress string `json:"NATIVE_TRANSPORT_ADDRESS,omitempty"` RpcAddress string `json:"RPC_ADDRESS,omitempty"` Status string `json:"STATUS,omitempty"` StatusWithPort string `json:"STATUS_WITH_PORT,omitempty"` Load string `json:"LOAD,omitempty"` }
func (*EndpointState) GetRpcAddress ¶
func (x *EndpointState) GetRpcAddress() string
func (*EndpointState) HasStatus ¶ added in v1.10.0
func (e *EndpointState) HasStatus(status EndpointStateStatus) bool
type EndpointStateStatus ¶ added in v1.10.0
type EndpointStateStatus string
const ( StatusNormal EndpointStateStatus = "NORMAL" StatusLeaving EndpointStateStatus = "LEAVING" StatusLeft EndpointStateStatus = "LEFT" StatusMoving EndpointStateStatus = "MOVING" StatusRemoved EndpointStateStatus = "removed" )
type FeatureSet ¶ added in v1.9.0
func (*FeatureSet) Supports ¶ added in v1.9.0
func (f *FeatureSet) Supports(feature Feature) bool
Supports returns true if the target pod's management-api supports certain feature
func (*FeatureSet) UnmarshalJSON ¶ added in v1.9.0
func (f *FeatureSet) UnmarshalJSON(b []byte) error
type HttpClient ¶
func BuildManagementApiHttpClient ¶
func BuildManagementApiHttpClient(dc *api.CassandraDatacenter, client client.Client, ctx context.Context) (HttpClient, error)
type InsecureManagementApiSecurityProvider ¶
type InsecureManagementApiSecurityProvider struct { }
func (*InsecureManagementApiSecurityProvider) AddServerSecurity ¶
func (provider *InsecureManagementApiSecurityProvider) AddServerSecurity(pod *corev1.PodTemplateSpec) error
func (*InsecureManagementApiSecurityProvider) BuildHttpClient ¶
func (provider *InsecureManagementApiSecurityProvider) BuildHttpClient(client client.Client, ctx context.Context) (HttpClient, error)
func (*InsecureManagementApiSecurityProvider) BuildMgmtApiWgetAction ¶
func (provider *InsecureManagementApiSecurityProvider) BuildMgmtApiWgetAction(endpoint string) *corev1.ExecAction
func (*InsecureManagementApiSecurityProvider) BuildMgmtApiWgetPostAction ¶
func (provider *InsecureManagementApiSecurityProvider) BuildMgmtApiWgetPostAction(endpoint string, postData string) *corev1.ExecAction
func (*InsecureManagementApiSecurityProvider) GetProtocol ¶
func (provider *InsecureManagementApiSecurityProvider) GetProtocol() string
func (*InsecureManagementApiSecurityProvider) ValidateConfig ¶
type JobDetails ¶ added in v1.9.0
type ManagementApiSecurityProvider ¶
type ManagementApiSecurityProvider interface { BuildHttpClient(client client.Client, ctx context.Context) (HttpClient, error) BuildMgmtApiWgetAction(endpoint string) *corev1.ExecAction BuildMgmtApiWgetPostAction(endpoint string, postData string) *corev1.ExecAction AddServerSecurity(pod *corev1.PodTemplateSpec) error GetProtocol() string ValidateConfig(client client.Client, ctx context.Context) []error }
SPI for adding new mechanisms for securing the management API
func BuildManagmenetApiSecurityProvider ¶
func BuildManagmenetApiSecurityProvider(dc *api.CassandraDatacenter) (ManagementApiSecurityProvider, error)
type ManualManagementApiSecurityProvider ¶
type ManualManagementApiSecurityProvider struct { Namespace string Config *api.ManagementApiAuthManualConfig }
func (*ManualManagementApiSecurityProvider) AddServerSecurity ¶
func (provider *ManualManagementApiSecurityProvider) AddServerSecurity(pod *corev1.PodTemplateSpec) error
func (*ManualManagementApiSecurityProvider) BuildHttpClient ¶
func (provider *ManualManagementApiSecurityProvider) BuildHttpClient(client client.Client, ctx context.Context) (HttpClient, error)
func (*ManualManagementApiSecurityProvider) BuildMgmtApiWgetAction ¶
func (provider *ManualManagementApiSecurityProvider) BuildMgmtApiWgetAction(endpoint string) *corev1.ExecAction
func (*ManualManagementApiSecurityProvider) BuildMgmtApiWgetPostAction ¶
func (provider *ManualManagementApiSecurityProvider) BuildMgmtApiWgetPostAction(endpoint string, postData string) *corev1.ExecAction
func (*ManualManagementApiSecurityProvider) GetProtocol ¶
func (provider *ManualManagementApiSecurityProvider) GetProtocol() string
func (*ManualManagementApiSecurityProvider) ValidateConfig ¶
type NoPodIPError ¶
type NoPodIPError error
type NodeMgmtClient ¶
type NodeMgmtClient struct { Client HttpClient Log logr.Logger Protocol string }
func NewMgmtClient ¶ added in v1.10.0
func NewMgmtClient(ctx context.Context, client client.Client, dc *cassdcapi.CassandraDatacenter) (NodeMgmtClient, error)
func (*NodeMgmtClient) AlterKeyspace ¶
func (client *NodeMgmtClient) AlterKeyspace(pod *corev1.Pod, keyspaceName string, replicationSettings []map[string]string) error
AlterKeyspace modifies the keyspace by calling management API
func (*NodeMgmtClient) CallCreateRoleEndpoint ¶
func (client *NodeMgmtClient) CallCreateRoleEndpoint(pod *corev1.Pod, username string, password string, superuser bool) error
Create a new superuser with the given username and password
func (*NodeMgmtClient) CallDatacenterRebuild ¶ added in v1.10.0
func (client *NodeMgmtClient) CallDatacenterRebuild(pod *corev1.Pod, sourceDatacenter string) (string, error)
CallDatacenterRebuild returns the job id of the rebuild job.
func (*NodeMgmtClient) CallDecommissionNode ¶ added in v1.10.0
CallDecommissionNode returns the job id of the decommission job.
func (*NodeMgmtClient) CallDecommissionNodeEndpoint ¶
func (client *NodeMgmtClient) CallDecommissionNodeEndpoint(pod *corev1.Pod) error
CallDecommissionNodeEndpoint is for the old /api/v0 decommission. Use the CallDecommissionNode for async behavior if available
func (*NodeMgmtClient) CallDrainEndpoint ¶
func (client *NodeMgmtClient) CallDrainEndpoint(pod *corev1.Pod) error
func (*NodeMgmtClient) CallIsFullQueryLogEnabledEndpoint ¶ added in v1.9.0
func (client *NodeMgmtClient) CallIsFullQueryLogEnabledEndpoint(pod *corev1.Pod) (bool, error)
func (*NodeMgmtClient) CallKeyspaceCleanup ¶ added in v1.9.0
func (client *NodeMgmtClient) CallKeyspaceCleanup(pod *corev1.Pod, jobs int, keyspaceName string, tables []string) (string, error)
CallKeyspaceCleanup returns the job id of the cleanup job
func (*NodeMgmtClient) CallKeyspaceCleanupEndpoint ¶
func (client *NodeMgmtClient) CallKeyspaceCleanupEndpoint(pod *corev1.Pod, jobs int, keyspaceName string, tables []string) error
CallKeyspaceCleanupEndpoint is deprecated. Use it only when accessing old management-api versions. Otherwise, use CallKeyspaceCleanup
func (*NodeMgmtClient) CallLifecycleStartEndpoint ¶
func (client *NodeMgmtClient) CallLifecycleStartEndpoint(pod *corev1.Pod) error
func (*NodeMgmtClient) CallLifecycleStartEndpointWithReplaceIp ¶
func (client *NodeMgmtClient) CallLifecycleStartEndpointWithReplaceIp(pod *corev1.Pod, replaceIp string) error
func (*NodeMgmtClient) CallMetadataEndpointsEndpoint ¶
func (client *NodeMgmtClient) CallMetadataEndpointsEndpoint(pod *corev1.Pod) (CassMetadataEndpoints, error)
func (*NodeMgmtClient) CallProbeClusterEndpoint ¶
func (*NodeMgmtClient) CallReloadSeedsEndpoint ¶
func (client *NodeMgmtClient) CallReloadSeedsEndpoint(pod *corev1.Pod) error
func (*NodeMgmtClient) CallSchemaVersionsEndpoint ¶ added in v1.10.0
func (client *NodeMgmtClient) CallSchemaVersionsEndpoint(pod *corev1.Pod) (map[string][]string, error)
CallSchemaVersionsEndpoint returns a map of all schema versions. Map keys are the schema UUIDs and the values are lists of nodes' IPs that are at that version. The JSON response looks like this:
{"2207c2a9-f598-3971-986b-2926e09e239d": ["10.244.1.4", "10.244.2.3, 10.244.3.3"]}
A map length of 1 indicates schema agreement.
func (*NodeMgmtClient) CallSetFullQueryLog ¶ added in v1.9.0
func (client *NodeMgmtClient) CallSetFullQueryLog(pod *corev1.Pod, enableFullQueryLogging bool) error
func (*NodeMgmtClient) CreateKeyspace ¶
func (client *NodeMgmtClient) CreateKeyspace(pod *corev1.Pod, keyspaceName string, replicationSettings []map[string]string) error
CreateKeyspace calls management API to create a new Keyspace.
func (*NodeMgmtClient) CreateTable ¶ added in v1.9.0
func (client *NodeMgmtClient) CreateTable(pod *corev1.Pod, table *TableDefinition) error
CreateTable calls the management API to create a new table.
func (*NodeMgmtClient) FeatureSet ¶ added in v1.9.0
func (client *NodeMgmtClient) FeatureSet(pod *corev1.Pod) (*FeatureSet, error)
FeatureSet returns supported features on the target pod. If the target pod is too old, empty FeatureSet is returned. One can check the supported feature by using FeatureSet.Supports(feature) and that will work regardless if this endpoint returns a result or 404 (other errors are passed as error)
func (*NodeMgmtClient) GetKeyspace ¶
GetKeyspace calls the management API to check if a specific keyspace exists
func (*NodeMgmtClient) GetKeyspaceReplication ¶ added in v1.9.0
func (client *NodeMgmtClient) GetKeyspaceReplication(pod *corev1.Pod, keyspaceName string) (map[string]string, error)
GetKeyspaceReplication calls the management API to retrieve the replication settings of the given keyspace.
func (*NodeMgmtClient) JobDetails ¶ added in v1.9.0
func (client *NodeMgmtClient) JobDetails(pod *corev1.Pod, jobId string) (*JobDetails, error)
func (*NodeMgmtClient) ListKeyspaces ¶
func (client *NodeMgmtClient) ListKeyspaces(pod *corev1.Pod) ([]string, error)
ListKeyspaces calls the management API to list existing keyspaces
func (*NodeMgmtClient) ListTables ¶ added in v1.9.0
ListTables calls the management API and returns the table names in the given keyspace
type RequestError ¶ added in v1.9.0
func (*RequestError) Error ¶ added in v1.9.0
func (r *RequestError) Error() string
func (*RequestError) NotFound ¶ added in v1.9.0
func (r *RequestError) NotFound() bool
type TableDefinition ¶ added in v1.9.0
type TableDefinition struct { KeyspaceName string `json:"keyspace_name"` TableName string `json:"table_name"` Columns []*ColumnDefinition `json:"columns"` Options map[string]interface{} `json:"options,omitempty"` }
func NewTableDefinition ¶ added in v1.9.0
func NewTableDefinition(keyspaceName string, tableName string, columns ...*ColumnDefinition) *TableDefinition