mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-30 19:43:47 +00:00 
			
		
		
		
	We've copied the button and error colors from portico_signin.css. We did not want the new HTML file to depend on portico_signin.css since they are unrelated. In addition, having those colors diverge over time might not be an issue. We make the raw mode work with /help and /help/ both. See https://chat.zulip.org/#narrow/channel/19-documentation/topic/edits.20not.20appearing.20with.20vagrant/near/2257442 Co-authored-by: Alya Abbott <alya@zulip.com>
		
			
				
	
	
		
			143 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import os
 | |
| from urllib.parse import urlsplit
 | |
| 
 | |
| from django.conf import settings
 | |
| from django.conf.urls.static import static
 | |
| from django.contrib.staticfiles.views import serve as staticfiles_serve
 | |
| from django.http.request import HttpRequest
 | |
| from django.http.response import FileResponse
 | |
| from django.urls import path
 | |
| from django.views.generic import RedirectView, TemplateView
 | |
| from django.views.static import serve
 | |
| 
 | |
| from zerver.views.auth import login_page
 | |
| from zerver.views.development.cache import remove_caches
 | |
| from zerver.views.development.camo import handle_camo_url
 | |
| from zerver.views.development.dev_login import (
 | |
|     api_dev_fetch_api_key,
 | |
|     api_dev_list_users,
 | |
|     dev_direct_login,
 | |
| )
 | |
| from zerver.views.development.email_log import clear_emails, email_page, generate_all_emails
 | |
| from zerver.views.development.help import help_dev_mode_view
 | |
| from zerver.views.development.integrations import (
 | |
|     check_send_webhook_fixture_message,
 | |
|     dev_panel,
 | |
|     get_fixtures,
 | |
|     send_all_webhook_fixture_messages,
 | |
| )
 | |
| from zerver.views.development.registration import (
 | |
|     confirmation_key,
 | |
|     register_demo_development_realm,
 | |
|     register_development_realm,
 | |
|     register_development_user,
 | |
| )
 | |
| from zerver.views.development.showroom import (
 | |
|     showroom_component_banners,
 | |
|     showroom_component_buttons,
 | |
|     showroom_component_inputs,
 | |
| )
 | |
| from zerver.views.errors import config_error
 | |
| 
 | |
| # These URLs are available only in the development environment
 | |
| 
 | |
| use_prod_static = not settings.DEBUG
 | |
| 
 | |
| urls = [
 | |
|     # Serve useful development environment resources (docs, coverage reports, etc.)
 | |
|     path(
 | |
|         "coverage/<path:path>",
 | |
|         serve,
 | |
|         {"document_root": os.path.join(settings.DEPLOY_ROOT, "var/coverage"), "show_indexes": True},
 | |
|     ),
 | |
|     path(
 | |
|         "node-coverage/<path:path>",
 | |
|         serve,
 | |
|         {
 | |
|             "document_root": os.path.join(settings.DEPLOY_ROOT, "var/node-coverage/lcov-report"),
 | |
|             "show_indexes": True,
 | |
|         },
 | |
|     ),
 | |
|     path("docs/", RedirectView.as_view(url="/docs/index.html")),
 | |
|     path(
 | |
|         "docs/<path:path>",
 | |
|         serve,
 | |
|         {"document_root": os.path.join(settings.DEPLOY_ROOT, "docs/_build/html")},
 | |
|     ),
 | |
|     # The special no-password login endpoint for development
 | |
|     path(
 | |
|         "devlogin/",
 | |
|         login_page,
 | |
|         {"template_name": "zerver/development/dev_login.html"},
 | |
|         name="login_page",
 | |
|     ),
 | |
|     # Page for testing email templates
 | |
|     path("emails/", email_page),
 | |
|     path("emails/generate/", generate_all_emails),
 | |
|     path("emails/clear/", clear_emails),
 | |
|     # Listing of useful URLs and various tools for development
 | |
|     path("devtools/", TemplateView.as_view(template_name="zerver/development/dev_tools.html")),
 | |
|     # Register new user and realm
 | |
|     path("devtools/register_user/", register_development_user, name="register_dev_user"),
 | |
|     path("devtools/register_realm/", register_development_realm, name="register_dev_realm"),
 | |
|     path(
 | |
|         "devtools/register_demo_realm/",
 | |
|         register_demo_development_realm,
 | |
|         name="register_demo_dev_realm",
 | |
|     ),
 | |
|     # Have easy access for error pages
 | |
|     path("errors/404/", TemplateView.as_view(template_name="404.html")),
 | |
|     path("errors/5xx/", TemplateView.as_view(template_name="500.html")),
 | |
|     # Add a convenient way to generate webhook messages from fixtures.
 | |
|     path("devtools/integrations/", dev_panel),
 | |
|     path(
 | |
|         "devtools/integrations/check_send_webhook_fixture_message",
 | |
|         check_send_webhook_fixture_message,
 | |
|     ),
 | |
|     path(
 | |
|         "devtools/integrations/send_all_webhook_fixture_messages", send_all_webhook_fixture_messages
 | |
|     ),
 | |
|     path("devtools/integrations/<integration_name>/fixtures", get_fixtures),
 | |
|     path("config-error/<error_name>", config_error, name="config_error"),
 | |
|     # Special endpoint to remove all the server-side caches.
 | |
|     path("flush_caches", remove_caches),
 | |
|     # Redirect camo URLs for development
 | |
|     path("external_content/<digest>/<received_url>", handle_camo_url),
 | |
|     # Endpoints for Showroom components.
 | |
|     path("devtools/buttons/", showroom_component_buttons),
 | |
|     path("devtools/banners/", showroom_component_banners),
 | |
|     path("devtools/inputs/", showroom_component_inputs),
 | |
|     # Development server for the help center in not run by default, we
 | |
|     # show this page with zulip.com and view source links instead.
 | |
|     path("help", help_dev_mode_view),
 | |
|     path("help/", help_dev_mode_view),
 | |
|     path("help/<path:subpath>", help_dev_mode_view),
 | |
| ]
 | |
| 
 | |
| v1_api_mobile_patterns = [
 | |
|     # This is for the signing in through the devAuthBackEnd on mobile apps.
 | |
|     path("dev_fetch_api_key", api_dev_fetch_api_key),
 | |
|     # This is for fetching the emails of the admins and the users.
 | |
|     path("dev_list_users", api_dev_list_users),
 | |
| ]
 | |
| # Serve static assets via the Django server
 | |
| if use_prod_static:
 | |
|     urls += [
 | |
|         path("static/<path:path>", serve, {"document_root": settings.STATIC_ROOT}),
 | |
|     ]
 | |
| else:  # nocoverage
 | |
| 
 | |
|     def serve_static(request: HttpRequest, path: str) -> FileResponse:
 | |
|         response = staticfiles_serve(request, path)
 | |
|         response["Access-Control-Allow-Origin"] = "*"
 | |
|         return response
 | |
| 
 | |
|     assert settings.STATIC_URL is not None
 | |
|     urls += static(urlsplit(settings.STATIC_URL).path, view=serve_static)
 | |
| 
 | |
| i18n_urls = [
 | |
|     path("accounts/login/local/", dev_direct_login, name="login-local"),
 | |
|     path("confirmation_key/", confirmation_key),
 | |
| ]
 | |
| urls += i18n_urls
 |