-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #114 from duneanalytics/PRO-937-add-table-endpoint…
…s-to-sdk PRO-937: Add `create` and `insert` table endpoints to sdk
- Loading branch information
Showing
7 changed files
with
174 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
""" | ||
Table API endpoints enables users to | ||
create and insert data into Dune. | ||
""" | ||
|
||
from __future__ import annotations | ||
from typing import List, Dict, Any, IO | ||
|
||
from dune_client.api.base import BaseRouter | ||
from dune_client.models import DuneError | ||
|
||
|
||
class TableAPI(BaseRouter): | ||
""" | ||
Implementation of Table endpoints - Plus subscription only | ||
https://docs.dune.com/api-reference/tables/ | ||
""" | ||
|
||
def upload_csv( | ||
self, | ||
table_name: str, | ||
data: str, | ||
description: str = "", | ||
is_private: bool = False, | ||
) -> bool: | ||
""" | ||
https://docs.dune.com/api-reference/tables/endpoint/upload | ||
This endpoint allows you to upload any .csv file into Dune. The only limitations are: | ||
- File has to be < 200 MB | ||
- Column names in the table can't start with a special character or digits. | ||
- Private uploads require a Plus subscription. | ||
Below are the specifics of how to work with the API. | ||
""" | ||
response_json = self._post( | ||
route="/table/upload/csv", | ||
params={ | ||
"table_name": table_name, | ||
"description": description, | ||
"data": data, | ||
"is_private": is_private, | ||
}, | ||
) | ||
try: | ||
return bool(response_json["success"]) | ||
except KeyError as err: | ||
raise DuneError(response_json, "UploadCsvResponse", err) from err | ||
|
||
def create_table( | ||
self, | ||
namespace: str, | ||
table_name: str, | ||
schema: List[Dict[str, str]], | ||
description: str = "", | ||
is_private: bool = False, | ||
) -> Any: | ||
""" | ||
https://docs.dune.com/api-reference/tables/endpoint/create | ||
The create table endpoint allows you to create an empty table | ||
with a specific schema in Dune. | ||
The only limitations are: | ||
- If a table already exists with the same name, the request will fail. | ||
- Column names in the table can’t start with a special character or a digit. | ||
""" | ||
|
||
return self._post( | ||
route="/table/create", | ||
params={ | ||
"namespace": namespace, | ||
"table_name": table_name, | ||
"schema": schema, | ||
"description": description, | ||
"is_private": is_private, | ||
}, | ||
) | ||
|
||
def insert_table( | ||
self, | ||
namespace: str, | ||
table_name: str, | ||
data: IO[bytes], | ||
content_type: str, | ||
) -> Any: | ||
""" | ||
https://docs.dune.com/api-reference/tables/endpoint/insert | ||
The insert table endpoint allows you to insert data into an existing table in Dune. | ||
The only limitations are: | ||
- The file has to be in json or csv format | ||
- The file has to have the same schema as the table | ||
""" | ||
|
||
return self._post( | ||
route=f"/table/{namespace}/{table_name}/insert", | ||
headers={"Content-Type": content_type}, | ||
data=data, | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
date,dgs10 | ||
2020-12-01T23:33:00,10 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
{"date":"2020-12-01T23:33:00","dgs10":10} |