Sha256: 8f9a7ddc55b20c24229deea478872d8c0ff96740311c84f383a67ba82ab74f4c
Contents?: true
Size: 1.84 KB
Versions: 2
Compression:
Stored size: 1.84 KB
Contents
module Cadenero::V1 # Defines a subdomain with a default admin (owner) as a tenant in the Rails App class Account < ActiveRecord::Base include Cadenero::AuthToken belongs_to :owner, :class_name => "Cadenero::User" has_many :members, :class_name => "Cadenero::Member" has_many :users, :through => :members, :class_name => "Cadenero::User" accepts_nested_attributes_for :owner attr_accessible :name, :subdomain, :owner_attributes, :owner validates :subdomain, :presence => true, :uniqueness => true validates :owner, :presence => true after_create :ensure_auth_token! # Creates an account and assign the provided [Cadenero::User] as owner to the account # @param [Hash] params list # @example # Example for the params JSON: {name: "Testy", subdomain: "test", # owner_attributes: {email: "testy@example.com", password: "changeme", # password_confirmation: "changeme"} } # @return [Cadenero::V1::Account] created # @note because this model uses accepts_nested_attributes_for :owner the JSOB should have owner_attributes def self.create_with_owner(params={}) account = new(params) if account.save account.users << account.owner account.create_schema account.ensure_auth_token! end account end # Gets the account for the specified subdomain and guards errors # @param [String] subdomain # @example # get_by_subdomain("www") # @return [Cadenero::V1::Account] for that subdomain def self.get_by_subdomain(subdomain) account = find_by_subdomain(subdomain) if account account else raise Apartment::SchemaNotFound, "Subdomain is not valid" end end # Create a database schema using the subdomain def create_schema Apartment::Database.create(subdomain) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
cadenero-0.0.2.b8 | app/models/cadenero/v1/account.rb |
cadenero-0.0.2.b7 | app/models/cadenero/v1/account.rb |