29 lines
		
	
	
		
			750 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
		
			750 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # Copyright (C) 2024-2025 LibreWeddingPlanner contributors
 | |
| 
 | |
| # frozen_string_literal: true
 | |
| 
 | |
| # == Schema Information
 | |
| #
 | |
| # Table name: weddings
 | |
| #
 | |
| #  id         :uuid             not null, primary key
 | |
| #  slug       :string           not null
 | |
| #  created_at :datetime         not null
 | |
| #  updated_at :datetime         not null
 | |
| #
 | |
| # Indexes
 | |
| #
 | |
| #  index_weddings_on_slug  (slug) UNIQUE
 | |
| #
 | |
| class Wedding < ApplicationRecord
 | |
|   SLUG_REGEX = /[a-z\d-]+/
 | |
| 
 | |
|   validates :slug, presence: true, uniqueness: true, format: { with: /\A#{SLUG_REGEX}\z/ }
 | |
| 
 | |
|   has_many :guests, dependent: :delete_all
 | |
|   has_many :groups, dependent: :delete_all
 | |
|   has_many :invitations, dependent: :delete_all
 | |
|   has_many :users, dependent: :delete_all
 | |
|   has_one :website, dependent: :destroy
 | |
| end
 |