Files
ubicloud/model/cert.rb
Furkan Sahin 803906916c CertNexus restart counter is added to not DOS ZeroSSL
In case the passed DNSZone is not valid globally, DNS validation or cert
generation may fail. In that case, CertNexus restarts to do a new acme
dance. It goes on forever. Instead of this, we are introducing a restart
logic. In case of restarts, we start napping aggressively up until 10
minutes.
2025-02-11 17:49:22 +01:00

43 lines
1.3 KiB
Ruby

# frozen_string_literal: true
require_relative "../model"
class Cert < Sequel::Model
one_through_one :load_balancer, join_table: :certs_load_balancers, left_key: :cert_id, right_key: :load_balancer_id
one_to_one :certs_load_balancers, key: :cert_id, class: :CertsLoadBalancers
one_to_one :strand, key: :id
plugin :association_dependencies, certs_load_balancers: :destroy
include ResourceMethods
include SemaphoreMethods
semaphore :destroy, :restarted
plugin :column_encryption do |enc|
enc.column :account_key
enc.column :csr_key
end
def self.redacted_columns
super + [:cert]
end
end
# Table: cert
# Columns:
# id | uuid | PRIMARY KEY
# hostname | text | NOT NULL
# dns_zone_id | uuid |
# created_at | timestamp without time zone | NOT NULL DEFAULT now()
# cert | text |
# account_key | text |
# kid | text |
# order_url | text |
# csr_key | text |
# Indexes:
# cert_pkey | PRIMARY KEY btree (id)
# Foreign key constraints:
# cert_dns_zone_id_fkey | (dns_zone_id) REFERENCES dns_zone(id)
# Referenced By:
# certs_load_balancers | certs_load_balancers_cert_id_fkey | (cert_id) REFERENCES cert(id)