From 74c335ea3ea796a5b93962249a702f61271a3941 Mon Sep 17 00:00:00 2001 From: Remi Jannel Date: Fri, 12 Oct 2018 09:52:43 -0700 Subject: [PATCH] Add support for the Person resource --- init.php | 1 + lib/Account.php | 64 +++++++++++++++++++++++++ lib/Person.php | 91 ++++++++++++++++++++++++++++++++++++ lib/Util/Util.php | 1 + tests/Stripe/AccountTest.php | 59 +++++++++++++++++++++++ tests/Stripe/PersonTest.php | 59 +++++++++++++++++++++++ 6 files changed, 275 insertions(+) create mode 100644 lib/Person.php create mode 100644 tests/Stripe/PersonTest.php diff --git a/init.php b/init.php index 1ed28257d..66bd360d1 100644 --- a/init.php +++ b/init.php @@ -95,6 +95,7 @@ require(dirname(__FILE__) . '/lib/OrderReturn.php'); require(dirname(__FILE__) . '/lib/PaymentIntent.php'); require(dirname(__FILE__) . '/lib/Payout.php'); +require(dirname(__FILE__) . '/lib/Person.php'); require(dirname(__FILE__) . '/lib/Plan.php'); require(dirname(__FILE__) . '/lib/Product.php'); require(dirname(__FILE__) . '/lib/Recipient.php'); diff --git a/lib/Account.php b/lib/Account.php index f5c450aef..2a03e6eb7 100644 --- a/lib/Account.php +++ b/lib/Account.php @@ -67,6 +67,7 @@ public static function getSavedNestedResources() const PATH_EXTERNAL_ACCOUNTS = '/external_accounts'; const PATH_LOGIN_LINKS = '/login_links'; + const PATH_PERSONS = '/persons'; public function instanceUrl() { @@ -197,6 +198,69 @@ public static function createLoginLink($id, $params = null, $opts = null) return self::_createNestedResource($id, static::PATH_LOGIN_LINKS, $params, $opts); } + /** + * @param array|null $id The ID of the account on which to create the person. + * @param array|null $params + * @param array|string|null $opts + * + * @return Person + */ + public static function createPerson($id, $params = null, $opts = null) + { + return self::_createNestedResource($id, static::PATH_PERSONS, $params, $opts); + } + + /** + * @param array|null $id The ID of the account to which the person belongs. + * @param array|null $personId The ID of the person to retrieve. + * @param array|null $params + * @param array|string|null $opts + * + * @return Person + */ + public static function retrievePerson($id, $personId, $params = null, $opts = null) + { + return self::_retrieveNestedResource($id, static::PATH_PERSONS, $personId, $params, $opts); + } + + /** + * @param array|null $id The ID of the account to which the person belongs. + * @param array|null $personId The ID of the person to update. + * @param array|null $params + * @param array|string|null $opts + * + * @return Person + */ + public static function updatePerson($id, $personId, $params = null, $opts = null) + { + return self::_updateNestedResource($id, static::PATH_PERSONS, $personId, $params, $opts); + } + + /** + * @param array|null $id The ID of the account to which the person belongs. + * @param array|null $personId The ID of the person to delete. + * @param array|null $params + * @param array|string|null $opts + * + * @return Person + */ + public static function deletePerson($id, $personId, $params = null, $opts = null) + { + return self::_deleteNestedResource($id, static::PATH_PERSONS, $personId, $params, $opts); + } + + /** + * @param array|null $id The ID of the account on which to retrieve the persons. + * @param array|null $params + * @param array|string|null $opts + * + * @return Person + */ + public static function allPersons($id, $params = null, $opts = null) + { + return self::_allNestedResources($id, static::PATH_PERSONS, $params, $opts); + } + public function serializeParameters($force = false) { $update = parent::serializeParameters($force); diff --git a/lib/Person.php b/lib/Person.php new file mode 100644 index 000000000..b08193e86 --- /dev/null +++ b/lib/Person.php @@ -0,0 +1,91 @@ +retrievePerson('person_id') instead."; + throw new Error\InvalidRequest($msg, null); + } + + /** + * @param string $_id + * @param array|null $_params + * @param array|string|null $_options + * + * @throws \Stripe\Error\InvalidRequest + */ + public static function update($_id, $_params = null, $_options = null) + { + $msg = "Persons cannot be accessed without an account ID. " . + "Retrieve a Person using \$account->retrievePerson('person_id') instead."; + throw new Error\InvalidRequest($msg, null); + } +} diff --git a/lib/Util/Util.php b/lib/Util/Util.php index 7e64536bf..d1db0858b 100644 --- a/lib/Util/Util.php +++ b/lib/Util/Util.php @@ -109,6 +109,7 @@ public static function convertToStripeObject($resp, $opts) \Stripe\OrderReturn::OBJECT_NAME => 'Stripe\\OrderReturn', \Stripe\PaymentIntent::OBJECT_NAME => 'Stripe\\PaymentIntent', \Stripe\Payout::OBJECT_NAME => 'Stripe\\Payout', + \Stripe\Person::OBJECT_NAME => 'Stripe\\Person', \Stripe\Plan::OBJECT_NAME => 'Stripe\\Plan', \Stripe\Product::OBJECT_NAME => 'Stripe\\Product', \Stripe\Recipient::OBJECT_NAME => 'Stripe\\Recipient', diff --git a/tests/Stripe/AccountTest.php b/tests/Stripe/AccountTest.php index 0e7b2fe17..e0c23f735 100644 --- a/tests/Stripe/AccountTest.php +++ b/tests/Stripe/AccountTest.php @@ -6,6 +6,7 @@ class AccountTest extends TestCase { const TEST_RESOURCE_ID = 'acct_123'; const TEST_EXTERNALACCOUNT_ID = 'ba_123'; + const TEST_PERSON_ID = 'person_123'; public function testIsListable() { @@ -180,6 +181,64 @@ public function testCanCreateLoginLink() $this->assertInstanceOf("Stripe\\LoginLink", $resource); } + public function testCanCreatePerson() + { + $this->expectsRequest( + 'post', + '/v1/accounts/' . self::TEST_RESOURCE_ID . '/persons' + ); + $resource = Account::createPerson(self::TEST_RESOURCE_ID, [ + "dob" => [ + "day" => 1, + "month" => 1, + "year" => 1980 + ] + ]); + $this->assertInstanceOf("Stripe\\Person", $resource); + } + + public function testCanRetrievePerson() + { + $this->expectsRequest( + 'get', + '/v1/accounts/' . self::TEST_RESOURCE_ID . '/persons/' . self::TEST_PERSON_ID + ); + $resource = Account::retrievePerson(self::TEST_RESOURCE_ID, self::TEST_PERSON_ID); + $this->assertInstanceOf("Stripe\\Person", $resource); + } + + public function testCanUpdatePerson() + { + $this->expectsRequest( + 'post', + '/v1/accounts/' . self::TEST_RESOURCE_ID . '/persons/' . self::TEST_PERSON_ID + ); + $resource = Account::updatePerson(self::TEST_RESOURCE_ID, self::TEST_PERSON_ID, [ + "first_name" => "First name", + ]); + $this->assertInstanceOf("Stripe\\Person", $resource); + } + + public function testCanDeletePerson() + { + $this->expectsRequest( + 'delete', + '/v1/accounts/' . self::TEST_RESOURCE_ID . '/persons/' . self::TEST_PERSON_ID + ); + $resource = Account::deletePerson(self::TEST_RESOURCE_ID, self::TEST_PERSON_ID); + $this->assertTrue($resource->deleted); + } + + public function testCanListPersons() + { + $this->expectsRequest( + 'get', + '/v1/accounts/' . self::TEST_RESOURCE_ID . '/persons' + ); + $resources = Account::allPersons(self::TEST_RESOURCE_ID); + $this->assertTrue(is_array($resources->data)); + } + public function testSerializeNewAdditionalOwners() { $obj = Util\Util::convertToStripeObject([ diff --git a/tests/Stripe/PersonTest.php b/tests/Stripe/PersonTest.php new file mode 100644 index 000000000..74c9c3403 --- /dev/null +++ b/tests/Stripe/PersonTest.php @@ -0,0 +1,59 @@ +assertSame( + "/v1/accounts/" . self::TEST_ACCOUNT_ID . "/persons/" . self::TEST_RESOURCE_ID, + $resource->instanceUrl() + ); + } + + /** + * @expectedException \Stripe\Error\InvalidRequest + */ + public function testIsNotDirectlyRetrievable() + { + Person::retrieve(self::TEST_RESOURCE_ID); + } + + public function testIsSaveable() + { + $resource = \Stripe\Account::retrievePerson(self::TEST_ACCOUNT_ID, self::TEST_RESOURCE_ID); + $resource->first_name = "value"; + $this->expectsRequest( + 'post', + '/v1/accounts/' . self::TEST_ACCOUNT_ID . '/persons/' . self::TEST_RESOURCE_ID + ); + $resource->save(); + $this->assertSame("Stripe\\Person", get_class($resource)); + } + + /** + * @expectedException \Stripe\Error\InvalidRequest + */ + public function testIsNotDirectlyUpdatable() + { + Person::update(self::TEST_RESOURCE_ID, [ + "first_name" => ["John"], + ]); + } + + public function testIsDeletable() + { + $resource = \Stripe\Account::retrievePerson(self::TEST_ACCOUNT_ID, self::TEST_RESOURCE_ID); + $this->expectsRequest( + 'delete', + '/v1/accounts/' . self::TEST_ACCOUNT_ID . '/persons/' . self::TEST_RESOURCE_ID + ); + $resource->delete(); + $this->assertSame("Stripe\\Person", get_class($resource)); + } +}