174 lines
6.8 KiB
Ruby
174 lines
6.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "yaml"
|
|
|
|
module Option
|
|
ai_models = YAML.load_file("config/ai_models.yml")
|
|
AI_MODELS = ai_models.select { it["enabled"] }.freeze
|
|
|
|
def self.locations(only_visible: true, feature_flags: [])
|
|
Location.where(project_id: nil).all.select { |pl| !only_visible || (pl.visible || feature_flags.include?("location_#{pl.name.tr("-", "_")}")) }
|
|
end
|
|
|
|
def self.kubernetes_locations
|
|
Location.where(name: ["hetzner-fsn1", "leaseweb-wdc02"]).all
|
|
end
|
|
|
|
def self.kubernetes_versions
|
|
["v1.33", "v1.32"].freeze
|
|
end
|
|
|
|
def self.families
|
|
Option::VmFamilies.select { it.visible }
|
|
end
|
|
|
|
def self.aws_instance_type_name(family, vcpu_count)
|
|
suffix = if vcpu_count == 2
|
|
"large"
|
|
elsif vcpu_count == 4
|
|
"xlarge"
|
|
else
|
|
"#{vcpu_count / 4}xlarge"
|
|
end
|
|
|
|
"#{family}.#{suffix}"
|
|
end
|
|
|
|
AWS_FAMILY_OPTIONS = ["c6gd", "m6id", "m6gd", "m7a", "m8gd"].freeze
|
|
AWS_STORAGE_SIZE_OPTIONS = {2 => ["118"], 4 => ["237"], 8 => ["474"], 16 => ["950"], 32 => ["1900"], 64 => ["3800"]}.freeze
|
|
|
|
BootImage = Struct.new(:name, :display_name)
|
|
BootImages = [
|
|
["ubuntu-noble", "Ubuntu Noble 24.04 LTS"],
|
|
["ubuntu-jammy", "Ubuntu Jammy 22.04 LTS"],
|
|
["debian-12", "Debian 12"],
|
|
["almalinux-9", "AlmaLinux 9"]
|
|
].map { |args| BootImage.new(*args) }.freeze
|
|
|
|
VmFamily = Data.define(:name, :ui_descriptor, :visible, :require_shared_slice) do
|
|
def display_name
|
|
name.capitalize
|
|
end
|
|
end
|
|
|
|
VmFamilies = [
|
|
["standard", "Dedicated CPU", true, false],
|
|
["standard-gpu", "Dedicated GPU", false, false],
|
|
["premium", "Dedicated Premium CPU", false, false],
|
|
["burstable", "Shared CPU", true, true]
|
|
].map { |args| VmFamily.new(*args) }
|
|
|
|
IoLimits = Data.define(:max_read_mbytes_per_sec, :max_write_mbytes_per_sec)
|
|
NO_IO_LIMITS = IoLimits.new(nil, nil)
|
|
|
|
VmSize = Struct.new(:name, :family, :vcpus, :cpu_percent_limit, :cpu_burst_percent_limit, :memory_gib, :storage_size_options, :io_limits, :visible, :arch) do
|
|
alias_method :display_name, :name
|
|
end
|
|
VmSizes = [2, 4, 8, 16, 30, 60].map {
|
|
storage_size_options = [it * 20, it * 40]
|
|
VmSize.new("standard-#{it}", "standard", it, it * 100, 0, it * 4, storage_size_options, NO_IO_LIMITS, true, "x64")
|
|
}.concat([2, 4, 8, 16, 30, 60].map {
|
|
storage_size_options = [it * 20, it * 40]
|
|
VmSize.new("standard-#{it}", "standard", it, it * 100, 0, (it * 3.2).to_i, storage_size_options, NO_IO_LIMITS, false, "arm64")
|
|
}).concat([6].map {
|
|
VmSize.new("standard-gpu-#{it}", "standard-gpu", it, it * 100, 0, (it * 5.34).to_i, [it * 30], NO_IO_LIMITS, false, "x64")
|
|
}).concat([2, 4, 8, 16, 30].map {
|
|
storage_size_options = [it * 20, it * 40]
|
|
VmSize.new("premium-#{it}", "premium", it, it * 100, 0, it * 4, storage_size_options, NO_IO_LIMITS, false, "x64")
|
|
}).concat([1, 2].map {
|
|
storage_size_options = [it * 10, it * 20]
|
|
io_limits = IoLimits.new(it * 50, it * 50)
|
|
VmSize.new("burstable-#{it}", "burstable", it, it * 50, it * 50, it * 2, storage_size_options, io_limits, true, "x64")
|
|
}).concat([1, 2].map {
|
|
storage_size_options = [it * 10, it * 20]
|
|
io_limits = IoLimits.new(it * 50, it * 50)
|
|
VmSize.new("burstable-#{it}", "burstable", it, it * 50, it * 50, (it * 1.6).to_i, storage_size_options, io_limits, false, "arm64")
|
|
}).concat(AWS_FAMILY_OPTIONS.product([2, 4, 8, 16, 32, 64]).map { |family, vcpu|
|
|
memory_coefficient = (family == "c6gd") ? 2 : 4
|
|
|
|
arch = ["m6id", "m7a"].include?(family) ? "x64" : "arm64"
|
|
VmSize.new(aws_instance_type_name(family, vcpu), family, vcpu, vcpu * 100, 0, vcpu * memory_coefficient, AWS_STORAGE_SIZE_OPTIONS[vcpu], NO_IO_LIMITS, false, arch)
|
|
}).freeze
|
|
|
|
# Postgres Global Options
|
|
PostgresFlavorOption = Data.define(:name, :brand, :title, :description)
|
|
POSTGRES_FLAVOR_OPTIONS = [
|
|
[PostgresResource::Flavor::STANDARD, "ubicloud", "PostgreSQL Database", "Get started by creating a new PostgreSQL database which is managed by Ubicloud team. It's a good choice for general purpose databases."],
|
|
[PostgresResource::Flavor::PARADEDB, "paradedb", "ParadeDB PostgreSQL Database", "ParadeDB is an Elasticsearch alternative built on Postgres. ParadeDB instances are managed by the ParadeDB team and are optimal for search and analytics workloads."],
|
|
[PostgresResource::Flavor::LANTERN, "lantern", "Lantern PostgreSQL Database", "Lantern is a PostgreSQL-based vector database designed specifically for building AI applications. Lantern instances are managed by the Lantern team and are optimal for AI workloads."]
|
|
].map { |args| [args[0], PostgresFlavorOption.new(*args)] }.to_h.freeze
|
|
|
|
PostgresFamilyOption = Data.define(:name, :description)
|
|
POSTGRES_FAMILY_OPTIONS = [
|
|
["standard", "Dedicated CPU"],
|
|
["burstable", "Shared CPU"],
|
|
["c6gd", "Compute Optimized, Graviton2"],
|
|
["m6id", "General Purpose, Intel Xeon"],
|
|
["m6gd", "General Purpose, Graviton2"],
|
|
["m8gd", "General Purpose, Graviton3"]
|
|
].map { |args| [args[0], PostgresFamilyOption.new(*args)] }.to_h.freeze
|
|
|
|
PostgresSizeOption = Data.define(:name, :family, :vcpu_count, :memory_gib)
|
|
POSTGRES_SIZE_OPTIONS = [
|
|
["standard", 2, 8],
|
|
["standard", 4, 16],
|
|
["standard", 8, 32],
|
|
["standard", 16, 64],
|
|
["standard", 30, 120],
|
|
["standard", 60, 240],
|
|
["burstable", 1, 2],
|
|
["burstable", 2, 4],
|
|
["c6gd", 2, 4],
|
|
["c6gd", 4, 8],
|
|
["c6gd", 8, 16],
|
|
["c6gd", 16, 32],
|
|
["c6gd", 32, 64],
|
|
["c6gd", 64, 128],
|
|
["m6id", 2, 8],
|
|
["m6id", 4, 16],
|
|
["m6id", 8, 32],
|
|
["m6id", 16, 64],
|
|
["m6id", 32, 128],
|
|
["m6id", 64, 256],
|
|
["m6gd", 2, 8],
|
|
["m6gd", 4, 16],
|
|
["m6gd", 8, 32],
|
|
["m6gd", 16, 64],
|
|
["m6gd", 32, 128],
|
|
["m6gd", 64, 256],
|
|
["m8gd", 2, 8],
|
|
["m8gd", 4, 16],
|
|
["m8gd", 8, 32],
|
|
["m8gd", 16, 64],
|
|
["m8gd", 32, 128],
|
|
["m8gd", 64, 256]
|
|
].map do |args|
|
|
name = if AWS_FAMILY_OPTIONS.include?(args[0])
|
|
aws_instance_type_name(args[0], args[1])
|
|
else
|
|
"#{args[0]}-#{args[1]}"
|
|
end
|
|
|
|
[name, PostgresSizeOption.new(name, *args)]
|
|
end.to_h.freeze
|
|
|
|
POSTGRES_STORAGE_SIZE_OPTIONS = ["16", "32", "64", "128", "256", "512", "1024", "2048", "4096"].freeze
|
|
|
|
POSTGRES_VERSION_OPTIONS = ["17", "16"].freeze
|
|
|
|
PostgresHaOption = Data.define(:name, :standby_count, :description)
|
|
POSTGRES_HA_OPTIONS = [
|
|
[PostgresResource::HaType::NONE, 0, "No Standbys"],
|
|
[PostgresResource::HaType::ASYNC, 1, "1 Standby"],
|
|
[PostgresResource::HaType::SYNC, 2, "2 Standbys"]
|
|
].map { |args| [args[0], PostgresHaOption.new(*args)] }.to_h.freeze
|
|
|
|
AWS_LOCATIONS = ["us-west-2", "us-east-1", "us-east-2", "ap-southeast-2", "eu-west-1"].freeze
|
|
|
|
KubernetesCPOption = Struct.new(:cp_node_count, :title, :explanation)
|
|
KubernetesCPOptions = [[1, "1 Node", "Single control plane node without resilience"],
|
|
[3, "3 Nodes", "Three control plane nodes with resilience"]].map {
|
|
KubernetesCPOption.new(*it)
|
|
}.freeze
|
|
end
|