私は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 ファイルに追加され、ミドルウェアがルート ファイルに登録されていることを確認しました。