mirror of
https://github.com/SigNoz/signoz.git
synced 2026-03-16 18:02:09 +00:00
83 lines
3.6 KiB
Go
83 lines
3.6 KiB
Go
package cloudintegration
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
|
|
"github.com/SigNoz/signoz/pkg/types/cloudintegrationtypes"
|
|
"github.com/SigNoz/signoz/pkg/types/dashboardtypes"
|
|
"github.com/SigNoz/signoz/pkg/valuer"
|
|
)
|
|
|
|
type Module interface {
|
|
// CreateConnectionArtifact generates cloud provider specific connection information,
|
|
// client side handles how this information is shown
|
|
CreateConnectionArtifact(
|
|
ctx context.Context,
|
|
orgID valuer.UUID,
|
|
provider cloudintegrationtypes.CloudProviderType,
|
|
request *cloudintegrationtypes.ConnectionArtifactRequest,
|
|
) (*cloudintegrationtypes.ConnectionArtifact, error)
|
|
|
|
// GetAccountStatus returns agent connection status for a cloud integration account
|
|
GetAccountStatus(ctx context.Context, orgID, accountID valuer.UUID) (*cloudintegrationtypes.AccountStatus, error)
|
|
|
|
// ListConnectedAccounts lists accounts where agent is connected
|
|
ListConnectedAccounts(ctx context.Context, orgID valuer.UUID) (*cloudintegrationtypes.ConnectedAccounts, error)
|
|
|
|
// DisconnectAccount soft deletes/removes a cloud integration account.
|
|
DisconnectAccount(ctx context.Context, orgID, accountID valuer.UUID) error
|
|
|
|
// UpdateAccountConfig updates the configuration of an existing cloud account for a specific organization.
|
|
UpdateAccountConfig(
|
|
ctx context.Context,
|
|
orgID,
|
|
accountID valuer.UUID,
|
|
config *cloudintegrationtypes.UpdateAccountConfigRequest,
|
|
) (*cloudintegrationtypes.Account, error)
|
|
|
|
// ListServicesMetadata returns list of services metadata for a cloud provider attached with the integrationID.
|
|
// This just returns a summary of the service and not the whole service definition
|
|
ListServicesMetadata(ctx context.Context, orgID valuer.UUID, integrationID *valuer.UUID) (*cloudintegrationtypes.ServicesMetadata, error)
|
|
|
|
// GetService returns service definition details for a serviceID. This returns config and
|
|
// other details required to show in service details page on web client.
|
|
GetService(ctx context.Context, orgID valuer.UUID, integrationID *valuer.UUID, serviceID string) (*cloudintegrationtypes.Service, error)
|
|
|
|
// UpdateServiceConfig updates cloud integration service config
|
|
UpdateServiceConfig(
|
|
ctx context.Context,
|
|
orgID valuer.UUID,
|
|
serviceID string,
|
|
config *cloudintegrationtypes.UpdateServiceConfigRequest,
|
|
) (*cloudintegrationtypes.UpdateServiceConfigResponse, error)
|
|
|
|
// AgentCheckIn is called by agent to heartbeat and get latest config in response.
|
|
AgentCheckIn(
|
|
ctx context.Context,
|
|
orgID valuer.UUID,
|
|
req *cloudintegrationtypes.AgentCheckInRequest,
|
|
) (*cloudintegrationtypes.AgentCheckInResponse, error)
|
|
|
|
// GetDashboardByID returns dashboard JSON for a given dashboard id.
|
|
// this only returns the dashboard when the service (embedded in dashboard id) is enabled
|
|
// in the org for any cloud integration account
|
|
GetDashboardByID(ctx context.Context, orgID valuer.UUID, id string) (*dashboardtypes.Dashboard, error)
|
|
|
|
// GetAllDashboards returns list of dashboards across all connected cloud integration accounts
|
|
// for enabled services in the org. This list gets added to dashboard list page
|
|
GetAllDashboards(ctx context.Context, orgID valuer.UUID) ([]*dashboardtypes.Dashboard, error)
|
|
}
|
|
|
|
type Handler interface {
|
|
AgentCheckIn(http.ResponseWriter, *http.Request)
|
|
GenerateConnectionArtifact(http.ResponseWriter, *http.Request)
|
|
ListConnectedAccounts(http.ResponseWriter, *http.Request)
|
|
GetAccountStatus(http.ResponseWriter, *http.Request)
|
|
ListServices(http.ResponseWriter, *http.Request)
|
|
GetServiceDetails(http.ResponseWriter, *http.Request)
|
|
UpdateAccountConfig(http.ResponseWriter, *http.Request)
|
|
UpdateServiceConfig(http.ResponseWriter, *http.Request)
|
|
DisconnectAccount(http.ResponseWriter, *http.Request)
|
|
}
|