Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: docstrings for Pager and RequestOptions #1498

Merged
merged 4 commits into from
Jan 3, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 24 additions & 0 deletions tableauserverclient/server/pager.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,30 @@ class Pager(Iterable[T]):
(users in a group, views in a workbook, etc) by passing a different endpoint.
Will loop over anything that returns (list[ModelItem], PaginationItem).
Will make a copy of the `RequestOptions` object passed in so it can be reused.
Makes a call to the Server for each page of items, then yields each item in the list.
Parameters
----------
endpoint: CallableEndpoint[T] or Endpoint[T]
The endpoint to call to get the items. Can be a callable or an Endpoint object.
Expects a tuple of (list[T], PaginationItem) to be returned.
request_opts: RequestOptions, optional
The request options to pass to the endpoint. If not provided, will use default RequestOptions.
Filters, sorts, page size, starting page number, etc can be set here.
Yields
------
T
The items returned from the endpoint.
Raises
------
ValueError
If the endpoint is not a callable or an Endpoint object.
"""

def __init__(
Expand Down
125 changes: 123 additions & 2 deletions tableauserverclient/server/request_options.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,28 @@ def apply_query_params(self, url):


class RequestOptions(RequestOptionsBase):
"""
This class is used to manage the options that can be used when querying content on the server.
Optionally initialize with a page number and page size to control the number of items returned.

Additionally, you can add sorting and filtering options to the request.

The `sort` and `filter` options are set-like objects, so you can only add a field once. If you add the same field
multiple times, only the last one will be used.

The list of fields that can be sorted on or filtered by can be found in the `Field`
class contained within this class.

Parameters
----------
pagenumber: int, optional
The page number to start the query on. Default is 1.

pagesize: int, optional
The number of items to return per page. Default is 100. Can also read
from the environment variable `TSC_PAGE_SIZE`
"""

def __init__(self, pagenumber=1, pagesize=None):
self.pagenumber = pagenumber
self.pagesize = pagesize or config.PAGE_SIZE
Expand Down Expand Up @@ -196,13 +218,43 @@ def get_query_params(self):

def vf(self, name: str, value: str) -> Self:
"""Apply a filter based on a column within the view.
Note that when filtering on a boolean type field, the only valid values are 'true' and 'false'"""
Note that when filtering on a boolean type field, the only valid values are 'true' and 'false'

For more detail see: https://help.tableau.com/current/api/rest_api/en-us/REST/rest_api_concepts_filtering_and_sorting.htm#Filter-query-views

Parameters
----------
name: str
The name of the column to filter on

value: str
The value to filter on

Returns
-------
Self
The current object
"""
self.view_filters.append((name, value))
return self

def parameter(self, name: str, value: str) -> Self:
"""Apply a filter based on a parameter within the workbook.
Note that when filtering on a boolean type field, the only valid values are 'true' and 'false'"""
Note that when filtering on a boolean type field, the only valid values are 'true' and 'false'

Parameters
----------
name: str
The name of the parameter to filter on

value: str
The value to filter on

Returns
-------
Self
The current object
"""
self.view_parameters.append((name, value))
return self

Expand Down Expand Up @@ -254,14 +306,60 @@ def get_query_params(self) -> dict:


class CSVRequestOptions(_DataExportOptions):
"""
Options that can be used when exporting a view to CSV. Set the maxage to control the age of the data exported.
Filters to the underlying data can be applied using the `vf` and `parameter` methods.

Parameters
----------
maxage: int, optional
The maximum age of the data to export. Shortest possible duration is 1
minute. No upper limit. Default is -1, which means no limit.
"""

extension = "csv"


class ExcelRequestOptions(_DataExportOptions):
"""
Options that can be used when exporting a view to Excel. Set the maxage to control the age of the data exported.
Filters to the underlying data can be applied using the `vf` and `parameter` methods.

Parameters
----------
maxage: int, optional
The maximum age of the data to export. Shortest possible duration is 1
minute. No upper limit. Default is -1, which means no limit.
"""

extension = "xlsx"


class ImageRequestOptions(_ImagePDFCommonExportOptions):
"""
Options that can be used when exporting a view to an image. Set the maxage to control the age of the data exported.
Filters to the underlying data can be applied using the `vf` and `parameter` methods.

Parameters
----------
imageresolution: str, optional
The resolution of the image to export. Valid values are "high" or None. Default is None.
Image width and actual pixel density are determined by the display context
of the image. Aspect ratio is always preserved. Set the value to "high" to
ensure maximum pixel density.

maxage: int, optional
The maximum age of the data to export. Shortest possible duration is 1
minute. No upper limit. Default is -1, which means no limit.

viz_height: int, optional
The height of the viz in pixels. If specified, viz_width must also be specified.

viz_width: int, optional
The width of the viz in pixels. If specified, viz_height must also be specified.

"""

extension = "png"

# if 'high' isn't specified, the REST API endpoint returns an image with standard resolution
Expand All @@ -280,6 +378,29 @@ def get_query_params(self):


class PDFRequestOptions(_ImagePDFCommonExportOptions):
"""
Options that can be used when exporting a view to PDF. Set the maxage to control the age of the data exported.
Filters to the underlying data can be applied using the `vf` and `parameter` methods.

Parameters
----------
page_type: str, optional
The page type of the PDF to export. Valid values are accessible via the `PageType` class.

orientation: str, optional
The orientation of the PDF to export. Valid values are accessible via the `Orientation` class.

maxage: int, optional
The maximum age of the data to export. Shortest possible duration is 1
minute. No upper limit. Default is -1, which means no limit.

viz_height: int, optional
The height of the viz in pixels. If specified, viz_width must also be specified.

viz_width: int, optional
The width of the viz in pixels. If specified, viz_height must also be specified.
"""

class PageType:
A3 = "a3"
A4 = "a4"
Expand Down
14 changes: 14 additions & 0 deletions tableauserverclient/server/sort.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,18 @@
class Sort:
"""
Used with request options (RequestOptions) where you can filter and sort on
the results returned from the server.
Parameters
----------
field : str
Sets the field to sort on. The fields are defined in the RequestOption class.
direction : str
The direction to sort, either ascending (Asc) or descending (Desc). The
options are defined in the RequestOptions.Direction class.
"""

def __init__(self, field, direction):
self.field = field
self.direction = direction
Expand Down
Loading