Class: Arkaan::Campaign

Inherits:
Object
  • Object
show all
Includes:
Mongoid::Document, Mongoid::Timestamps
Defined in:
lib/arkaan/campaign.rb

Overview

A campaign is a gathering of accounts playing on the same interface, and interacting in a common game.

Author:

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#descriptionString

Returns a more detailed description, used to give further information about the campaign in general.

Returns:

  • (String)

    a more detailed description, used to give further information about the campaign in general.



13
# File 'lib/arkaan/campaign.rb', line 13

field :description, type: String

#filesArray<Arkaan::Campaigns::Files::Document>

Returns the list of files that were uploaded in this campaign.

Returns:



29
# File 'lib/arkaan/campaign.rb', line 29

has_many :files, class_name: 'Arkaan::Campaigns::Files::Document', inverse_of: :campaign

#invitationsArray<Arkaan::Campaigns::Invitation>

Returns the invitations to players that have been made for this campaign.

Returns:



26
# File 'lib/arkaan/campaign.rb', line 26

has_many :invitations, class_name: 'Arkaan::Campaigns::Invitation', inverse_of: :campaign

#is_privateBoolean

Returns TRUE if the campaign can be joined only by being invited by the creator, FALSE if it’s publicly displayed and accessible.

Returns:

  • (Boolean)

    TRUE if the campaign can be joined only by being invited by the creator, FALSE if it’s publicly displayed and accessible.



16
# File 'lib/arkaan/campaign.rb', line 16

field :is_private, type: Boolean, default: true

#messagesArray<Arkaan::Campaigns::Messages::Base>

Returns the messages sent in the chatroom of the campaign.

Returns:

  • (Array<Arkaan::Campaigns::Messages::Base>)

    the messages sent in the chatroom of the campaign.



33
# File 'lib/arkaan/campaign.rb', line 33

embeds_many :messages, class_name: 'Arkaan::Campaigns::Message', inverse_of: :campaign

#rulesetArkaan::Ruleset

Returns the set of rules this campaign is based upon.

Returns:



37
# File 'lib/arkaan/campaign.rb', line 37

belongs_to :ruleset, class_name: 'Arkaan::Ruleset', inverse_of: :campaigns, optional: true

#tagsArray<String>

Returns an array of tags describing characteristics of this campaign.

Returns:

  • (Array<String>)

    an array of tags describing characteristics of this campaign.



19
# File 'lib/arkaan/campaign.rb', line 19

field :tags, type: Array, default: []

#titleString

Returns the title, or name, of the campaign, used to identify it in the list.

Returns:

  • (String)

    the title, or name, of the campaign, used to identify it in the list.



10
# File 'lib/arkaan/campaign.rb', line 10

field :title, type: String

Instance Method Details

#charactersArray<Arkaan::Campaigns::Character>

Returns a flattened list of characters for this campaign.

Returns:



95
96
97
# File 'lib/arkaan/campaign.rb', line 95

def characters
  players.map(&:characters).flatten
end

#creatorArkaan::Account

Getter for the creator account of this campaign.

Returns:



60
61
62
# File 'lib/arkaan/campaign.rb', line 60

def creator
  return invitations.where(enum_status: :creator).first.
end

#creator=(account) ⇒ Object

Sets the creator of the campaign. This method is mainly used for backward-compatibility needs.

Parameters:

  • account (Arkaan::Account)

    the account of the creator for this campaign.



52
53
54
55
56
# File 'lib/arkaan/campaign.rb', line 52

def creator=()
  if !invitations.where(account: ).exists?
    Arkaan::Campaigns::Invitation.create(campaign: self, account: , enum_status: :creator)
  end
end

#documentsArray<Arkaan::Campaigns::Files::Document>

Returns the document of this campaign as a flattened array.

Returns:



100
101
102
# File 'lib/arkaan/campaign.rb', line 100

def documents
  invitations.map(&:documents).flatten
end

#max_players_minimumObject

Validation for the max number of players for a campaign. If there is a max number of players, and the current number of players is above it, or the max number of players is 0, raises an error.



78
79
80
81
82
# File 'lib/arkaan/campaign.rb', line 78

def max_players_minimum
  if max_players? && (max_players < players_count || max_players < 1)
    errors.add(:max_players, 'minimum')
  end
end

#playersArray<Arkaan::Campaigns::Invitation>

Returns the players in this campaign.

Returns:



85
86
87
# File 'lib/arkaan/campaign.rb', line 85

def players
  invitations.where(enum_status: :accepted)
end

#players_countInteger

Returns the number of players in this campaign.

Returns:

  • (Integer)

    the number of players in this campaign.



90
91
92
# File 'lib/arkaan/campaign.rb', line 90

def players_count
  players.count
end

#title_unicityObject

Adds an error message if the account creating this campaign already has a campaign with the very same name.



65
66
67
68
69
70
71
72
73
# File 'lib/arkaan/campaign.rb', line 65

def title_unicity
  # First we take all the other campaign ids of the user.
  campaign_ids = creator.invitations.where(:campaign_id.ne => _id).pluck(:campaign_id)
  # With this list of campaign IDs, we look for a campaign with the same title.
  same_title_campaign = Arkaan::Campaign.where(:_id.in => campaign_ids, title: title)
  if !creator.nil? && title? && same_title_campaign.exists?
    errors.add(:title, 'uniq')
  end
end