arcade-google 0.1.5__py3-none-any.whl → 1.2.4__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,144 @@
1
+ from typing import Annotated
2
+
3
+ from arcade_tdk import ToolContext, tool
4
+ from arcade_tdk.auth import Google
5
+ from arcade_tdk.errors import RetryableToolError
6
+
7
+ from arcade_google.models import (
8
+ SheetDataInput,
9
+ Spreadsheet,
10
+ SpreadsheetProperties,
11
+ )
12
+ from arcade_google.utils import (
13
+ build_sheets_service,
14
+ create_sheet,
15
+ parse_get_spreadsheet_response,
16
+ parse_write_to_cell_response,
17
+ validate_write_to_cell_params,
18
+ )
19
+
20
+
21
+ @tool(
22
+ requires_auth=Google(
23
+ scopes=["https://www.googleapis.com/auth/drive.file"],
24
+ )
25
+ )
26
+ def create_spreadsheet(
27
+ context: ToolContext,
28
+ title: Annotated[str, "The title of the new spreadsheet"] = "Untitled spreadsheet",
29
+ data: Annotated[
30
+ str | None,
31
+ "The data to write to the spreadsheet. A JSON string "
32
+ "(property names enclosed in double quotes) representing a dictionary that "
33
+ "maps row numbers to dictionaries that map column letters to cell values. "
34
+ "For example, data[23]['C'] would be the value of the cell in row 23, column C. "
35
+ "Type hint: dict[int, dict[str, Union[int, float, str, bool]]]",
36
+ ] = None,
37
+ ) -> Annotated[dict, "The created spreadsheet's id and title"]:
38
+ """Create a new spreadsheet with the provided title and data in its first sheet
39
+
40
+ Returns the newly created spreadsheet's id and title
41
+ """
42
+ service = build_sheets_service(context.get_auth_token_or_empty())
43
+
44
+ try:
45
+ sheet_data = SheetDataInput(data=data) # type: ignore[arg-type]
46
+ except Exception as e:
47
+ msg = "Invalid JSON or unexpected data format for parameter `data`"
48
+ raise RetryableToolError(
49
+ message=msg,
50
+ additional_prompt_content=f"{msg}: {e}",
51
+ retry_after_ms=100,
52
+ )
53
+
54
+ spreadsheet = Spreadsheet(
55
+ properties=SpreadsheetProperties(title=title),
56
+ sheets=[create_sheet(sheet_data)],
57
+ )
58
+
59
+ body = spreadsheet.model_dump()
60
+
61
+ response = (
62
+ service.spreadsheets()
63
+ .create(body=body, fields="spreadsheetId,spreadsheetUrl,properties/title")
64
+ .execute()
65
+ )
66
+
67
+ return {
68
+ "title": response["properties"]["title"],
69
+ "spreadsheetId": response["spreadsheetId"],
70
+ "spreadsheetUrl": response["spreadsheetUrl"],
71
+ }
72
+
73
+
74
+ @tool(
75
+ requires_auth=Google(
76
+ scopes=["https://www.googleapis.com/auth/drive.file"],
77
+ )
78
+ )
79
+ async def get_spreadsheet(
80
+ context: ToolContext,
81
+ spreadsheet_id: Annotated[str, "The id of the spreadsheet to get"],
82
+ ) -> Annotated[
83
+ dict,
84
+ "The spreadsheet properties and data for all sheets in the spreadsheet",
85
+ ]:
86
+ """
87
+ Get the user entered values and formatted values for all cells in all sheets in the spreadsheet
88
+ along with the spreadsheet's properties
89
+ """
90
+ service = build_sheets_service(context.get_auth_token_or_empty())
91
+ response = (
92
+ service.spreadsheets()
93
+ .get(
94
+ spreadsheetId=spreadsheet_id,
95
+ includeGridData=True,
96
+ fields="spreadsheetId,spreadsheetUrl,properties/title,sheets/properties,sheets/data/rowData/values/userEnteredValue,sheets/data/rowData/values/formattedValue,sheets/data/rowData/values/effectiveValue",
97
+ )
98
+ .execute()
99
+ )
100
+ return parse_get_spreadsheet_response(response)
101
+
102
+
103
+ @tool(
104
+ requires_auth=Google(
105
+ scopes=["https://www.googleapis.com/auth/drive.file"],
106
+ )
107
+ )
108
+ def write_to_cell(
109
+ context: ToolContext,
110
+ spreadsheet_id: Annotated[str, "The id of the spreadsheet to write to"],
111
+ column: Annotated[str, "The column string to write to. For example, 'A', 'F', or 'AZ'"],
112
+ row: Annotated[int, "The row number to write to"],
113
+ value: Annotated[str, "The value to write to the cell"],
114
+ sheet_name: Annotated[
115
+ str, "The name of the sheet to write to. Defaults to 'Sheet1'"
116
+ ] = "Sheet1",
117
+ ) -> Annotated[dict, "The status of the operation"]:
118
+ """
119
+ Write a value to a single cell in a spreadsheet.
120
+ """
121
+ service = build_sheets_service(context.get_auth_token_or_empty())
122
+ validate_write_to_cell_params(service, spreadsheet_id, sheet_name, column, row)
123
+
124
+ range_ = f"'{sheet_name}'!{column.upper()}{row}"
125
+ body = {
126
+ "range": range_,
127
+ "majorDimension": "ROWS",
128
+ "values": [[value]],
129
+ }
130
+
131
+ sheet_properties = (
132
+ service.spreadsheets()
133
+ .values()
134
+ .update(
135
+ spreadsheetId=spreadsheet_id,
136
+ range=range_,
137
+ valueInputOption="USER_ENTERED",
138
+ includeValuesInResponse=True,
139
+ body=body,
140
+ )
141
+ .execute()
142
+ )
143
+
144
+ return parse_write_to_cell_response(sheet_properties)