8

私はlaravelを初めて使用し、開発中のWebアプリのキャッシャーを使用しています。私のアプリでは、ユーザーは自分のアカウントと会社を作成し、アプリの使用を許可されています。会社には多くのユーザーがいる可能性があるため、会社にサブスクリプションがあるかどうかを確認するレジ係が必要です。

Stripe を使用したレジ係のドキュメントでは、事前にクレジット カードが不要な場所に設定してあり、クレジット カードの入力を求められるまで 14 日間システムを使用できます。

これまでのところ、会社のテーブルにレジ係の列を作成し、ドキュメントに従ってsubsctiptionテーブルを追加しました。
add_cashier_table_fields.php 移行ファイル:

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class AddCashierTableFields extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        //
        Schema::table('companies', function ($table) {
            $table->string('stripe_id')->nullable();
            $table->string('card_brand')->nullable();
            $table->string('card_last_four')->nullable();
            $table->timestamp('trial_ends_at')->nullable();
        });

        Schema::create('subscriptions', function ($table) {
            $table->increments('id');
            $table->integer('company_id');
            $table->string('name');
            $table->string('stripe_id');
            $table->string('stripe_plan');
            $table->integer('quantity');
            $table->timestamp('trial_ends_at')->nullable();
            $table->timestamp('ends_at')->nullable();
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        //
    }
}

次に、私の会社のモデルに、提案されたように Billable トレイトを追加しました。 Company.php - モデル

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use Laravel\Cashier\Billable;

class Company extends Model
{
    use Billable;
    protected $dates = [
        'trial_ends_at', 
        'subscription_ends_at'
    ];

    protected $fillable = [
        'company_name',
        'trial_ends_at', 
        'subscription_ends_at'
    ];

    protected $cardUpFront = false;

    public function users()
    {
        return $this->hasMany(\App\User::class);
    }
}

今、私のRegisterController.phpファイルには、会社が作成されたときに、その日から14日後の日付をCarbonし、Auth/RegisterController.php'trial_ends_at'列 に追加する場所があります

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\Company;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\RegistersUsers;
use Carbon\Carbon;

class RegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after login / registration.
     *
     * @var string
     */
    protected $redirectTo = '/home';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest');
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'company_name' => 'required|unique:companies,company_name',
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|min:6|confirmed',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        $company = \App\Company::create([
            'company_name'=> $data['company_name'],
            'trial_ends_at' => Carbon::now()->addDays(14), //Collect CC# 14 days from now
        ]);

        $user = $company->users()->create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);

        $user->attachRole(1); //Admin role

        return $user;

    }
}

現在のサブスクリプションが試用期間内であるか、使用していないかを確認しようとしています

if ($company->onTrial()) {}

システム全体 (登録ページを除く) へのアクセスを制限する必要があるため、ミドルウェアを使用してサブスクリプションのステータスを確認する必要があると考えています。そこで、次のように Subscription.php ミドルウェアを作成しました。

<?php

namespace App\Http\Middleware;

use Closure;
use App\User;
use App\Company;
use Illuminate\Support\Facades\Auth;

class Subscription
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if (Auth::check()){
            //dd($request->user);
;            $companyID = Auth::user()->company_id;
            $company = Company::find($companyID);
            dd($company->onTrial());
            if($company->onTrial()){
                return redirect('order');
            }
        }
        return $next($request);
    }
}

質問: キャッシャーを (ユーザーごとではなく) 会社に接続し、サブスクリプションがアクティブでない場合にシステムへのアクセスを制限する最良の方法は何ですか? 私var_dump($company->onTrial())はそれが常にfalseを印刷するとき?日付が今年の初めのものであることを確認したので、試用期間を過ぎているはずですが、試用期間中かどうかに関係なく、常に誤って出力されます. これは私がやろうとしていることに対する最良のアプローチですか? すべてのコードについてお詫び申し上げます。このオンラインに関する情報はほとんどないため、全体像を皆さんにお伝えしたかったのです。

このトピックに関する他の投稿と異なる唯一の点は、会社のモデルがモデルを拡張し、認証可能ではないことです。サブスクリプションが kernel.php ファイルに追加され、ミドルウェアがルート ファイルに登録されていることを確認しました。

4

1 に答える 1

3

これが機能していることがわかりました。データベースで日付を手動で変更して試用期間外にすると、false が返されます。同様に、試用期間中の場合は true が返されます。私の場合onTrial()、現在の URL が localhost:8000/order であるかどうかを確認する必要がありました。そうでない場合、カード情報を入力するまで、アプリはその注文ページにリダイレクトします。将来誰かが同様の状況に陥り、機能するコードが必要になった場合に備えて、最終的なミドルウェアをここに投稿します。(これが最善のアプローチかどうかはまだわかりませんが、うまくいきます)

<?php

namespace App\Http\Middleware;

use Closure;
use App\User;
use App\Company;
use Illuminate\Support\Facades\Auth;

class Subscription
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        if (Auth::check()){
            //dd($request->user);
            $companyID = Auth::user()->company_id;
            $company = Company::find($companyID);
            //dd($company->onTrial());
            if(!$company->onTrial() && $request->path() != 'order'){ //If trial has expired redirect to order page
                return redirect('order');
            }
        }
        return $next($request);
    }
}
于 2016-12-14T17:14:22.300 に答える