質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.09%

EC-CUBE3をBtoBのクローズドにして、新規会員登録を管理者の承認形式に変更する

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 950

waat

score 7

現在の状況

現在EC-CUBE3にてBtoBのショッピングサイトを制作しております。
その際、一般の人には登録させたくないので、
src > Eccube > Application.php 570行目の

$this['security.access_rules'] = array(

array('^/entry', 'IS_AUTHENTICATED_ANONYMOUSLY', $channel), //会員登録ページ許可
array('^/', 'ROLE_USER', $channel), // その他ページ拒否

等を追加して、クローズドサイトとしております。
上記を施すことでログインをしなければトップページを閲覧できない状態にしておりますが、新規登録さえすれば誰でも閲覧できてしまう状況です。

理想の状況

最終的に、
1.企業様:新規会員登録をする
2.企業様:仮登録完了のメールが届く
3.管理者:企業様が仮登録されたという通知メールが届く
4.管理者:承認する
5.企業様:本登録完了のメールが届く
という流れにしたいです。
2は仮登録完了メールに記載している「本登録のURL」を削除して「ご登録内容の確認を行いますので」と案内のみとしておりますが、345に関してはどの部分のプログラムを変更すればいいのかわからない状態です。

EC-CUBE自体の開発経験が薄い為、なるべくご丁寧に解説をして下さると大変助かります。
何卒よろしくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • xenbeat

    2018/12/13 12:17

    2までできているのであれば「3.管理者:企業様が仮登録されたという通知メールが届く」をとりあえず実装してみましょう。
    Teratailで回答を得たいのであれば、そこで躓いたことに対して質問されることをおすすめします。

    キャンセル

  • waat

    2018/12/13 12:26

    すみません、teratailもあまり使用したことがない為、不適切な質問となってしまいました。
    2を実装し、質問内容を更新させていただきます。
    ご指摘ありがとうございました。

    キャンセル

回答 2

checkベストアンサー

+2

どこを変更
⇒ EC キューブの本体はいじってはいけません。脆弱性対応が宛てれなくなります。

どう変更

  1. 管理者にメール
    (フロント)ユーザー登録完了時のフックポイントで管理者にメールを送信してください。

  2. 管理者によるユーザー有効化
    仮登録完了メール~とあるので普通に修正不要です。
    ユーザー管理画面にフラグがあるかと

  3. ユーザー登録通知
    (管理画面)ユーザー更新完了時のフックポイントでユーザーにメールを送信してください。

よほどのことが無い限り、データ更新前後で2箇所以上フックポイントがあります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/13 14:33

    確かに脆弱性のことを考えると、本体部分をいじってはいけないですね…。
    そこまで意識を向けられませんでした。
    ご回答ありがとうございました!

    キャンセル

+2

Eccube/Controller/EntryController.php の index で、仮登録〜メール送信の処理をしているので、メール送信部分の修正が必要と思います。

ソースコードを眺めただけなので、アイデアレベルですが...

2.企業様:仮登録完了のメールが届く

ソースコードから判断すると Mail/entry_confirm.html.twig か Mail/entry_confirm.twig が、仮登録メールのテンプレートと思いますので、{{activation_code}} の部分を除いたテンプレートにして、メールを送信するようにする。

3.管理者:企業様が仮登録されたという通知メールが届く

アクティベーションURL付きのメールのテンプレートを Mail/entry_user_activation_admin.twig のような感じで、用意して、管理人に送信するプログラムを追加する。

という感じで、 2は、テンプレートを変更。3は、テンプレート追加とメール送信処理を追加で、変更すれば、4、5は、そのままプログラムの変更なしで運用だけでいけるかもしれないですね。


探してみたら、会員登録承認制プラグイン for EC-CUBE3 って ありますけどね...

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/13 14:35

    詳しいご説明ありがとうございます!
    「会員登録承認制プラグイン for EC-CUBE3」というプラグインはあるのですが、自分で作るとどうやるんだろう…と質問をさせていただきました。
    ご回答ありがとうございました!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.09%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる