.. _introspection: Introspection ============= Datasette includes some pages and JSON API endpoints for introspecting the current instance. These can be used to understand some of the internals of Datasette and to see how a particular instance has been configured. Each of these pages can be viewed in your browser. Add ``.json`` to the URL to get back the contents as JSON. .. _JsonDataView_metadata: /-/metadata ----------- Shows the contents of the ``metadata.json`` file that was passed to ``datasette serve``, if any. `Metadata example `_: .. code-block:: json { "license": "CC Attribution 4.0 License", "license_url": "http://creativecommons.org/licenses/by/4.0/", "source": "fivethirtyeight/data on GitHub", "source_url": "https://github.com/fivethirtyeight/data", "title": "Five Thirty Eight", "databases": { } } .. _JsonDataView_versions: /-/versions ----------- Shows the version of Datasette, Python and SQLite. `Versions example `_: .. code-block:: json { "datasette": { "version": "0.60" }, "python": { "full": "3.8.12 (default, Dec 21 2021, 10:45:09) \n[GCC 10.2.1 20210110]", "version": "3.8.12" }, "sqlite": { "extensions": { "json1": null }, "fts_versions": [ "FTS5", "FTS4", "FTS3" ], "compile_options": [ "COMPILER=gcc-6.3.0 20170516", "ENABLE_FTS3", "ENABLE_FTS4", "ENABLE_FTS5", "ENABLE_JSON1", "ENABLE_RTREE", "THREADSAFE=1" ], "version": "3.37.0" } } .. _JsonDataView_plugins: /-/plugins ---------- Shows a list of currently installed plugins and their versions. `Plugins example `_: .. code-block:: json [ { "name": "datasette_cluster_map", "static": true, "templates": false, "version": "0.10", "hooks": ["extra_css_urls", "extra_js_urls", "extra_body_script"] } ] Add ``?all=1`` to include details of the default plugins baked into Datasette. .. _JsonDataView_settings: /-/settings ----------- Shows the :ref:`settings` for this instance of Datasette. `Settings example `_: .. code-block:: json { "default_facet_size": 30, "default_page_size": 100, "facet_suggest_time_limit_ms": 50, "facet_time_limit_ms": 1000, "max_returned_rows": 1000, "sql_time_limit_ms": 1000 } .. _JsonDataView_config: /-/config --------- Shows the :ref:`configuration ` for this instance of Datasette. This is generally the contents of the :ref:`datasette.yaml or datasette.json ` file, which can include plugin configuration as well. `Config example `_: .. code-block:: json { "settings": { "template_debug": true, "trace_debug": true, "force_https_urls": true } } Any keys that include the one of the following substrings in their names will be returned as redacted ``***`` output, to help avoid accidentally leaking private configuration information: ``secret``, ``key``, ``password``, ``token``, ``hash``, ``dsn``. .. _JsonDataView_databases: /-/databases ------------ Shows currently attached databases. `Databases example `_: .. code-block:: json [ { "hash": null, "is_memory": false, "is_mutable": true, "name": "fixtures", "path": "fixtures.db", "size": 225280 } ] .. _JumpView: /-/jump ------- Returns a JSON list of items that the current actor has permission to view for Datasette's jump menu. By default this includes visible databases, tables, views and canned queries, and plugins can contribute additional items. The endpoint supports a ``?q=`` query parameter for filtering items by name. Canned queries with a configured ``title`` also include a ``display_name`` in their results, and can be found by searching for that title. Plugins can provide the same extra field from ``jump_items_sql`` by returning a ``display_name`` column and setting ``JumpSQL(..., has_display_name=True)``. `Jump example `_: .. code-block:: json { "matches": [ { "name": "fixtures", "url": "/fixtures", "type": "database", "description": "Database" }, { "name": "fixtures: facetable", "url": "/fixtures/facetable", "type": "table", "description": "Table" }, { "name": "fixtures: recent_releases", "display_name": "Recent Datasette releases", "url": "/fixtures/recent_releases", "type": "query", "description": "Canned query" } ], "truncated": false } Search example with ``?q=facet`` returns only items matching ``.*facet.*``: .. code-block:: json { "matches": [ { "name": "fixtures: facetable", "url": "/fixtures/facetable", "type": "table", "description": "Table" } ], "truncated": false } When multiple search terms are provided (e.g., ``?q=user+profile``), items must match the pattern ``.*user.*profile.*``. Results are ordered by relevance, then by item type and shortest display name. .. _JsonDataView_threads: /-/threads ---------- Shows details of threads and ``asyncio`` tasks. `Threads example `_: .. code-block:: json { "num_threads": 2, "threads": [ { "daemon": false, "ident": 4759197120, "name": "MainThread" }, { "daemon": true, "ident": 123145319682048, "name": "Thread-1" }, ], "num_tasks": 3, "tasks": [ " cb=[set.discard()]>", " wait_for=()]> cb=[run_until_complete..()]>", " wait_for=()]>>" ] } .. _JsonDataView_actor: /-/actor -------- Shows the currently authenticated actor. Useful for debugging Datasette authentication plugins. .. code-block:: json { "actor": { "id": 1, "username": "some-user" } } .. _MessagesDebugView: /-/messages ----------- The debug tool at ``/-/messages`` can be used to set flash messages to try out that feature. See :ref:`datasette_add_message` for details of this feature.