コード例 #1
0
 public function main()
 {
     $name = Utility::cleanString($_POST["name"]);
     $notes = Utility::cleanString($_POST["notes"]);
     $is_chapter = Utility::cleanBoolean($_POST["is_chapter"]);
     $all_day_event = !$is_chapter && Utility::cleanBoolean($_POST["is_all_day"]);
     $start = Utility::getDateTimeFromDateYmdHis(Utility::cleanString($_POST["time_start"]));
     $end = Utility::getDateTimeFromDateYmdHis(Utility::cleanString($_POST["time_end"]));
     $is_repeating = !$is_chapter && Utility::cleanBoolean($_POST["is_repeating"]);
     $n_times = Utility::cleanInt($_POST["n_times"], 2);
     $repeat_type = Utility::cleanInt($_POST["repeat_type"], Group::TYPE_DAYS, Group::TYPE_YEARS);
     if ($name == "") {
         $this->setError(self::$E_INVALID_NAME);
     } else {
         if (!$all_day_event && !$start) {
             $this->setError(self::$E_INVALID_DATE_START);
         } else {
             if (!$all_day_event && !$is_chapter && !$end) {
                 $this->setError(self::$E_INVALID_DATE_END);
             } else {
                 if (!$all_day_event && $end <= $start) {
                     $this->setError(self::$E_INVALID_DATE_END_BEFORE_START);
                 } else {
                     if ($is_repeating) {
                         if ($n_times === false) {
                             $this->setError(self::$E_INVALID_REPEAT_TIME);
                         } else {
                             if ($repeat_type === false) {
                                 $this->setError(self::$E_INVALID_REPEAT_TYPE);
                             }
                         }
                     }
                 }
             }
         }
     }
     if ($this->hasError()) {
         return [];
     }
     $_events = [];
     if ($all_day_event) {
         $start = $start ?: null;
         $end = $end ?: null;
     }
     if (!$is_repeating) {
         $_event = new Event($this->_pdo);
         $_event->create($name, $notes, $all_day_event, $is_chapter, $this->_auth->getUser(), $end, $start);
         $_events[] = $_event;
     } else {
         $_group = new Group($this->_pdo);
         $_group->create($name, $notes, $all_day_event, $is_chapter, $n_times, $this->_auth->getUser(), $repeat_type, $start, $end);
         $_events = $_group->generateEvents();
     }
     return $_events;
 }
コード例 #2
0
 public function main()
 {
     $org_id = Utility::cleanInt($_POST["org_id"], 1);
     $uni_id = Utility::cleanInt($_POST["uni_id"], 1);
     $email = Utility::cleanString($_POST["university_email"]);
     $name_first = Utility::cleanString($_POST["name_first"]);
     $name_last = Utility::cleanString($_POST["name_last"]);
     $password = Utility::cleanString($_POST["password"]);
     $pledge_class = Utility::cleanString($_POST["pledge_class"]);
     $year = Utility::getDateTimeFromYear(Utility::cleanString($_POST["year"]));
     if (!$org_id) {
         $this->setError(self::$E_ORG_INVALID);
         return;
     }
     if (!$uni_id) {
         $this->setError(self::$E_UNI_INVALID);
         return;
     }
     $_org = GreekOrganization::find($this->_pdo, $org_id);
     $_uni = University::find($this->_pdo, $uni_id);
     if (is_null($_org)) {
         $this->setError(self::$E_ORG_INVALID);
         return;
     }
     if (is_null($_uni)) {
         $this->setError(self::$E_UNI_INVALID);
         return;
     }
     if (Chapter::findByOrgAndUni($this->_pdo, $_org, $_uni)) {
         $this->setError(self::$E_CHAPTER_EXISTS);
         return;
     }
     if ($name_first == "") {
         $this->setError(self::$E_NAME_F_INVALID);
         return;
     }
     if ($name_last == "") {
         $this->setError(self::$E_NAME_L_INVALID);
         return;
     }
     if (!Utility::isValidEmail($email)) {
         $this->setError(self::$E_EMAIL_INVALID);
         return;
     }
     if (User::findByEmail($this->_pdo, $email)) {
         $this->setError(self::$E_USER_EXISTS);
         return;
     }
     if ($pledge_class == "") {
         $this->setError(self::$E_PLEDGE_CLASS_INVALID);
         return;
     }
     if (!Utility::cleanInt($_POST["year"], date("Y") - 6)) {
         $this->setError(self::$E_YEAR_INVALID);
         return;
     }
     if ($year === false) {
         $this->setError(self::$E_YEAR_INVALID);
         return;
     }
     if (!Utility::isValidPassword($password)) {
         $this->setError(self::$E_PASSWORD_INVALID);
         return;
     }
     $_chapter = new Chapter($this->_pdo);
     $_chapter->create($_org, $_uni);
     $_pc = new PledgeClass($this->_pdo);
     $_pc->create($_chapter, $pledge_class);
     $_user = new User($this->_pdo);
     $_user->create($_chapter, $_pc, $name_first, $name_last, $email, $password, $year, true);
     $worker = new EmailWorker($this->_pdo);
     //TODO: Send email to user about what's next
     $worker->queueSignUpNotificationEmail($_chapter);
 }