2016-05-11 00:46:32 +02:00
|
|
|
<?php namespace App\Models;
|
|
|
|
|
|
|
|
use Cache;
|
|
|
|
use Eloquent;
|
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
|
|
|
|
class PaymentMethod extends EntityModel
|
|
|
|
{
|
|
|
|
use SoftDeletes;
|
|
|
|
|
|
|
|
protected $dates = ['deleted_at'];
|
|
|
|
public $timestamps = true;
|
|
|
|
protected $hidden = ['id'];
|
|
|
|
|
|
|
|
public static function createNew($accountGatewayToken = null)
|
|
|
|
{
|
|
|
|
$entity = new PaymentMethod();
|
|
|
|
|
|
|
|
$entity->account_id = $accountGatewayToken->account_id;
|
|
|
|
$entity->account_gateway_token_id = $accountGatewayToken->id;
|
|
|
|
|
|
|
|
$lastEntity = static::scope(false, $entity->account_id);
|
|
|
|
|
|
|
|
$lastEntity = $lastEntity->orderBy('public_id', 'DESC')
|
|
|
|
->first();
|
|
|
|
|
|
|
|
if ($lastEntity) {
|
|
|
|
$entity->public_id = $lastEntity->public_id + 1;
|
|
|
|
} else {
|
|
|
|
$entity->public_id = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $entity;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function account()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\Account');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function contact()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\Contact');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function account_gateway_token()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\AccountGatewayToken');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function payment_type()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\PaymentType');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function currency()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('App\Models\Currency');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function payments()
|
|
|
|
{
|
|
|
|
return $this->hasMany('App\Models\Payments');
|
|
|
|
}
|
|
|
|
|
2016-05-15 22:27:56 +02:00
|
|
|
public function getBankDataAttribute()
|
2016-05-11 00:46:32 +02:00
|
|
|
{
|
|
|
|
if (!$this->routing_number) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
return static::lookupBankData($this->routing_number);
|
|
|
|
}
|
|
|
|
|
2016-05-24 20:16:42 +02:00
|
|
|
public function getBankNameAttribute($bank_name)
|
|
|
|
{
|
|
|
|
if ($bank_name) {
|
|
|
|
return $bank_name;
|
|
|
|
}
|
|
|
|
$bankData = $this->bank_data;
|
|
|
|
|
|
|
|
return $bankData?$bankData->name:null;
|
|
|
|
}
|
|
|
|
|
2016-05-11 01:17:55 +02:00
|
|
|
public function getLast4Attribute($value)
|
|
|
|
{
|
|
|
|
return $value ? str_pad($value, 4, '0', STR_PAD_LEFT) : null;
|
|
|
|
}
|
|
|
|
|
2016-05-11 00:46:32 +02:00
|
|
|
public function scopeScope($query, $publicId = false, $accountId = false, $accountGatewayTokenId = false)
|
|
|
|
{
|
|
|
|
$query = parent::scopeScope($query, $publicId, $accountId);
|
|
|
|
|
|
|
|
if ($accountGatewayTokenId) {
|
|
|
|
$query->where($this->getTable() . '.account_gateway_token_id', '=', $accountGatewayTokenId);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function lookupBankData($routingNumber) {
|
|
|
|
$cached = Cache::get('bankData:'.$routingNumber);
|
|
|
|
|
|
|
|
if ($cached != null) {
|
|
|
|
return $cached == false ? null : $cached;
|
|
|
|
}
|
|
|
|
|
|
|
|
$dataPath = base_path('vendor/gatepay/FedACHdir/FedACHdir.txt');
|
|
|
|
|
|
|
|
if (!file_exists($dataPath) || !$size = filesize($dataPath)) {
|
|
|
|
return 'Invalid data file';
|
|
|
|
}
|
|
|
|
|
|
|
|
$lineSize = 157;
|
|
|
|
$numLines = $size/$lineSize;
|
|
|
|
|
|
|
|
if ($numLines % 1 != 0) {
|
|
|
|
// The number of lines should be an integer
|
|
|
|
return 'Invalid data file';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Format: http://www.sco.ca.gov/Files-21C/Bank_Master_Interface_Information_Package.pdf
|
|
|
|
$file = fopen($dataPath, 'r');
|
|
|
|
|
|
|
|
// Binary search
|
|
|
|
$low = 0;
|
|
|
|
$high = $numLines - 1;
|
|
|
|
while ($low <= $high) {
|
|
|
|
$mid = floor(($low + $high) / 2);
|
|
|
|
|
|
|
|
fseek($file, $mid * $lineSize);
|
|
|
|
$thisNumber = fread($file, 9);
|
|
|
|
|
|
|
|
if ($thisNumber > $routingNumber) {
|
|
|
|
$high = $mid - 1;
|
|
|
|
} else if ($thisNumber < $routingNumber) {
|
|
|
|
$low = $mid + 1;
|
|
|
|
} else {
|
|
|
|
$data = new \stdClass();
|
|
|
|
$data->routing_number = $thisNumber;
|
|
|
|
|
|
|
|
fseek($file, 26, SEEK_CUR);
|
|
|
|
|
|
|
|
$data->name = trim(fread($file, 36));
|
|
|
|
$data->address = trim(fread($file, 36));
|
|
|
|
$data->city = trim(fread($file, 20));
|
|
|
|
$data->state = fread($file, 2);
|
|
|
|
$data->zip = fread($file, 5).'-'.fread($file, 4);
|
|
|
|
$data->phone = fread($file, 10);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($data)) {
|
|
|
|
Cache::put('bankData:'.$routingNumber, $data, 5);
|
|
|
|
return $data;
|
|
|
|
} else {
|
|
|
|
Cache::put('bankData:'.$routingNumber, false, 5);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2016-05-24 20:16:42 +02:00
|
|
|
|
2016-05-25 04:49:06 +02:00
|
|
|
public function requiresDelayedAutoBill(){
|
2016-05-26 21:22:09 +02:00
|
|
|
return $this->payment_type_id == PAYMENT_TYPE_ACH;
|
2016-05-24 20:16:42 +02:00
|
|
|
}
|
2016-05-11 00:46:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
PaymentMethod::deleting(function($paymentMethod) {
|
|
|
|
$accountGatewayToken = $paymentMethod->account_gateway_token;
|
|
|
|
if ($accountGatewayToken->default_payment_method_id == $paymentMethod->id) {
|
|
|
|
$newDefault = $accountGatewayToken->payment_methods->first(function($i, $paymentMethdod) use ($accountGatewayToken){
|
|
|
|
return $paymentMethdod->id != $accountGatewayToken->default_payment_method_id;
|
|
|
|
});
|
|
|
|
$accountGatewayToken->default_payment_method_id = $newDefault ? $newDefault->id : null;
|
|
|
|
$accountGatewayToken->save();
|
|
|
|
}
|
|
|
|
});
|