mirror of
https://github.com/supabase/supabase.git
synced 2026-05-09 10:19:50 -04:00
4a0bb36ca8
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Ivan Vasilov <vasilov.ivan@gmail.com>
116 lines
3.8 KiB
TypeScript
116 lines
3.8 KiB
TypeScript
import { ReadReplicaSetupError, ReadReplicaSetupProgress } from '@supabase/shared-types/out/events'
|
|
import type { AWS_REGIONS_KEYS } from 'shared-data'
|
|
import { AWS_REGIONS } from 'shared-data'
|
|
|
|
import { components } from '@/data/api'
|
|
import { PROJECT_STATUS } from '@/lib/constants'
|
|
|
|
export interface Region {
|
|
key: AWS_REGIONS_KEYS
|
|
name: string
|
|
region: string
|
|
coordinates: [number, number]
|
|
}
|
|
|
|
export type NodeData = {
|
|
id: string
|
|
provider: string
|
|
region: Region
|
|
computeSize?: string
|
|
status: string
|
|
inserted_at: string
|
|
}
|
|
|
|
export type PrimaryNodeData = NodeData & {
|
|
numReplicas: number
|
|
numRegions: number
|
|
hasLoadBalancer: boolean
|
|
}
|
|
|
|
export type LoadBalancerData = NodeData & {
|
|
numDatabases: number
|
|
}
|
|
|
|
export type ReplicaNodeData = NodeData & {
|
|
onSelectRestartReplica: () => void
|
|
onSelectResizeReplica: () => void
|
|
onSelectDropReplica: () => void
|
|
}
|
|
|
|
export type EdgeData = {
|
|
status: string
|
|
identifier: string
|
|
connectionString: string | null | undefined
|
|
}
|
|
|
|
// ReactFlow is scaling everything by the factor of 2
|
|
export const NODE_WIDTH = 660
|
|
export const NODE_ROW_HEIGHT = 50
|
|
export const NODE_SEP = 20
|
|
|
|
export const REPLICA_STATUS: {
|
|
[key: string]: components['schemas']['DatabaseStatusResponse']['status']
|
|
} = {
|
|
...PROJECT_STATUS,
|
|
INIT_READ_REPLICA: 'INIT_READ_REPLICA',
|
|
INIT_READ_REPLICA_FAILED: 'INIT_READ_REPLICA_FAILED',
|
|
}
|
|
|
|
// [Joshen] Coordinates from https://github.com/tobilg/aws-edge-locations/blob/main/data/aws-edge-locations.json
|
|
// In the format of [lon, lat]
|
|
export const AWS_REGIONS_COORDINATES: { [key: string]: [number, number] } = {
|
|
SOUTHEAST_ASIA: [103.8, 1.37],
|
|
NORTHEAST_ASIA: [139.42, 35.41],
|
|
NORTHEAST_ASIA_2: [126.98, 37.56],
|
|
CENTRAL_CANADA: [-73.6, 45.5],
|
|
WEST_US: [-121.96, 37.35],
|
|
WEST_US_2: [-122.67, 45.51],
|
|
EAST_US: [-78.45, 38.13],
|
|
WEST_EU: [-8, 53],
|
|
WEST_EU_2: [-0.1, 51],
|
|
CENTRAL_EU: [8, 50],
|
|
SOUTH_ASIA: [72.88, 19.08],
|
|
OCEANIA: [151.2, -33.86],
|
|
SOUTH_AMERICA: [-46.38, -23.34],
|
|
CENTRAL_EU_2: [8.54, 47.45],
|
|
EAST_US_2: [-83, 39.96],
|
|
NORTH_EU: [17.91, 59.65],
|
|
WEST_EU_3: [2.35, 48.86],
|
|
}
|
|
|
|
export const FLY_REGIONS_COORDINATES: { [key: string]: [number, number] } = {
|
|
SOUTHEAST_ASIA: [103.8, 1.37],
|
|
}
|
|
|
|
// [Joshen] Just to make sure that we just depend on AWS_REGIONS to determine available
|
|
// regions for replicas. Just FYI - might need to update this if we support Fly in future
|
|
export const AVAILABLE_REPLICA_REGIONS: Region[] = Object.keys(AWS_REGIONS)
|
|
.map((key) => {
|
|
return {
|
|
key: key as AWS_REGIONS_KEYS,
|
|
name: AWS_REGIONS?.[key as AWS_REGIONS_KEYS].displayName,
|
|
region: AWS_REGIONS?.[key as AWS_REGIONS_KEYS].code,
|
|
coordinates: AWS_REGIONS_COORDINATES[key],
|
|
}
|
|
})
|
|
.filter((x) => x.coordinates !== undefined)
|
|
|
|
// [Joshen] Just a more user friendly language, so that all the verbs are progressive
|
|
export const INIT_PROGRESS = {
|
|
[ReadReplicaSetupProgress.Requested]: 'Requesting replica instance',
|
|
[ReadReplicaSetupProgress.Started]: 'Launching replica instance',
|
|
[ReadReplicaSetupProgress.LaunchedReadReplicaInstance]: 'Initiating replica setup',
|
|
[ReadReplicaSetupProgress.InitiatedReadReplicaSetup]: 'Downloading base backup',
|
|
[ReadReplicaSetupProgress.DownloadedBaseBackup]: 'Replaying WAL archives',
|
|
[ReadReplicaSetupProgress.ReplayedWalArchives]: 'Completing set up',
|
|
[ReadReplicaSetupProgress.CompletedReadReplicaSetup]: 'Completed',
|
|
}
|
|
|
|
export const ERROR_STATES = {
|
|
[ReadReplicaSetupError.ReadReplicaInstanceLaunchFailed]: 'Failed to launch replica',
|
|
[ReadReplicaSetupError.InitiateReadReplicaSetupFailed]: 'Failed to initiate replica',
|
|
[ReadReplicaSetupError.DownloadBaseBackupFailed]: 'Failed to download backup',
|
|
[ReadReplicaSetupError.ReplayWalArchivesFailed]: 'Failed to replay WAL archives',
|
|
[ReadReplicaSetupError.CompleteReadReplicaSetupFailed]: 'Failed to set up replica',
|
|
}
|