mirror of
https://github.com/langgenius/dify.git
synced 2026-06-26 23:01:11 +08:00
Reintroduce the nullable api_tokens.dataset_id column (dropped in 2e9819ca5b28) so dataset API keys can opt into per-knowledge-base scoping: - NULL dataset_id keeps today's workspace-wide behavior, so every existing key and the existing /datasets/api-keys create route are unchanged. - validate_dataset_token rejects a bound key for any other dataset, and for endpoints that carry no dataset id (e.g. list-all), with 403. - CachedApiToken carries dataset_id with a None default so cache entries written before deploy keep deserializing. - The per-dataset console routes in apikey.py (previously dead code that 500ed on a missing ApiToken.dataset_id) now create bound keys; their list returns bound keys plus workspace keys so the dataset page shows the full access picture. - Frontend: the knowledge base API access popover gains an API keys entry; the secret key modal accepts datasetId, shows a scope column, and offers a workspace / this-knowledge-base scope choice on create. New strings are localized for all 23 locales. |
||
|---|---|---|
| .. | ||
| rag_pipeline | ||
| __init__.py | ||
| test_data_source.py | ||
| test_datasets_document_download.py | ||
| test_datasets_document.py | ||
| test_datasets_segments.py | ||
| test_datasets.py | ||
| test_external_dataset_payload.py | ||
| test_external.py | ||
| test_hit_testing_base.py | ||
| test_hit_testing.py | ||
| test_metadata.py | ||
| test_website.py | ||
| test_wraps.py | ||