コード例 #1
0
 public static function getLogger()
 {
     if (self::$logger === null) {
         $log_path = PLUGIN_MOVIEVIEWER_LOG_DIR . "/movieviewer.log";
         self::$logger = new \Monolog\Logger('movieviewer');
         self::$logger->pushHandler(new \Monolog\Handler\RotatingFileHandler($log_path, 10, \Monolog\Logger::INFO));
         $ip = new \Monolog\Processor\IntrospectionProcessor(\Monolog\Logger::DEBUG, array('Monolog\\', 'Illuminate\\'));
         self::$logger->pushProcessor($ip);
     }
     return self::$logger;
 }
コード例 #2
0
 private function sendRequestNotifycation($user, $request)
 {
     $payment_guide = MovieViewerReviewPackPurchasePaymentGuide::create($this->_settings->payment, $request);
     $price_with_notes = plugin_movieviewer_render_price_with_notes($request->getPrice(), "回", true);
     $item_names = $this->getItemNames($request);
     $mail_builder = new MovieViewerReviewPackRequestNotificationMailBuilder($this->_settings->mail);
     $mail = $mail_builder->build($user, $item_names, $price_with_notes, $payment_guide->bank_transfer, $payment_guide->deadline);
     $result = $mail->send();
     if (!$result) {
         MovieViewerLogger::getLogger()->addError("再視聴申し込み通知エラー", array("error_statement" => $mail->ErrorInfo));
         // スタッフ向けはログのみで終わらせる
     }
 }
コード例 #3
0
 function findBy($user_id, $date_requested)
 {
     $file_path = $this->getFilePath($user_id, $date_requested);
     if (!file_exists($file_path)) {
         MovieViewerLogger::getLogger()->addError("ファイルオープンに失敗", array("file" => $file_path));
         throw new MovieViewerRepositoryObjectNotFoundException();
     }
     $object = $this->createObject($file_path);
     return $object;
 }
/**
 * プラグイン規定関数::アクション型で呼び出された場合の処理
 * 申し込みを確定させる
 * 
 * 引数: string purchase_method 支払い区分(bank, credit)
 *      string deal_pack_id 受講パックID
 * 
 * 注意: 単独で呼び出さないこと(convertの画面と連携している)
 *
 * @return array ページ名、画面(html)
 */
