Skip to content

Commit

Permalink
查询企业付款接口参数调整,加入企业付款到银行卡接口(RSA 参数加密待完成) (#1019)
Browse files Browse the repository at this point in the history
  • Loading branch information
tianyong90 authored and overtrue committed Nov 10, 2017
1 parent a95e948 commit 47147a0
Show file tree
Hide file tree
Showing 2 changed files with 86 additions and 12 deletions.
50 changes: 43 additions & 7 deletions src/Payment/Transfer/Client.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,30 +21,31 @@
class Client extends BaseClient
{
/**
* Query MerchantPay.
* Query MerchantPay to balance.
*
* @param array $params
* @param string $partnetTradeNo
*
* @return \Psr\Http\Message\ResponseInterface|\EasyWeChat\Kernel\Support\Collection|array|object|string
*/
public function info(array $params)
public function queryBalanceOrder(string $partnetTradeNo)
{
$base = [
$params = [
'appid' => $this->app['config']->app_id,
'mch_id' => $this->app['config']->mch_id,
'partner_trade_no' => $partnetTradeNo,
];

return $this->safeRequest('mmpaymkttransfers/gettransferinfo', array_merge($base, $params));
return $this->safeRequest('mmpaymkttransfers/gettransferinfo', $params);
}

/**
* Send MerchantPay.
* Send MerchantPay to balance.
*
* @param array $params
*
* @return \Psr\Http\Message\ResponseInterface|\EasyWeChat\Kernel\Support\Collection|array|object|string
*/
public function send(array $params)
public function toBalance(array $params)
{
$base = [
'mchid' => $this->app['config']->mch_id,
Expand All @@ -53,4 +54,39 @@ public function send(array $params)

return $this->safeRequest('mmpaymkttransfers/promotion/transfers', array_merge($base, $params));
}

/**
* Query MerchantPay order to BankCard.
*
* @param string $partnetTradeNo
*
* @return \Psr\Http\Message\ResponseInterface|\EasyWeChat\Kernel\Support\Collection|array|object|string
*/
public function queryBankCardOrder(string $partnetTradeNo)
{
$params = [
'mch_id' => $this->app['config']->mch_id,
'partner_trade_no' => $partnetTradeNo,
];

return $this->safeRequest('mmpaysptrans/query_bank', $params);
}

/**
* Send MerchantPay to BankCard.
*
* @param array $params
*
* @return \Psr\Http\Message\ResponseInterface|\EasyWeChat\Kernel\Support\Collection|array|object|string
*/
public function toBankCard(array $params)
{
$base = [
'mchid' => $this->app['config']->mch_id,
];

// TODO: RSA 加密 enc_bank_no, enc_true_name

return $this->safeRequest('mmpaysptrans/pay_bank', array_merge($base, $params));
}
}
48 changes: 43 additions & 5 deletions tests/Payment/Transfer/ClientTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,13 @@ private function makeApp($config = [])
], $config));
}

public function testInfo()
public function testQueryBalanceOrder()
{
$app = $this->makeApp();

$client = $this->mockApiClient(Client::class, ['safeRequest'], $app)->makePartial();

$params = ['partner_trade_no' => 'bar'];
$partnerTradeNo = 'bar';

$client->expects()->safeRequest('mmpaymkttransfers/gettransferinfo', \Mockery::on(function ($paramsForSafeRequest) use ($app) {
$this->assertSame($paramsForSafeRequest['partner_trade_no'], 'bar');
Expand All @@ -49,10 +49,10 @@ public function testInfo()
return true;
}))->andReturn('mock-result');

$this->assertSame('mock-result', $client->info($params));
$this->assertSame('mock-result', $client->queryBalanceOrder($partnerTradeNo));
}

public function testSend()
public function testToBalance()
{
$app = $this->makeApp();

Expand All @@ -70,6 +70,44 @@ public function testSend()
return true;
}))->andReturn('mock-result');

$this->assertSame('mock-result', $client->send($params));
$this->assertSame('mock-result', $client->toBalance($params));
}

public function testQueryBankCardOrder()
{
$app = $this->makeApp();

$client = $this->mockApiClient(Client::class, ['safeRequest'], $app)->makePartial();

$partnerTradeNo = 'bar';

$client->expects()->safeRequest('mmpaysptrans/query_bank', \Mockery::on(function ($paramsForSafeRequest) use ($app) {
$this->assertSame($paramsForSafeRequest['partner_trade_no'], 'bar');
$this->assertSame($paramsForSafeRequest['mch_id'], $app['config']->mch_id);

return true;
}))->andReturn('mock-result');

$this->assertSame('mock-result', $client->queryBankCardOrder($partnerTradeNo));
}

public function testToBackCard()
{
$app = $this->makeApp();

$client = $this->mockApiClient(Client::class, ['send', 'safeRequest'], $app)->makePartial();

$params = [
'foo' => 'bar',
];

$client->expects()->safeRequest('mmpaysptrans/pay_bank', \Mockery::on(function ($paramsForSafeRequest) use ($params, $app) {
$this->assertSame($params['foo'], $paramsForSafeRequest['foo']);
$this->assertSame($paramsForSafeRequest['mchid'], $app['config']->mch_id);

return true;
}))->andReturn('mock-result');

$this->assertSame('mock-result', $client->toBankCard($params));
}
}

0 comments on commit 47147a0

Please sign in to comment.