/** * Set up a member * * @return @e void */ protected static function setUpMember() { //----------------------------------------- // INIT //----------------------------------------- $cache = ipsRegistry::cache()->getCache('group_cache'); //----------------------------------------- // Unpack cache //----------------------------------------- if (isset(self::$data_store['members_cache'])) { self::$data_store['_cache'] = IPSMember::unpackMemberCache(self::$data_store['members_cache']); } else { self::$data_store['_cache'] = array(); } if (!isset(self::$data_store['_cache']['friends']) or !is_array(self::$data_store['_cache']['friends'])) { self::$data_store['_cache']['friends'] = array(); } //----------------------------------------- // Unpack ignored users //----------------------------------------- if (isset(self::$data_store['ignored_users'])) { self::$data_store['_ignoredUsers'] = @unserialize(self::$data_store['ignored_users']); } else { self::$data_store['_ignoredUsers'] = array(); } //----------------------------------------- // Set up main 'display' group //----------------------------------------- if (is_array($cache[self::$data_store['member_group_id']])) { self::$data_store = array_merge(self::$data_store, $cache[self::$data_store['member_group_id']]); } //----------------------------------------- // Work out permissions //----------------------------------------- self::$data_store = self::instance()->setUpSecondaryGroups(self::$data_store); /* Ensure we don't have a ,, string */ self::$data_store['org_perm_id'] = IPSText::cleanPermString(self::$data_store['org_perm_id']); self::instance()->perm_id = !empty(self::$data_store['org_perm_id']) ? self::$data_store['org_perm_id'] : self::$data_store['g_perm_id']; self::instance()->perm_id_array = explode(",", self::instance()->perm_id); //----------------------------------------- // Synchronise the last visit and activity times if // we have some in the member profile //----------------------------------------- if (!self::$data_store['last_activity']) { self::$data_store['last_activity'] = IPS_UNIX_TIME_NOW; } //----------------------------------------- // If there hasn't been a cookie update in 2 hours, // we assume that they've gone and come back //----------------------------------------- if (!self::$data_store['last_visit']) { //----------------------------------------- // No last visit set, do so now! //----------------------------------------- ipsRegistry::DB()->update('members', array('last_visit' => self::$data_store['last_activity'], 'last_activity' => IPS_UNIX_TIME_NOW), "member_id=" . self::$data_store['member_id'], true); self::$data_store['last_visit'] = self::$data_store['last_activity']; } else { if (IPS_UNIX_TIME_NOW - self::$data_store['last_activity'] > 300) { //----------------------------------------- // If the last click was longer than 5 mins ago and this is a member // Update their profile. //----------------------------------------- $be_anon = IPSMember::isLoggedInAnon(self::$data_store); ipsRegistry::DB()->update('members', array('login_anonymous' => "{$be_anon}&1", 'last_activity' => IPS_UNIX_TIME_NOW), 'member_id=' . self::$data_store['member_id'], true); } } //----------------------------------------- // Group promotion based on time since joining //----------------------------------------- /* Are we checking for auto promotion? */ if (self::$data_store['g_promotion'] != '-1&-1') { /* Are we checking for post based auto incrementation? 0 is post based, 1 is date based, so... */ if (self::$data_store['gbw_promote_unit_type']) { list($gid, $gdate) = explode('&', self::$data_store['g_promotion']); if ($gid > 0 and $gdate > 0) { if (self::$data_store['joined'] <= time() - $gdate * 86400) { IPSMember::save(self::$data_store['member_id'], array('core' => array('member_group_id' => $gid))); /* Now reset the members group stuff */ self::$data_store = array_merge(self::$data_store, $cache[$gid]); self::$data_store = self::instance()->setUpSecondaryGroups(self::$data_store); self::instance()->perm_id = !empty(self::$data_store['org_perm_id']) ? self::$data_store['org_perm_id'] : self::$data_store['g_perm_id']; self::instance()->perm_id_array = explode(",", self::instance()->perm_id); } } } } }