Skip to content

Commit

Permalink
Merge pull request #131 from square/release/36.0.0.20240417
Browse files Browse the repository at this point in the history
Generated PR for Release: 36.0.0.20240417
  • Loading branch information
daphnechiu authored Apr 16, 2024
2 parents 47f9e6f + e168122 commit 1f3ecd0
Show file tree
Hide file tree
Showing 15 changed files with 18 additions and 219 deletions.
4 changes: 4 additions & 0 deletions .github/pull_request_template.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# **ATTENTION**
This repository **cannot** accept Pull Requests. If you wish to proceed with opening this PR, please understand that your code **will not** be pulled into this repository. Consider opening an issue which lays out the problem instead. Thank you very much for your efforts and highlighting issues!

Please direct all technical support questions, feature requests, API-related issues, and general discussions to our Square-supported developer channels. For public support, [join us in our Square Developer Discord server](https://discord.com/invite/squaredev) or [post in our Developer Forums](https://developer.squareup.com/forums). For private support, [contact our Developer Success Engineers](https://squareup.com/help/us/en/contact?panel=BF53A9C8EF68) directly.
71 changes: 0 additions & 71 deletions doc/api/o-auth.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,82 +10,11 @@ o_auth_api = client.o_auth

## Methods

* [Renew Token](../../doc/api/o-auth.md#renew-token)
* [Revoke Token](../../doc/api/o-auth.md#revoke-token)
* [Obtain Token](../../doc/api/o-auth.md#obtain-token)
* [Retrieve Token Status](../../doc/api/o-auth.md#retrieve-token-status)


# Renew Token

**This endpoint is deprecated.**

`RenewToken` is deprecated. For information about refreshing OAuth access tokens, see
[Migrate from Renew to Refresh OAuth Tokens](https://developer.squareup.com/docs/oauth-api/migrate-to-refresh-tokens).

Renews an OAuth access token before it expires.

OAuth access tokens besides your application's personal access token expire after 30 days.
You can also renew expired tokens within 15 days of their expiration.
You cannot renew an access token that has been expired for more than 15 days.
Instead, the associated user must recomplete the OAuth flow from the beginning.

__Important:__ The `Authorization` header for this endpoint must have the
following format:

```
Authorization: Client APPLICATION_SECRET
```

Replace `APPLICATION_SECRET` with the application secret on the **Credentials**
page in the [Developer Dashboard](https://developer.squareup.com/apps).

:information_source: **Note** This endpoint does not require authentication.

```python
def renew_token(self,
client_id,
body,
authorization)
```

## Parameters

| Parameter | Type | Tags | Description |
| --- | --- | --- | --- |
| `client_id` | `str` | Template, Required | Your application ID, which is available on the **OAuth** page in the [Developer Dashboard](https://developer.squareup.com/apps). |
| `body` | [`Renew Token Request`](../../doc/models/renew-token-request.md) | Body, Required | An object containing the fields to POST for the request.<br><br>See the corresponding object definition for field details. |
| `authorization` | `str` | Header, Required | Client APPLICATION_SECRET |

## Response Type

This method returns a `ApiResponse` instance. The `body` property of this instance returns the response data which is of type [`Renew Token Response`](../../doc/models/renew-token-response.md).

## Example Usage

```python
client_id = 'client_id8'

body = {
'access_token': 'ACCESS_TOKEN'
}

authorization = 'Client CLIENT_SECRET'

result = o_auth_api.renew_token(
client_id,
body,
authorization
)
print(result)

if result.is_success():
print(result.body)
elif result.is_error():
print(result.errors)
```


# Revoke Token

Revokes an access token generated with the OAuth flow.
Expand Down
6 changes: 3 additions & 3 deletions doc/client.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ The following parameters are configurable for the API Client:

| Parameter | Type | Description |
| --- | --- | --- |
| `square_version` | `str` | Square Connect API versions<br>*Default*: `'2024-03-20'` |
| `square_version` | `str` | Square Connect API versions<br>*Default*: `'2024-04-17'` |
| `custom_url` | `str` | Sets the base URL requests are made to. Defaults to `https://connect.squareup.com`<br>*Default*: `'https://connect.squareup.com'` |
| `environment` | `string` | The API environment. <br> **Default: `production`** |
| `http_client_instance` | `HttpClient` | The Http Client passed from the sdk user for making requests |
Expand All @@ -24,7 +24,7 @@ The API client can be initialized as follows:

```python
client = Client(
square_version='2024-03-20',
square_version='2024-04-17',
bearer_auth_credentials=BearerAuthCredentials(
access_token='AccessToken'
)
Expand All @@ -51,7 +51,7 @@ from square.http.auth.o_auth_2 import BearerAuthCredentials
from square.client import Client

client = Client(
square_version='2024-03-20',
square_version='2024-04-17',
bearer_auth_credentials=BearerAuthCredentials(
access_token='AccessToken'
)
Expand Down
2 changes: 1 addition & 1 deletion doc/models/catalog-custom-attribute-definition.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ to store any sensitive information (personally identifiable information, card de
| `name` | `str` | Required | The name of this definition for API and seller-facing UI purposes.<br>The name must be unique within the (merchant, application) pair. Required.<br>May not be empty and may not exceed 255 characters. Can be modified after creation.<br>**Constraints**: *Minimum Length*: `1`, *Maximum Length*: `255` |
| `description` | `str` | Optional | Seller-oriented description of the meaning of this Custom Attribute,<br>any constraints that the seller should observe, etc. May be displayed as a tooltip in Square UIs.<br>**Constraints**: *Maximum Length*: `255` |
| `source_application` | [`Source Application`](../../doc/models/source-application.md) | Optional | Represents information about the application used to generate a change. |
| `allowed_object_types` | [`str (List Catalog Object Type)`](../../doc/models/catalog-object-type.md) | Required | The set of `CatalogObject` types that this custom atttribute may be applied to.<br>Currently, only `ITEM`, `ITEM_VARIATION`, and `MODIFIER` are allowed. At least one type must be included.<br>See [CatalogObjectType](#type-catalogobjecttype) for possible values |
| `allowed_object_types` | [`str (List Catalog Object Type)`](../../doc/models/catalog-object-type.md) | Required | The set of `CatalogObject` types that this custom atttribute may be applied to.<br>Currently, only `ITEM`, `ITEM_VARIATION`, `MODIFIER`, `MODIFIER_LIST`, and `CATEGORY` are allowed. At least one type must be included.<br>See [CatalogObjectType](#type-catalogobjecttype) for possible values |
| `seller_visibility` | [`str (Catalog Custom Attribute Definition Seller Visibility)`](../../doc/models/catalog-custom-attribute-definition-seller-visibility.md) | Optional | Defines the visibility of a custom attribute to sellers in Square<br>client applications, Square APIs or in Square UIs (including Square Point<br>of Sale applications and Square Dashboard). |
| `app_visibility` | [`str (Catalog Custom Attribute Definition App Visibility)`](../../doc/models/catalog-custom-attribute-definition-app-visibility.md) | Optional | Defines the visibility of a custom attribute to applications other than their<br>creating application. |
| `string_config` | [`Catalog Custom Attribute Definition String Config`](../../doc/models/catalog-custom-attribute-definition-string-config.md) | Optional | Configuration associated with Custom Attribute Definitions of type `STRING`. |
Expand Down
2 changes: 1 addition & 1 deletion doc/models/order-line-item-tax.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ contributes to the order subtotal.
| `catalog_version` | `long\|int` | Optional | The version of the catalog object that this tax references. |
| `name` | `str` | Optional | The tax's name.<br>**Constraints**: *Maximum Length*: `255` |
| `type` | [`str (Order Line Item Tax Type)`](../../doc/models/order-line-item-tax-type.md) | Optional | Indicates how the tax is applied to the associated line item or order. |
| `percentage` | `str` | Optional | The percentage of the tax, as a string representation of a decimal<br>number. For example, a value of `"7.25"` corresponds to a percentage of<br>7.25%.<br><br>Either `percentage` or `amount_money` should be set, but not both.<br>**Constraints**: *Maximum Length*: `10` |
| `percentage` | `str` | Optional | The percentage of the tax, as a string representation of a decimal<br>number. For example, a value of `"7.25"` corresponds to a percentage of<br>7.25%.<br>**Constraints**: *Maximum Length*: `10` |
| `metadata` | `Dict[str, str]` | Optional | Application-defined data attached to this tax. Metadata fields are intended<br>to store descriptive references or associations with an entity in another system or store brief<br>information about the object. Square does not process this field; it only stores and returns it<br>in relevant API calls. Do not use metadata to store any sensitive information (such as personally<br>identifiable information or card details).<br><br>Keys written by applications must be 60 characters or less and must be in the character set<br>`[a-zA-Z0-9_-]`. Entries can also include metadata generated by Square. These keys are prefixed<br>with a namespace, separated from the key with a ':' character.<br><br>Values have a maximum length of 255 characters.<br><br>An application can have up to 10 entries per metadata field.<br><br>Entries written by applications are private and can only be read or modified by the same<br>application.<br><br>For more information, see [Metadata](https://developer.squareup.com/docs/build-basics/metadata). |
| `applied_money` | [`Money`](../../doc/models/money.md) | Optional | Represents an amount of money. `Money` fields can be signed or unsigned.<br>Fields that do not explicitly define whether they are signed or unsigned are<br>considered unsigned and can only hold positive amounts. For signed fields, the<br>sign of the value indicates the purpose of the money transfer. See<br>[Working with Monetary Amounts](https://developer.squareup.com/docs/build-basics/working-with-monetary-amounts)<br>for more information. |
| `scope` | [`str (Order Line Item Tax Scope)`](../../doc/models/order-line-item-tax-scope.md) | Optional | Indicates whether this is a line-item or order-level tax. |
Expand Down
4 changes: 2 additions & 2 deletions doc/models/order.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ itemization data.
| `tenders` | [`List Tender`](../../doc/models/tender.md) | Optional | The tenders that were used to pay for the order. |
| `refunds` | [`List Refund`](../../doc/models/refund.md) | Optional | The refunds that are part of this order. |
| `metadata` | `Dict[str, str]` | Optional | Application-defined data attached to this order. Metadata fields are intended<br>to store descriptive references or associations with an entity in another system or store brief<br>information about the object. Square does not process this field; it only stores and returns it<br>in relevant API calls. Do not use metadata to store any sensitive information (such as personally<br>identifiable information or card details).<br><br>Keys written by applications must be 60 characters or less and must be in the character set<br>`[a-zA-Z0-9_-]`. Entries can also include metadata generated by Square. These keys are prefixed<br>with a namespace, separated from the key with a ':' character.<br><br>Values have a maximum length of 255 characters.<br><br>An application can have up to 10 entries per metadata field.<br><br>Entries written by applications are private and can only be read or modified by the same<br>application.<br><br>For more information, see [Metadata](https://developer.squareup.com/docs/build-basics/metadata). |
| `created_at` | `str` | Optional | The timestamp for when the order was created, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). |
| `updated_at` | `str` | Optional | The timestamp for when the order was last updated, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). |
| `created_at` | `str` | Optional | The timestamp for when the order was created, at server side, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). |
| `updated_at` | `str` | Optional | The timestamp for when the order was last updated, at server side, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). |
| `closed_at` | `str` | Optional | The timestamp for when the order reached a terminal [state](entity:OrderState), in RFC 3339 format (for example "2016-09-04T23:59:33.123Z"). |
| `state` | [`str (Order State)`](../../doc/models/order-state.md) | Optional | The state of the order. |
| `version` | `int` | Optional | The version number, which is incremented each time an update is committed to the order.<br>Orders not created through the API do not include a version number and<br>therefore cannot be updated.<br><br>[Read more about working with versions](https://developer.squareup.com/docs/orders-api/manage-orders/update-orders). |
Expand Down
21 changes: 0 additions & 21 deletions doc/models/renew-token-request.md

This file was deleted.

31 changes: 0 additions & 31 deletions doc/models/renew-token-response.md

This file was deleted.

4 changes: 2 additions & 2 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@ requires = ["setuptools>=61.0"]
[project]
name = "squareup"
description = "Use Square APIs to manage and run business including payment, customer, product, inventory, and employee management."
version = "35.1.0.20240320"
version = "36.0.0.20240417"
readme = "README.md"
requires-python = ">=3.7"
authors = [{name = "Square Developer Platform", email = "developers@squareup.com"}]
dependencies = ["apimatic-core~=0.2.0", "apimatic-core-interfaces~=0.1.0", "apimatic-requests-client-adapter~=0.1.0", "python-dateutil~=2.8.1", "deprecation~=2.1"]
dependencies = ["apimatic-core~=0.2.0", "apimatic-core-interfaces~=0.1.0", "apimatic-requests-client-adapter~=0.1.0", "deprecation~=2.1"]
[project.optional-dependencies]
testutils = ["pytest>=7.2.2"]
[tool.setuptools.packages.find]
Expand Down
1 change: 0 additions & 1 deletion requirements.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
apimatic-core~=0.2.0
apimatic-core-interfaces~=0.1.0
apimatic-requests-client-adapter~=0.1.0
python-dateutil~=2.8.1
deprecation~=2.1
2 changes: 1 addition & 1 deletion square/api/base_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ class BaseApi(object):

@staticmethod
def user_agent():
return 'Square-Python-SDK/35.1.0.20240320 ({api-version}) {engine}/{engine-version} ({os-info}) {detail}'
return 'Square-Python-SDK/36.0.0.20240417 ({api-version}) {engine}/{engine-version} ({os-info}) {detail}'

@staticmethod
def user_agent_parameters():
Expand Down
80 changes: 0 additions & 80 deletions square/api/o_auth_api.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
# -*- coding: utf-8 -*-

from deprecation import deprecated
from square.api_helper import APIHelper
from square.http.api_response import ApiResponse
from square.api.base_api import BaseApi
Expand All @@ -16,85 +15,6 @@ class OAuthApi(BaseApi):
def __init__(self, config):
super(OAuthApi, self).__init__(config)

@deprecated()
def renew_token(self,
client_id,
body,
authorization):
"""Does a POST request to /oauth2/clients/{client_id}/access-token/renew.
`RenewToken` is deprecated. For information about refreshing OAuth
access tokens, see
[Migrate from Renew to Refresh OAuth
Tokens](https://developer.squareup.com/docs/oauth-api/migrate-to-refres
h-tokens).
Renews an OAuth access token before it expires.
OAuth access tokens besides your application's personal access token
expire after 30 days.
You can also renew expired tokens within 15 days of their expiration.
You cannot renew an access token that has been expired for more than
15 days.
Instead, the associated user must recomplete the OAuth flow from the
beginning.
__Important:__ The `Authorization` header for this endpoint must have
the
following format:
```
Authorization: Client APPLICATION_SECRET
```
Replace `APPLICATION_SECRET` with the application secret on the
**Credentials**
page in the [Developer
Dashboard](https://developer.squareup.com/apps).
Args:
client_id (str): Your application ID, which is available on the
**OAuth** page in the [Developer
Dashboard](https://developer.squareup.com/apps).
body (RenewTokenRequest): An object containing the fields to POST
for the request. See the corresponding object definition for
field details.
authorization (str): Client APPLICATION_SECRET
Returns:
ApiResponse: An object with the response value as well as other
useful information such as status codes and headers. Success
Raises:
APIException: When an error occurs while fetching the data from
the remote API. This exception includes the HTTP Response
code, an error message, and the HTTP body that was received in
the request.
"""

return super().new_api_call_builder.request(
RequestBuilder().server('default')
.path('/oauth2/clients/{client_id}/access-token/renew')
.http_method(HttpMethodEnum.POST)
.template_param(Parameter()
.key('client_id')
.value(client_id)
.should_encode(True))
.header_param(Parameter()
.key('Content-Type')
.value('application/json'))
.body_param(Parameter()
.value(body))
.header_param(Parameter()
.key('Authorization')
.value(authorization))
.header_param(Parameter()
.key('accept')
.value('application/json'))
.body_serializer(APIHelper.json_serialize)
).response(
ResponseHandler()
.deserializer(APIHelper.json_deserialize)
.is_api_response(True)
.convertor(ApiResponse.create)
).execute()

def revoke_token(self,
body,
authorization):
Expand Down
Loading

0 comments on commit 1f3ecd0

Please sign in to comment.