php-bitpay-client/examples/CreatePayout.php
2019-02-13 13:46:22 +01:00

60 lines
1.7 KiB
PHP

<?php
/**
* Copyright (c) 2014-2015 BitPay
*/
/**
* WARNING - This example will NOT work until you have generated your public
* keys and also see the documentation on how to save those keys.
*
* Also please be aware that you CANNOT create an invoice until you have paired
* the keys and received a token back. The token is usesd with the request.
*/
require __DIR__ . '/../vendor/autoload.php';
$time = gmdate("Y-m-d\TH:i:s\.", 1414691179)."000Z";
$token = new \Bitpay\Token();
$token
->setFacade('payroll')
->setToken('<your payroll facade-enable token>'); //this is a special api that requires a explicit payroll relationship with BitPay
$instruction1 = new \Bitpay\PayoutInstruction();
$instruction1
->setAmount(100)
->setAddress('2NA5EVH9HHHhM5RxSEWf54gP4v397EmFTxi')
->setLabel('Paying Chris');
$payout = new \Bitpay\Payout();
$payout
->setEffectiveDate($time)
->setAmount(100)
->setCurrency(new \Bitpay\Currency('USD'))
->setPricingMethod('bitcoinbestbuy')
->setReference('a reference, can be json')
->setNotificationEmail('me@example.com')
->setNotificationUrl('https://example.com/ipn.php')
->setToken($token)
->addInstruction($instruction1);
$private = new \Bitpay\PrivateKey();
$private->setHex('662be90968bc659873d723374213fa5bf7a30c24f0f0713aa798eb7daa7230fc'); //this is your private key in some form (see GetKeys.php)
$public = new \Bitpay\PublicKey();
$public->generate($private);
$adapter = new \Bitpay\Client\Adapter\CurlAdapter();
$bitpay = new \Bitpay\Bitpay();
$client = new \Bitpay\Client\Client();
$client->setPrivateKey($private);
$client->setPublicKey($public);
$client->setUri('https://btcpay.server/');
$client->setAdapter($adapter);
$client->createPayout($payout);
print_r($payout);