mirror of
https://github.com/danswer-ai/danswer.git
synced 2025-03-26 01:31:51 +01:00
162 lines
6.3 KiB
Python
162 lines
6.3 KiB
Python
from fastapi import FastAPI
|
|
from httpx_oauth.clients.google import GoogleOAuth2
|
|
from httpx_oauth.clients.openid import BASE_SCOPES
|
|
from httpx_oauth.clients.openid import OpenID
|
|
|
|
from ee.onyx.configs.app_configs import OIDC_SCOPE_OVERRIDE
|
|
from ee.onyx.configs.app_configs import OPENID_CONFIG_URL
|
|
from ee.onyx.server.analytics.api import router as analytics_router
|
|
from ee.onyx.server.auth_check import check_ee_router_auth
|
|
from ee.onyx.server.enterprise_settings.api import (
|
|
admin_router as enterprise_settings_admin_router,
|
|
)
|
|
from ee.onyx.server.enterprise_settings.api import (
|
|
basic_router as enterprise_settings_router,
|
|
)
|
|
from ee.onyx.server.manage.standard_answer import router as standard_answer_router
|
|
from ee.onyx.server.middleware.tenant_tracking import add_tenant_id_middleware
|
|
from ee.onyx.server.oauth.api import router as oauth_router
|
|
from ee.onyx.server.query_and_chat.chat_backend import (
|
|
router as chat_router,
|
|
)
|
|
from ee.onyx.server.query_and_chat.query_backend import (
|
|
basic_router as query_router,
|
|
)
|
|
from ee.onyx.server.query_history.api import router as query_history_router
|
|
from ee.onyx.server.reporting.usage_export_api import router as usage_export_router
|
|
from ee.onyx.server.saml import router as saml_router
|
|
from ee.onyx.server.seeding import seed_db
|
|
from ee.onyx.server.tenants.api import router as tenants_router
|
|
from ee.onyx.server.tenants.router import router as new_router
|
|
from ee.onyx.server.token_rate_limits.api import (
|
|
router as token_rate_limit_settings_router,
|
|
)
|
|
from ee.onyx.server.user_group.api import router as user_group_router
|
|
from ee.onyx.utils.encryption import test_encryption
|
|
from onyx.auth.users import auth_backend
|
|
from onyx.auth.users import create_onyx_oauth_router
|
|
from onyx.auth.users import fastapi_users
|
|
from onyx.configs.app_configs import AUTH_TYPE
|
|
from onyx.configs.app_configs import OAUTH_CLIENT_ID
|
|
from onyx.configs.app_configs import OAUTH_CLIENT_SECRET
|
|
from onyx.configs.app_configs import USER_AUTH_SECRET
|
|
from onyx.configs.app_configs import WEB_DOMAIN
|
|
from onyx.configs.constants import AuthType
|
|
from onyx.main import get_application as get_application_base
|
|
from onyx.main import include_auth_router_with_prefix
|
|
from onyx.main import include_router_with_global_prefix_prepended
|
|
from onyx.utils.logger import setup_logger
|
|
from onyx.utils.variable_functionality import global_version
|
|
from shared_configs.configs import MULTI_TENANT
|
|
|
|
logger = setup_logger()
|
|
|
|
|
|
def get_application() -> FastAPI:
|
|
# Anything that happens at import time is not guaranteed to be running ee-version
|
|
# Anything after the server startup will be running ee version
|
|
global_version.set_ee()
|
|
|
|
test_encryption()
|
|
|
|
application = get_application_base()
|
|
|
|
if MULTI_TENANT:
|
|
add_tenant_id_middleware(application, logger)
|
|
|
|
if AUTH_TYPE == AuthType.CLOUD:
|
|
oauth_client = GoogleOAuth2(OAUTH_CLIENT_ID, OAUTH_CLIENT_SECRET)
|
|
include_auth_router_with_prefix(
|
|
application,
|
|
create_onyx_oauth_router(
|
|
oauth_client,
|
|
auth_backend,
|
|
USER_AUTH_SECRET,
|
|
associate_by_email=True,
|
|
is_verified_by_default=True,
|
|
# Points the user back to the login page
|
|
redirect_url=f"{WEB_DOMAIN}/auth/oauth/callback",
|
|
),
|
|
prefix="/auth/oauth",
|
|
)
|
|
|
|
# Need basic auth router for `logout` endpoint
|
|
include_auth_router_with_prefix(
|
|
application,
|
|
fastapi_users.get_logout_router(auth_backend),
|
|
prefix="/auth",
|
|
)
|
|
|
|
if AUTH_TYPE == AuthType.OIDC:
|
|
include_auth_router_with_prefix(
|
|
application,
|
|
create_onyx_oauth_router(
|
|
OpenID(
|
|
OAUTH_CLIENT_ID,
|
|
OAUTH_CLIENT_SECRET,
|
|
OPENID_CONFIG_URL,
|
|
# BASE_SCOPES is the same as not setting this
|
|
base_scopes=OIDC_SCOPE_OVERRIDE or BASE_SCOPES,
|
|
),
|
|
auth_backend,
|
|
USER_AUTH_SECRET,
|
|
associate_by_email=True,
|
|
is_verified_by_default=True,
|
|
redirect_url=f"{WEB_DOMAIN}/auth/oidc/callback",
|
|
),
|
|
prefix="/auth/oidc",
|
|
)
|
|
|
|
# need basic auth router for `logout` endpoint
|
|
include_auth_router_with_prefix(
|
|
application,
|
|
fastapi_users.get_auth_router(auth_backend),
|
|
prefix="/auth",
|
|
)
|
|
|
|
elif AUTH_TYPE == AuthType.SAML:
|
|
include_auth_router_with_prefix(
|
|
application,
|
|
saml_router,
|
|
)
|
|
|
|
# RBAC / group access control
|
|
include_router_with_global_prefix_prepended(application, user_group_router)
|
|
# Analytics endpoints
|
|
include_router_with_global_prefix_prepended(application, analytics_router)
|
|
include_router_with_global_prefix_prepended(application, new_router)
|
|
include_router_with_global_prefix_prepended(application, query_history_router)
|
|
# EE only backend APIs
|
|
include_router_with_global_prefix_prepended(application, query_router)
|
|
include_router_with_global_prefix_prepended(application, chat_router)
|
|
include_router_with_global_prefix_prepended(application, standard_answer_router)
|
|
include_router_with_global_prefix_prepended(application, oauth_router)
|
|
|
|
# Enterprise-only global settings
|
|
include_router_with_global_prefix_prepended(
|
|
application, enterprise_settings_admin_router
|
|
)
|
|
# Token rate limit settings
|
|
include_router_with_global_prefix_prepended(
|
|
application, token_rate_limit_settings_router
|
|
)
|
|
include_router_with_global_prefix_prepended(application, enterprise_settings_router)
|
|
include_router_with_global_prefix_prepended(application, usage_export_router)
|
|
|
|
if MULTI_TENANT:
|
|
# Tenant management
|
|
include_router_with_global_prefix_prepended(application, tenants_router)
|
|
|
|
# Ensure all routes have auth enabled or are explicitly marked as public
|
|
check_ee_router_auth(application)
|
|
|
|
# seed the Onyx environment with LLMs, Assistants, etc. based on an optional
|
|
# environment variable. Used to automate deployment for multiple environments.
|
|
seed_db()
|
|
|
|
# for debugging discovered routes
|
|
# for route in application.router.routes:
|
|
# print(f"Path: {route.path}, Methods: {route.methods}")
|
|
|
|
return application
|