function plugin_movieviewer_purchase_start_action()
{
    $page = plugin_movieviewer_get_current_page();
    $from_external_link = false;
    $test_var = filter_input(INPUT_POST, "purchase_method");
    if (empty($test_var)) {
        $from_external_link = true;
    }
    if ($from_external_link) {
        $deal_pack_id = filter_input(INPUT_GET, "deal_pack_id");
        $purchase_method = filter_input(INPUT_GET, "purchase_method");
    } else {
        $deal_pack_id = filter_input(INPUT_POST, "deal_pack_id");
        $purchase_method = filter_input(INPUT_POST, "purchase_method");
    }
    if (!$from_external_link) {
        try {
            plugin_movieviewer_validate_csrf_token();
        } catch (MovieViewerValidationException $ex) {
            return plugin_movieviewer_action_error_response($page, "不正なリクエストです。");
        }
    }
    try {
        $user = plugin_movieviewer_get_current_user();
    } catch (MovieViewerRepositoryObjectNotFoundException $ex) {
        return plugin_movieviewer_action_error_response($page, "ログインが必要です。");
    }
    if ($user->mailAddress === null || $user->mailAddress === "") {
        return plugin_movieviewer_action_error_response($page, "メールアドレスが登録されていません。");
    }
    try {
        plugin_movieviewer_validate_deal_pack_id($deal_pack_id);
    } catch (MovieViewerValidationException $ex) {
        return plugin_movieviewer_action_error_response($page, "指定した内容に誤りがあります。");
    }
    try {
        plugin_movieviewer_validate_purchase_method($purchase_method);
    } catch (MovieViewerValidationException $ex) {
        return plugin_movieviewer_action_error_response($page, "指定した内容に誤りがあります。");
    }
    $settings = plugin_movieviewer_get_global_settings();
    $offer_maker = new MovieViewerDealPackOfferMaker($settings->payment, $user);
    if (!$offer_maker->canOffer()) {
        return plugin_movieviewer_action_error_response($page, "ご指定のコースはすでに申し込み済み、または、受講できなくなりました。");
    }
    $offer = $offer_maker->getOffer();
    if ($offer->getPackId() !== $deal_pack_id) {
        return plugin_movieviewer_action_error_response($page, "ご指定のコースはすでに申し込み済み、または、受講できなくなりました。");
    }
    $offer->accept();
    if ($purchase_method === "bank") {
        $price_with_notes = plugin_movieviewer_render_dealpack_offer_price($offer, true);
        $mail_builder = new MovieViewerDealPackBankTransferInformationMailBuilder($settings->mail);
        $mail = $mail_builder->build($user, $offer->getPackName(), $price_with_notes, $offer->getPaymentGuide()->bank_transfer, $offer->getPaymentGuide()->deadline);
        $result = $mail->send();
        if (!$result) {
            MovieViewerLogger::getLogger()->addError("案内通知エラー", array("error_statement" => $mail->ErrorInfo));
            return plugin_movieviewer_action_error_response($page, "メールの送信に失敗しました。{$settings->contact['name']}に問い合わせしてください。");
        }
        $messages = <<<TEXT
        ご登録のアドレスに振込先等のご案内をお送りしています。<br>
        ご確認の上、お振込を期限までに完了してください。<br>
        現在の状況をマイページに戻って、ご確認ください。
TEXT;
    } else {
        if ($purchase_method === "credit") {
            $messages = <<<TEXT
        クレジットカードでの支払いが完了しました。<br>
        現在の状況をマイページに戻って、ご確認ください。<br>
        なおシステムの関係上、入金の確認には、しばらくお時間がかかることがありますので、ご了承ください。
TEXT;
        }
    }
    $hsc = "plugin_movieviewer_hsc";
    $back_uri = plugin_movieviewer_get_home_uri();
    $content = <<<TEXT
    <link href="https://code.jquery.com/ui/1.11.4/themes/redmond/jquery-ui.css" rel="stylesheet">
    <link href="plugin/movieviewer/assets/css/movieviewer.css" rel="stylesheet">
    <h2>受講申し込み完了</h2>
    <p>
    {$messages}
    </p>
    <p>
    <a href="{$back_uri}" class='ui-button ui-widget ui-state-default ui-corner-all ui-button-text-only'>マイページに戻る</a>
    </p>
TEXT;
    return array("msg" => $page, "body" => $content);
}
/**
 * [アクション] パスワードをリセットし、結果画面を生成する
 *
 * @return array ページ名, 画面(html)
 */
function plugin_movieviewer_reset_password_action_reset()
{
    $page = plugin_movieviewer_get_current_page();
    try {
        plugin_movieviewer_validate_csrf_token();
    } catch (MovieViewerValidationException $ex) {
        return plugin_movieviewer_reset_password_error("不正なリクエストです。");
    }
    $token_id = filter_input(INPUT_POST, 'token');
    try {
        $token = plugin_movieviewer_get_user_reset_password_token_repository()->findById($token_id);
    } catch (MovieViewerRepositoryObjectNotFoundException $ex) {
        MovieViewerLogger::getLogger()->addError("トークンが見つからない", array("token" => $token_id));
        return plugin_movieviewer_reset_password_error("パスワードの再設定ができませんでした。");
    }
    try {
        $user = plugin_movieviewer_get_user_repository()->findById($token->user_id);
    } catch (MovieViewerRepositoryObjectNotFoundException $ex) {
        MovieViewerLogger::getLogger()->addError("ユーザが見つからない", array("token" => $token_id, "user" => $token->user_id));
        return plugin_movieviewer_reset_password_error("パスワードの再設定ができませんでした。");
    }
    $password = filter_input(INPUT_POST, 'movieviewer_password');
    $password_confirm = filter_input(INPUT_POST, 'movieviewer_password_confirm');
    if ($password !== $password_confirm) {
        $content = plugin_movieviewer_reset_password_action_confirm_generate_page($token, $user, "入力したパスワードとパスワード(確認)が一致しません。");
        return array("msg" => $page, "body" => $content);
    }
    $user->setPassword($password);
    plugin_movieviewer_get_user_repository()->store($user);
    plugin_movieviewer_get_user_reset_password_token_repository()->delete($token);
    $content = <<<TEXT
    パスワードを更新しました。
TEXT;
    return array("msg" => $page, "body" => $content);
}