summaryrefslogtreecommitdiff
path: root/app/models/tenant_membership.rb
diff options
context:
space:
mode:
authorStefan Wintermeyer <stefan.wintermeyer@amooma.de>2012-12-17 12:05:14 +0100
committerStefan Wintermeyer <stefan.wintermeyer@amooma.de>2012-12-17 12:05:14 +0100
commiteaad37485fe59d0306c37cc038dda6d210052910 (patch)
tree072c4b0e33d442528555b82c415f5e7a1712b2b0 /app/models/tenant_membership.rb
parent3e706c2025ecc5523e81ad649639ef2ff75e7bac (diff)
parentb80bd744ad873f6fc43018bc4bfb90677de167bd (diff)
Merge branch 'develop'
Diffstat (limited to 'app/models/tenant_membership.rb')
-rw-r--r--app/models/tenant_membership.rb25
1 files changed, 25 insertions, 0 deletions
diff --git a/app/models/tenant_membership.rb b/app/models/tenant_membership.rb
new file mode 100644
index 0000000..122f702
--- /dev/null
+++ b/app/models/tenant_membership.rb
@@ -0,0 +1,25 @@
+class TenantMembership < ActiveRecord::Base
+ belongs_to :tenant
+ belongs_to :user
+
+ validates_presence_of :tenant
+ validates_presence_of :user
+
+ after_create :set_current_tenant_if_necessary
+
+ # State Machine stuff
+ default_scope where(:state => 'active')
+ state_machine :initial => :active do
+ end
+
+ private
+ # The first TenantMembership becomes the current_tenant by default.
+ #
+ def set_current_tenant_if_necessary
+ if !self.user.current_tenant
+ self.user.current_tenant = self.tenant
+ self.user.save
+ end
+ end
+
+end