Current File : /home/tradevaly/prioyshi.com/project/vendor/cartalyst/stripe/src/Api/Sources.php |
<?php
/**
* Part of the Stripe package.
*
* NOTICE OF LICENSE
*
* Licensed under the 3-clause BSD License.
*
* This source file is subject to the 3-clause BSD License that is
* bundled with this package in the LICENSE file.
*
* @package Stripe
* @version 2.4.4
* @author Cartalyst LLC
* @license BSD License (3-clause)
* @copyright (c) 2011-2021, Cartalyst LLC
* @link https://cartalyst.com
*/
namespace Cartalyst\Stripe\Api;
class Sources extends Api
{
/**
* Creates a new source on the given customer.
*
* @param string|array $parameters
* @return array
*/
public function create($parameters = [])
{
return $this->_post('sources', $parameters);
}
/**
* Retrieves an existing source.
*
* @param string $sourceId
* @return array
*/
public function find($sourceId)
{
return $this->_get("sources/{$sourceId}");
}
/**
* Updates an existing source.
*
* @param string $sourceId
* @param array $parameters
* @return array
*/
public function update($sourceId, array $parameters = [])
{
return $this->_post("sources/{$sourceId}", $parameters);
}
/**
* Attaches the given source to the customer.
*
* @param string $customerId
* @param string $sourceId
* @return array
*/
public function attach($customerId, $sourceId)
{
return $this->_post("customers/{$customerId}/sources", [
'source' => $sourceId,
]);
}
/**
* Detaches the given source from the customer.
*
* @param string $customerId
* @param string $sourceId
* @return array
*/
public function detach($customerId, $sourceId)
{
return $this->_delete("customers/{$customerId}/sources/{$sourceId}");
}
/**
* Lists all sources from the given customer.
*
* @param string $customerId
* @param array $parameters
* @return array
*/
public function all($customerId, array $parameters = [])
{
return $this->_get("customers/{$customerId}/sources", $parameters);
}
}