public function execute($args = null) { if (!empty($_POST)) { $_POST['id'] = null; $_POST['hash'] = ServiceAuth::createHash($_POST['pass1']); $_POST['inBounds'] = 0; $_POST['outBounds'] = 0; $u = ModelUser::newInstance()->hydrate($_POST); $p = ModelProfile::newInstance(); if ($_POST['pass1'] != $_POST['pass2']) { ServiceMessage::getInstance()->addMessage('Les mots de passes ne correspondent pas', 'error'); } elseif (CollectionUser::newInstance()->findBy('login', $_POST['login'])) { ServiceMessage::getInstance()->addMessage('Ce login est déjà utilisé', 'error'); } else { if (ServiceDb::getInstance()->persist($u)) { if ($i = ServiceDb::getInstance()->lastInsertId()) { if (ServiceDb::getInstance()->persist($p->hydrate(array('user_id' => $i)))) { ServiceMessage::getInstance()->addMessage('Votre compte a bien été créé', 'success'); ServiceDb::getInstance()->persist(ModelAction::newInstance()->setUser_id($i)->setType('create')->setObject('profile')->setWhen()); return header('Location: /logout/quiet'); } else { ServiceDb::getInstance()->delete($u); ServiceMessage::getInstance()->addMessage('Une erreur est survenue #2', 'error'); } } else { ServiceMessage::getInstance()->addMessage('Une erreur est survenue #1', 'error'); } } } } ServiceRenderHtml::newInstance()->load('subscribe')->setData('hideNavigation', true)->render(); }
public function findByWithUser($names, $ids) { if (!is_array($ids)) { $ids = array($ids); } if (!is_array($names)) { $names = array($names); } $c = static::getModelName(); $sth = ServiceDb::getInstance()->prepare(' select `' . static::getTableName() . '`.*, `user`.* from `' . static::getTableName() . '` left join `user` on `user`.`id`=`' . static::getTableName() . '`.`user_id` where `' . implode('`=? and `', $names) . '`=?'); $sth->execute($ids); $arr = array(); foreach ($sth->fetchAll() as $data) { if ($data['id'] == ServiceAuth::getInstance()->getUser()->getId()) { continue; } $a = new ModelUser(); $a->hydrate($data); $b = new $c(); $b->hydrate($data); $a->setProfile($b); $arr[] = $a; } return $arr; }
private function del($args) { $p = ServiceRenderJson::newInstance(); $u = ServiceAuth::getInstance()->getUser(); $i = $u->getId(); if ($v = $this->getQueryNext()) { if (!($o = $u->getPhoto($v))) { $p->setData('success', false)->setData('message', 'Cette photo n\'existe pas !'); } elseif ($o->getUser_id() != $i) { $p->setData('success', false)->setData('message', 'Cette photo n\'est pas la votre !'); } else { if (!ServiceDb::getInstance()->delete($o)) { $p->setData('message', 'L\'opération a échoué !'); } else { $p->setData('success', true)->setData('message', 'La photo a bien été supprimée'); $u->delPhoto($o); $f = '../public/uploads/' . $o->getId(); //.'.'.$ext; if (@unlink($f)) { ServiceDb::getInstance()->persist(ModelAction::newInstance()->setUser_id($i)->setType('delete')->setObject('photo')->setValue($o->getId())->setWhen()); } else { $p->setData('success', false)->setData('message', 'Erreur lors de la suppression de l\'image'); } } } } else { $p->setData('success', false); } $p->render(); }
public function execute($args = null) { $p = ServiceRenderJson::newInstance(); if (isset($_POST['id'], $_POST['type'], $_POST['action'])) { if (!($u = CollectionUser::newInstance()->find($_POST['id']))) { $p->setData('success', false)->setData('message', 'Membre inconnu'); } else { $c = ($_POST['action'] == 'add' ? 'enable' : 'disable') . 'Type'; $r = ServiceAuth::getInstance()->getUser()->getUser_has_user($u); $r->{$c}($_POST['type']); if (ServiceDb::getInstance()->persist($r)) { $p->setData('success', true)->setData('message', 'La relation a bien été ' . ($_POST['action'] == 'add' ? 'ajoutée' : 'supprimée')); ServiceDb::getInstance()->persist(ModelAction::newInstance()->setUser_id(ServiceAuth::getInstance()->getUser()->getId())->setObject('relation')->setValue($u->getLogin() . ' (' . ModelUser_has_user::$shortNames[$_POST['type']] . ')')->setType($_POST['action'] == 'add' ? 'create' : 'delete')->setWhen()); if ($r->getType() == 0) { ServiceAuth::getInstance()->getUser()->delUser_has_user($r); ServiceDb::getInstance()->delete($r); } else { ServiceAuth::getInstance()->getUser()->addUser_has_user($r); } } else { $p->setData('message', 'L\'opération a échoué !'); } } } else { $p->setData('success', false); } $p->render(); }
private function updateV($args) { $p = ServiceRenderJson::newInstance(); $pro = ServiceAuth::getInstance()->getUser()->getProfile(); if (isset($_POST['id'], $_POST['value'])) { if (!($u = $pro->getParameter($_POST['id']))) { $p->setData('success', false)->setData('message', 'Paramètre inconnu'); } else { if (!ModelParameter::isValidVisibility($_POST['value'])) { $p->setData('success', false)->setData('message', 'Valeur incorrecte'); } else { $u->setVisibility($_POST['value']); // we persist the Profile, not the Parameter ! Be careful if (ServiceDb::getInstance()->persist($pro)) { $p->setData('success', true)->setData('message', 'La visibilité du paramètre a bien été modifiée'); ServiceDb::getInstance()->persist(ModelAction::newInstance()->setUser_id(ServiceAuth::getInstance()->getUser()->getId())->setType('update')->setObject('parameter visibility')->setValue($_POST['id'])->setWhen()); } else { $p->setData('message', 'L\'opération a échoué !'); } } } } else { $p->setData('success', false); } $p->render(); }
public function delete(Persistable $instance) { $t = strtolower(str_replace('Model', '', get_class($instance))); $sth = ServiceDb::getInstance()->prepare(' delete from `' . $t . '` where `' . implode('`=? and `', $instance::getPersistentId()) . '`=? limit 1'); foreach ($instance::getPersistentId() as $V) { $c = getGetter($V); $v[] = $instance->{$c}(); } $a = $sth->execute($v); return $a; }
public function findAllWithReputation() { $sth = ServiceDb::getInstance()->prepare(' select `user`.*, (`inBounds`/(`inBounds`+`outBounds`)) `reputation` from `user` order by `reputation` desc, `inBounds` desc'); $sth->execute(); $arr = array(); foreach ($sth->fetchAll() as $data) { $a = new ModelUser(); $a->hydrate($data); $arr[] = $a; } return $arr; }
public function findAllCoworkers() { $k = ''; foreach (array_keys(ModelUser::newInstance()->getPersistentData()) as $v) { $k .= "`user1`.`{$v}` `a__{$v}`, `user2`.`{$v}` `b__{$v}`,"; } $sth = ServiceDb::getInstance()->prepare(' select `user_has_user`.*, ' . $k . ' `user1`.`id` `a__id`, `user2`.`id` `b__id` from `user_has_user` left join `user` `user1` on `user1`.`id`=`user_has_user`.`user_id1` left join `user` `user2` on `user2`.`id`=`user_has_user`.`user_id2` where (`user_has_user`.`type` & ' . ModelUser_has_user::WORK . ' ) and exists ( select 1 from `user_has_user` `foo` where `user_has_user`.`user_id2`=`foo`.`user_id1` and (`foo`.`type` & ' . ModelUser_has_user::WORK . ' ) )'); $sth->execute(); $pairs = array(); $arr = array(); foreach ($sth->fetchAll() as $data) { $datax = array(); // FIXME : find another way to avoir doublons if (in_array($data['a__id'] . '.' . $data['b__id'], $pairs) || in_array($data['b__id'] . '.' . $data['a__id'], $pairs)) { continue; } $pairs[] = $data['a__id'] . '.' . $data['b__id']; $a = ModelUser_has_user::newInstance()->hydrate($data); foreach ($data as $k => $v) { if (strpos($k, 'a__') === 0) { $datax[str_replace('a__', '', $k)] = $v; } } $a->setUser1(ModelUser::newInstance()->hydrate($datax)); foreach ($data as $k => $v) { if (strpos($k, 'b__') === 0) { $datax[str_replace('b__', '', $k)] = $v; } } $a->setUser2(ModelUser::newInstance()->hydrate($datax)); $arr[] = $a; } return $arr; }
public function countDesc() { $sth = ServiceDb::getInstance()->prepare(' select `action`.* ,`user`.* ,count(*) as `nb` from `action` left join `user` on `user`.`id`=`action`.`user_id` group by `action`.`user_id` order by `nb` desc'); $sth->execute(); $arr = array(); foreach ($sth->fetchAll() as $data) { $a = new ModelUser(); $a->hydrate($data); $b = new ModelAction(); $b->hydrate($data); $b->setUser($a); $arr[] = array($b, $data['nb']); } return $arr; }
private function del($args) { $p = ServiceRenderJson::newInstance(); $u = ServiceAuth::getInstance()->getUser(); $i = $u->getId(); if ($v = $this->getQueryNext()) { if (!($o = $u->getSkill($v))) { $p->setData('success', false)->setData('message', 'Vous n\'avez pas cette compétence #1'); } elseif ($o->getUser_id() != $u->getId()) { $p->setData('success', false)->setData('message', 'Vous n\'avez pas cette compétence #2'); } else { if (!ServiceDb::getInstance()->delete($o)) { $p->setData('message', 'L\'opération a échoué !'); } else { $p->setData('success', true)->setData('message', 'La compétence a bien été supprimée'); $u->delSkill($o); ServiceDb::getInstance()->persist(ModelAction::newInstance()->setUser_id($i)->setType('delete')->setObject('skill')->setValue($o->getName())->setWhen()); } } } else { $p->setData('success', false); } $p->render(); }
public function findAllAssoc($ids) { if (!is_array($ids)) { $ids = array($ids); } $c = static::getModelName(); $t = $c::getPersistentId(); $d1 = array_pop($t); $d2 = array_pop($t); $e = array_pop(explode('_', static::getTableName())); // user_has_skill => skill $E = 'Model' . ucfirst($e); $k = array_pop($E::getPersistentId()); $sth = ServiceDb::getInstance()->prepare(' select `' . static::getTableName() . '`.*,`' . $e . '`.* from `' . static::getTableName() . '` left join `' . $e . '` on `' . static::getTableName() . '`.`' . $d1 . '`=`' . $e . '`.`' . $k . '` where `' . static::getTableName() . '`.`' . $d2 . '`=?'); $sth->execute($ids); $arr = array(); foreach ($sth->fetchAll() as $data) { $z = 'set' . ucfirst($e) . '2'; $a = new $c(); $a->hydrate($data); $x = new $E(); $x->hydrate($data); $a->{$z}($x); $arr[] = $a; } return $arr; }