-
-
Notifications
You must be signed in to change notification settings - Fork 701
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
API explorer tool #1871
Comments
Host it at It's an input box with a path in and a textarea you can put JSON in, plus a submit button to post the request. It lists the API endpoints you can use - click on a link to populate the form field plus a example. |
This is even more important now I have pushed: |
Initial prototype API explorer is now live at https://latest-1-0-dev.datasette.io/-/api |
Realized the API explorer doesn't need the API key piece at all - it can work with standard cookie-based auth. This also reflects how most plugins are likely to use this API, where they'll be adding JavaScript that uses |
I do need to skip CSRF for these API calls. I'm going to start out by doing that using the @hookimpl
def skip_csrf(scope):
if scope["type"] == "http":
headers = scope.get("headers")
if dict(headers).get(b'content-type') == b'application/json':
return True |
It's weird that the API explorer only lets you explore POST APIs. It should probably also let you explore GET APIs, or be renamed. |
I want JSON syntax highlighting. https://github.com/luyilin/json-format-highlight is an MIT licensed tiny highlighter that looks decent for this. https://unpkg.com/[email protected]/dist/json-format-highlight.js |
This is pretty useful now. Two features I still want to add:
|
Here's a slightly wild idea: what if there was a button on Only reason I don't want to show these to everyone is that I don't think this is a very user-friendly feature: if you don't know what an API is I don't want to expose you to it unnecessarily. |
The API Explorer should definitely link to the And it should probably go in the Datasette application menu? |
I'm going to add a link to the Datasette API docs for the current running version of Datasette, e.g. to https://docs.datasette.io/en/0.63/json_api.html |
Added this while playing with the new API explorer, refs #1871
I can close this issue once I fix it so it no longer hard-codes a potentially invalid example endpoint: datasette/datasette/templates/api_explorer.html Lines 24 to 26 in bcc781f
datasette/datasette/templates/api_explorer.html Lines 34 to 35 in bcc781f
|
I'll probably enhance it a bit more though, I want to provide a UI that lists all the tables you can explore and lets you click to pre-fill the forms with them. Though at that point what should I do about the other endpoints? Probably list those too. Gets a bit complex, especially with the row-level update and delete endpoints. |
I agree (that's what I did with the previous insert plugin), maybe a complete example using |
The current API explorer uses details/summary elements for the GET and POST dialogs. I only want one of these to be open at a time, to reflect that you can make either a GET or a POST. I just noticed that clicking anywhere else on the page closes both elements, which isn't what I want to happen. Turns out that's because of this code I added as part of Datasette's menu implementation! datasette/datasette/templates/_close_open_menus.html Lines 2 to 15 in 9f54f00
|
I'm going to add a special |
Actually no, I'm going to add a class of |
I'm going to need extra code to toggle POST closed when GET opens and vice-versa. |
Two things left before I close this issue:
|
For the example links - I'm going to have these at the bottom of the page so you don't have to scroll past them. Ideally these would take the user's permissions into account. This could make the page expensive to load, but I'm going to risk it for the moment. Something like this then:
I won't bother with per-row demo links (for update and delete) because there could be thousands of them for each table. |
In playing with the API explorer just now I realized it's way too easy to accidentally drop a table using it. |
The API will be much easier to develop if there's a page that helps you execute JSON POSTs against it.
The text was updated successfully, but these errors were encountered: