self::FIRSTNAME => array(self::VN_ORDINARY, self::VN_INI, self::VN_OTHER)
);
- const ADDRESS_MAIN = 0x000001;
- const ADDRESS_PERSO = 0x000002;
- const ADDRESS_PRO = 0x000004;
- const ADDRESS_ALL = 0x000006;
- const ADDRESS_POSTAL = 0x000008;
-
- const EDUCATION_MAIN = 0x000010;
- const EDUCATION_EXTRA = 0x000020;
- const EDUCATION_ALL = 0x000040;
- const EDUCATION_FINISHED = 0x000080;
- const EDUCATION_CURRENT = 0x000100;
-
- const JOBS_MAIN = 0x001000;
- const JOBS_ALL = 0x002000;
- const JOBS_FINISHED = 0x004000;
- const JOBS_CURRENT = 0x008000;
-
- const NETWORKING_ALL = 0x000000;
- const NETWORKING_WEB = 0x010000;
- const NETWORKING_IM = 0x020000;
- const NETWORKING_SOCIAL = 0x040000;
+ const ADDRESS_MAIN = 0x00000001;
+ const ADDRESS_PERSO = 0x00000002;
+ const ADDRESS_PRO = 0x00000004;
+ const ADDRESS_ALL = 0x00000006;
+ const ADDRESS_POSTAL = 0x00000008;
+
+ const EDUCATION_MAIN = 0x00000010;
+ const EDUCATION_EXTRA = 0x00000020;
+ const EDUCATION_ALL = 0x00000040;
+ const EDUCATION_FINISHED = 0x00000080;
+ const EDUCATION_CURRENT = 0x00000100;
+
+ const JOBS_MAIN = 0x00001000;
+ const JOBS_ALL = 0x00002000;
+ const JOBS_FINISHED = 0x00004000;
+ const JOBS_CURRENT = 0x00008000;
+
+ const NETWORKING_ALL = 0x00070000;
+ const NETWORKING_WEB = 0x00010000;
+ const NETWORKING_IM = 0x00020000;
+ const NETWORKING_SOCIAL = 0x00040000;
+
+ const PHONE_LINK_JOB = 0x00100000;
+ const PHONE_LINK_ADDRESS = 0x00200000;
+ const PHONE_LINK_PROFILE = 0x00400000;
+ const PHONE_LINK_COMPANY = 0x00800000;
+ const PHONE_LINK_ANY = 0x00F00000;
+
+ const PHONE_TYPE_FAX = 0x01000000;
+ const PHONE_TYPE_FIXED = 0x02000000;
+ const PHONE_TYPE_MOBILE = 0x04000000;
+ const PHONE_TYPE_ANY = 0x07000000;
+
+ const PHONE_ANY = 0x07F00000;
const FETCH_ADDRESSES = 0x000001;
const FETCH_CORPS = 0x000002;
return $this->owner;
}
+ public function isActive()
+ {
+ if ($this->owner()) {
+ return $this->owner->isActive();
+ }
+ return false;
+ }
+
public function promo()
{
return $this->promo;
public function nationalities()
{
$nats = array();
+ $countries = DirEnum::getOptions(DirEnum::COUNTRIES);
if ($this->nationality1) {
- $nats[] = $this->nationality1;
+ $nats[$this->nationality1] = $countries[$this->nationality1];
}
if ($this->nationality2) {
- $nats[] = $this->nationality2;
+ $nats[$this->nationality2] = $countries[$this->nationality2];
}
if ($this->nationality3) {
- $nats[] = $this->nationality3;
+ $nats[$this->nationality3] = $countries[$this->nationality3];
}
return $nats;
}
}
+ /**
+ * Clears a profile.
+ * *always deletes in: profile_addresses, profile_binets, profile_job,
+ * profile_langskills, profile_mentor, profile_networking,
+ * profile_phones, profile_skills, watch_profile
+ * *always keeps in: profile_corps, profile_display, profile_education,
+ * profile_medals, profile_name, profile_photos, search_name
+ * *modifies: profiles
+ */
+ public function clear()
+ {
+ $tables = array(
+ 'profile_job', 'profile_langskills', 'profile_mentor',
+ 'profile_networking', 'profile_skills', 'watch_profile',
+ 'profile_phones', 'profile_addresses', 'profile_binets');
+
+ foreach ($tables as $t) {
+ XDB::execute('DELETE FROM ' . $t . '
+ WHERE pid = {?}',
+ $this->id());
+ }
+
+ XDB::execute("UPDATE profiles
+ SET cv = NULL, freetext = NULL, freetext_pub = 'private',
+ medals_pub = 'private', alias_pub = 'private',
+ email_directory = NULL
+ WHERE pid = {?}",
+ $this->id());
+ }
+
/** Sets the level of visibility of the profile
* Sets $this->visibility to a list of valid visibilities.
* @param one of the self::VIS_* values
$this->consolidateFields();
}
- public function getAddresses($flags, $limit = null)
+ private function fetchAddresses()
{
if ($this->addresses == null && !$this->fetched(self::FETCH_ADDRESSES)) {
$addr = $this->getProfileField(self::FETCH_ADDRESSES);
if ($addr) {
$this->setAddresses($addr);
+ $this->fetchPhones();
}
}
+ }
+
+ public function getAddresses($flags, $limit = null)
+ {
+ $this->fetchAddresses();
if ($this->addresses == null) {
return array();
$this->consolidateFields();
}
- public function getPhones($flags, $limit = null)
+ private function fetchPhones()
{
if ($this->phones == null && !$this->fetched(self::FETCH_PHONES)) {
- $this->setPhones($this->getProfileField(self::FETCH_PHONES));
+ $phones = $this->getProfileField(self::FETCH_PHONES);
+ if (isset($phones)) {
+ $this->setPhones($phones);
+ }
}
+ }
+ public function getPhones($flags, $limit = null)
+ {
+ $this->fetchPhones();
if ($this->phones == null) {
return array();
}
$this->consolidateFields();
}
- public function getJobs($flags, $limit = null)
+ private function fetchJobs()
{
if ($this->jobs == null && !$this->fetched(self::FETCH_JOBS)) {
$jobs = $this->getProfileField(self::FETCH_JOBS);
if ($jobs) {
$this->setJobs($jobs);
+ $this->fetchAddresses();
}
}
+ }
+
+ public function getJobs($flags, $limit = null)
+ {
+ $this->fetchJobs();
if ($this->jobs == null) {
return array();
private static function fetchProfileData(array $pids, $respect_order = true, $fields = 0x0000, $visibility = null)
{
if (count($pids) == 0) {
- return array();
+ return null;
}
if ($respect_order) {
$it = XDB::Iterator('SELECT p.pid, p.hrpid, p.xorg_id, p.ax_id, p.birthdate, p.birthdate_ref,
p.next_birthday, p.deathdate, p.deathdate_rec, p.sex = \'female\' AS sex,
- p.cv, p.medals_pub, p.alias_pub, p.email_directory, p.last_change,
- p.nationality1, p.nationality2, p.nationality3,
+ IF ({?}, p.cv, NULL) AS cv, p.medals_pub, p.alias_pub, p.email_directory,
+ p.last_change, p.nationality1, p.nationality2, p.nationality3,
IF (p.freetext_pub IN {?}, p.freetext, NULL) AS freetext,
pe.entry_year, pe.grad_year,
- IF ({?} IN {?}, pse.text, NULL) AS section,
- pn_f.name AS firstname, pn_l.name AS lastname, pn_n.name AS nickname,
+ IF ({?}, pse.text, NULL) AS section,
+ pn_f.name AS firstname, pn_l.name AS lastname,
+ IF( {?}, pn_n.name, NULL) AS nickname,
IF(pn_uf.name IS NULL, pn_f.name, pn_uf.name) AS firstname_ordinary,
IF(pn_ul.name IS NULL, pn_l.name, pn_ul.name) AS lastname_ordinary,
- pd.promo AS promo, pd.short_name, pd.directory_name AS full_name,
- pd.directory_name, IF(pp.pub IN {?}, pp.display_tel, NULL) AS mobile,
+ pd.yourself, pd.promo, pd.short_name, pd.public_name AS full_name,
+ pd.directory_name, pd.public_name, pd.private_name,
+ IF(pp.pub IN {?}, pp.display_tel, NULL) AS mobile,
(ph.pub IN {?} AND ph.attach IS NOT NULL) AS has_photo,
ph.x AS photo_width, ph.y AS photo_height,
p.last_change < DATE_SUB(NOW(), INTERVAL 365 DAY) AS is_old,
WHERE p.pid IN {?}
GROUP BY p.pid
' . $order,
- $visibility->levels(),
- ProfileVisibility::VIS_PRIVATE, $visibility->levels(),
- $visibility->levels(), $visibility->levels(),
+ $visibility->isVisible(ProfileVisibility::VIS_PRIVATE), // CV
+ $visibility->levels(), // freetext
+ $visibility->isVisible(ProfileVisibility::VIS_PRIVATE), // section
+ $visibility->isVisible(ProfileVisibility::VIS_PRIVATE), // nickname
+ $visibility->levels(), // mobile
+ $visibility->levels(), // photo
$pids
);
return new ProfileIterator($it, $pids, $fields, $visibility);
|| $name == self::DN_SHORT || $name == self::DN_SORT;
}
+ /** Returns the closest "accounts only" name type for $name
+ */
+ public static function getAccountEquivalentName($name)
+ {
+ switch ($name)
+ {
+ case self::DN_DIRECTORY:
+ case self::DN_SORT:
+ return 'directory_name';
+ case self::DN_FULL:
+ case self::DN_PUBLIC:
+ return 'full_name';
+ case self::DN_PRIVATE:
+ case self::DN_SHORT:
+ case self::DN_YOURSELF:
+ default:
+ return 'display_name';
+ }
+ }
+
public static function getNameTypeId($type, $for_sql = false)
{
if (!S::has('name_types')) {
/** The school identifier consists of 6 digits. The first 3 represent the
* promotion entry year. The last 3 indicate the student's rank.
- *
+ *
* Our identifier consists of 8 digits and both half have the same role.
* This enables us to deal with bigger promotions and with a wider range
* of promotions.