]> git.ipfire.org Git - ipfire.org.git/blobdiff - src/web/__init__.py
backend: show checksum on thank-you page
[ipfire.org.git] / src / web / __init__.py
index c2b749abedb828983031d69529c095c0444d654e..dfc72eaa1212e30f246913f2dc7d6bc99ebb17d1 100644 (file)
@@ -14,19 +14,21 @@ from .. import util
 
 from .handlers import *
 
+from . import analytics
 from . import auth
 from . import blog
 from . import boot
+from . import docs
 from . import donate
 from . import downloads
 from . import fireinfo
 from . import iuse
+from . import lists
 from . import location
 from . import nopaste
-from . import people
 from . import ui_modules
 from . import users
-from . import wiki
+from . import voip
 
 class Application(tornado.web.Application):
        def __init__(self, config, **kwargs):
@@ -39,6 +41,9 @@ class Application(tornado.web.Application):
 
                        # Enable XSRF cookies
                        "xsrf_cookies" : True,
+                       "xsrf_cookie_kwargs" : {
+                               "secure" : True,
+                       },
 
                        # Login
                        "login_url" : "/login",
@@ -59,23 +64,25 @@ class Application(tornado.web.Application):
 
                        # UI Modules
                        "ui_modules" : {
+                               # Analytics
+                               "AnalyticsSummary"     : analytics.SummaryModule,
+
+                               # Auth
+                               "Password"             : auth.PasswordModule,
+
                                # Blog
                                "BlogHistoryNavigation": blog.HistoryNavigationModule,
                                "BlogList"             : blog.ListModule,
-                               "BlogPost"             : blog.PostModule,
 
                                # Boot
                                "BootMenuConfig"       : boot.MenuConfigModule,
                                "BootMenuHeader"       : boot.MenuHeaderModule,
                                "BootMenuSeparator"    : boot.MenuSeparatorModule,
 
-                               # People
-                               "Agent"                : people.AgentModule,
-                               "CDR"                  : people.CDRModule,
-                               "Channels"             : people.ChannelsModule,
-                               "MOS"                  : people.MOSModule,
-                               "Password"             : people.PasswordModule,
-                               "Registrations"        : people.RegistrationsModule,
+                               # Docs
+                               "DocsDiff"             : docs.DiffModule,
+                               "DocsHeader"           : docs.HeaderModule,
+                               "DocsList"             : docs.ListModule,
 
                                # Nopaste
                                "Code"                 : nopaste.CodeModule,
@@ -88,13 +95,15 @@ class Application(tornado.web.Application):
                                # Users
                                "UsersList"            : users.ListModule,
 
-                               # Wiki
-                               "WikiDiff"             : wiki.WikiDiffModule,
-                               "WikiNavbar"           : wiki.WikiNavbarModule,
-                               "WikiList"             : wiki.WikiListModule,
+                               # VoIP
+                               "VoIPConferences"      : voip.ConferencesModule,
+                               "VoIPOutboundRegistrations" :
+                                       voip.OutboundRegistrationsModule,
+                               "VoIPQueues"           : voip.QueuesModule,
+                               "VoIPRegistrations"    : voip.RegistrationsModule,
 
                                # Misc
-                               "ChristmasBanner"      : ui_modules.ChristmasBannerModule,
+                               "IPFireLogo"           : ui_modules.IPFireLogoModule,
                                "Markdown"             : ui_modules.MarkdownModule,
                                "Map"                  : ui_modules.MapModule,
                                "ProgressBar"          : ui_modules.ProgressBarModule,
@@ -112,48 +121,89 @@ class Application(tornado.web.Application):
                        (r"/logout", auth.LogoutHandler),
                ]
 
-               self.add_handlers(r"(www\.)?([a-z]+\.dev\.)?ipfire\.org", [
+               self.add_handlers(r"www\.([a-z]+\.dev\.)?ipfire\.org", [
                        # Entry site that lead the user to index
                        (r"/", IndexHandler),
 
+                       # Analytics
+                       (r"/analytics", analytics.IndexHandler),
+                       (r"/analytics/docs", analytics.DocsHandler),
+
                        # Authentication
+                       (r"/join", auth.JoinHandler),
                        (r"/login", auth.LoginHandler),
                        (r"/logout", auth.LogoutHandler),
-                       (r"/register", auth.RegisterHandler),
+                       (r"/activate/([a-z_][a-z0-9_-]{0,31})/(\w+)", auth.ActivateHandler),
 
                        # Blog
                        (r"/blog", blog.IndexHandler),
-                       (r"/blog/authors/(\w+)", blog.AuthorHandler),
-                       (r"/blog/compose", blog.ComposeHandler),
                        (r"/blog/drafts", blog.DraftsHandler),
                        (r"/blog/feed.xml", blog.FeedHandler),
-                       (r"/blog/search", blog.SearchHandler),
-                       (r"/blog/tags/([0-9a-z\-\.]+)", blog.TagHandler),
+                       (r"/blog/write", blog.WriteHandler),
                        (r"/blog/years/([0-9]{4})", blog.YearHandler),
                        (r"/blog/([0-9a-z\-\._]+)", blog.PostHandler),
                        (r"/blog/([0-9a-z\-\._]+)/delete", blog.DeleteHandler),
                        (r"/blog/([0-9a-z\-\._]+)/edit", blog.EditHandler),
                        (r"/blog/([0-9a-z\-\._]+)/publish", blog.PublishHandler),
+                       (r"/blog/([0-9a-z\-\._]+)/debug/email", blog.DebugEmailHandler),
+
+                       # Docs
+                       (r"/docs/recent\-changes", docs.RecentChangesHandler),
+                       (r"/docs/search", docs.SearchHandler),
+                       (r"/docs/tree", docs.TreeHandler),
+                       (r"/docs/watchlist", docs.WatchlistHandler),
+                       (r"/docs/_restore", docs.RestoreHandler),
+                       (r"/docs/_upload", docs.UploadHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+)?/_edit", docs.EditHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+)?/_render", docs.RenderHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+)?/_(watch|unwatch)", docs.WatchHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+)?/_files", docs.FilesHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+(?:.*)\.(?:\w+))/_delete", docs.DeleteFileHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]+(?:.*)\.(?:\w+))$", docs.FileHandler),
+                       (r"/docs(/[A-Za-z0-9\-_\/]*)?", docs.PageHandler),
 
                        # Downloads
                        (r"/downloads", downloads.IndexHandler),
+                       (r"/downloads/cloud", StaticHandler, { "template" : "downloads/cloud.html" }),
                        (r"/downloads/mirrors", downloads.MirrorsHandler),
                        (r"/downloads/thank-you", downloads.ThankYouHandler),
                        (r"/downloads/([0-9a-z\-\.]+)", downloads.ReleaseHandler),
 
-                       # Download legacy redirection
-                       (r"/download", tornado.web.RedirectHandler, { "url" : "/downloads" }),
-                       (r"/download/([0-9a-z\-\.]+)", tornado.web.RedirectHandler, { "url" : "/downloads/{0}" }),
-
                        # Donate
                        (r"/donate", donate.DonateHandler),
                        (r"/donate/thank-you", donate.ThankYouHandler),
                        (r"/donate/error", donate.ErrorHandler),
-                       (r"/donation", tornado.web.RedirectHandler, { "url" : "/donate" }),
+                       (r"/donate/check-vat-number", donate.CheckVATNumberHandler),
+
+                       # Fireinfo
+                       (r"/fireinfo/?", fireinfo.IndexHandler),
+                       (r"/fireinfo/admin", fireinfo.AdminIndexHandler),
+                       (r"/fireinfo/vendors", fireinfo.VendorsHandler),
+                       (r"/fireinfo/vendors/(pci|usb)/([0-9a-f]{4})", fireinfo.VendorHandler),
+                       (r"/fireinfo/drivers/(.*)", fireinfo.DriverDetail),
+                       (r"/fireinfo/profile/random", fireinfo.RandomProfileHandler),
+                       (r"/fireinfo/profile/([a-z0-9]{40})", fireinfo.ProfileHandler),
+                       (r"/fireinfo/processors", fireinfo.ProcessorsHandler),
+                       (r"/fireinfo/releases", fireinfo.ReleasesHandler),
+
+                       # Lists
+                       (r"/lists", lists.IndexHandler),
 
                        # Password Reset
                        (r"/password\-reset", auth.PasswordResetInitiationHandler),
                        (r"/password\-reset/([a-z_][a-z0-9_-]{0,31})/(\w+)", auth.PasswordResetHandler),
+                       (r"/.well-known/change-password", auth.WellKnownChangePasswordHandler),
+
+                       # Location
+                       (r"/location/?", StaticHandler, { "template" : "location/index.html" }),
+                       (r"/location/download", tornado.web.RedirectHandler, { "url" : "/location/install" }),
+                       (r"/location/how\-to\-use", StaticHandler, { "template" : "location/how-to-use/index.html" }),
+                       (r"/location/how\-to\-use/cli", StaticHandler, { "template" : "location/how-to-use/cli.html" }),
+                       (r"/location/how\-to\-use/dns", StaticHandler, { "template" : "location/how-to-use/dns.html" }),
+                       (r"/location/how\-to\-use/python", StaticHandler, { "template" : "location/how-to-use/python.html" }),
+                       (r"/location/install", StaticHandler, { "template" : "location/install.html" }),
+                       (r"/location/report\-a\-problem", StaticHandler, { "template" : "location/report-a-problem.html" }),
+                       (r"/location/lookup/(.+)", location.LookupHandler),
 
                        # Single-Sign-On for Discourse
                        (r"/sso/discourse", auth.SSODiscourse),
@@ -166,23 +216,40 @@ class Application(tornado.web.Application):
                        (r"/users", users.IndexHandler),
                        (r"/users/([a-z_][a-z0-9_-]{0,31})", users.ShowHandler),
                        (r"/users/([a-z_][a-z0-9_-]{0,31})\.jpg", users.AvatarHandler),
+                       (r"/users/([a-z_][a-z0-9_-]{0,31})/delete", users.DeleteHandler),
+                       (r"/users/([a-z_][a-z0-9_-]{0,31})/edit", users.EditHandler),
+                       (r"/users/([a-z_][a-z0-9_-]{0,31})/passwd", users.PasswdHandler),
 
-                       # RSS feed
-                       (r"/news.rss", tornado.web.RedirectHandler, { "url" : "https://blog.ipfire.org/feed.xml" }),
+                       # Promotional Consent Stuff
+                       (r"/subscribe", users.SubscribeHandler),
+                       (r"/unsubscribe", users.UnsubscribeHandler),
 
-                       # Redirect news articles to blog
-                       (r"/news/(.*)", handlers.NewsHandler),
+                       # VoIP
+                       (r"/voip", voip.IndexHandler),
 
                        # Static Pages
-                       (r"/about",  StaticHandler, { "template" : "about.html" }),
-                       (r"/legal", StaticHandler, { "template" : "legal.html" }),
-                       (r"/help", StaticHandler, { "template" : "help.html" }),
+                       (r"/about",  StaticHandler, { "template" : "static/about.html" }),
+                       (r"/legal", StaticHandler, { "template" : "static/legal.html" }),
+                       (r"/help", StaticHandler, { "template" : "static/help.html" }),
+                       (r"/partners", StaticHandler, { "template" : "static/partners.html" }),
+                       (r"/sitemap",  StaticHandler, { "template" : "static/sitemap.html" }),
+
+                       # API
+                       (r"/api/check/email", auth.APICheckEmail),
+                       (r"/api/check/uid", auth.APICheckUID),
 
                        # Handle old pages that have moved elsewhere
+                       (r"/blog/authors/(\w+)", tornado.web.RedirectHandler, { "url" : "/users/{0}" }),
+                       (r"/donation", tornado.web.RedirectHandler, { "url" : "/donate" }),
+                       (r"/download", tornado.web.RedirectHandler, { "url" : "/downloads" }),
+                       (r"/download/([0-9a-z\-\.]+)", tornado.web.RedirectHandler, { "url" : "/downloads/{0}" }),
                        (r"/features", tornado.web.RedirectHandler, { "url" : "/about" }),
                        (r"/imprint", tornado.web.RedirectHandler, { "url" : "/legal" }),
-                       (r"/(de|en)/(.*)", LangCompatHandler),
+                       (r"/news.rss", tornado.web.RedirectHandler, { "url" : "/blog/feed.xml" }),
+                       (r"/news/(.*)", tornado.web.RedirectHandler, { "url" : "/blog/{0}" }),
+                       (r"/projects(/.*)", tornado.web.RedirectHandler, { "url" : "{0}" }),
                        (r"/support", tornado.web.RedirectHandler, { "url" : "/help"}),
+                       (r"/(de|en)/(.*)", tornado.web.RedirectHandler, { "url" : "/{0}"}),
 
                        # Export arbitrary error pages
                        (r"/error/([45][0-9]{2})", base.ErrorHandler),
@@ -218,8 +285,8 @@ class Application(tornado.web.Application):
                # planet.ipfire.org
                self.add_handlers(r"planet\.([a-z]+\.dev\.)?ipfire\.org", [
                        (r"/", tornado.web.RedirectHandler, { "url" : "https://blog.ipfire.org/" }),
-                       (r"/post/([A-Za-z0-9_-]+)", handlers.PlanetPostHandler),
-                       (r"/user/([a-z0-9_-]+)", handlers.PlanetUserHandler),
+                       (r"/post/([A-Za-z0-9_-]+)", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/blog/{0}" }),
+                       (r"/user/([a-z0-9_-]+)", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/blog/authors/{0}" }),
 
                        # RSS
                        (r"/rss", tornado.web.RedirectHandler, { "url" : "https://blog.ipfire.org/feed.xml" }),
@@ -229,32 +296,12 @@ class Application(tornado.web.Application):
 
                # fireinfo.ipfire.org
                self.add_handlers(r"fireinfo\.([a-z]+\.dev\.)?ipfire\.org", [
-                       (r"/", fireinfo.IndexHandler),
-
-                       # Admin
-                       (r"/admin", fireinfo.AdminIndexHandler),
-
-                       # Vendors
-                       (r"/vendors", fireinfo.VendorsHandler),
-                       (r"/vendors/(pci|usb)/([0-9a-f]{4})", fireinfo.VendorHandler),
-
-                       # Driver
-                       (r"/drivers/(.*)", fireinfo.DriverDetail),
-
-                       # Show profiles
-                       (r"/profile/random", fireinfo.RandomProfileHandler),
-                       (r"/profile/([a-z0-9]{40})", fireinfo.ProfileHandler),
-
-                       # Stats
-                       (r"/processors", fireinfo.ProcessorsHandler),
-                       (r"/releases", fireinfo.ReleasesHandler),
-
-                       # Send profiles
+                       # Handle profiles
                        (r"/send/([a-z0-9]+)", fireinfo.ProfileSendHandler),
 
-                       # Serve any static files
-                       (r"/static/(.*)", tornado.web.StaticFileHandler, { "path" : self.settings.get("static_path") }),
-               ] + authentication_handlers)
+                       # Redirect anything else
+                       (r"(.*)", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/fireinfo{0}" }),
+               ])
 
                # i-use.ipfire.org
                self.add_handlers(r"i-use\.([a-z]+\.dev\.)?ipfire\.org", [
@@ -280,6 +327,9 @@ class Application(tornado.web.Application):
                # nopaste.ipfire.org
                self.add_handlers(r"nopaste\.([a-z]+\.dev\.)?ipfire\.org", [
                        (r"/", nopaste.CreateHandler),
+                       (r"/upload", nopaste.UploadHandler),
+
+                       # View
                        (r"/raw/(.*)", nopaste.RawHandler),
                        (r"/view/(.*)", nopaste.ViewHandler),
 
@@ -289,14 +339,7 @@ class Application(tornado.web.Application):
 
                # location.ipfire.org
                self.add_handlers(r"location\.([a-z]+\.dev\.)?ipfire\.org", [
-                       (r"/", location.IndexHandler),
-                       (r"/download", StaticHandler, { "template" : "../location/download.html" }),
-                       (r"/how\-to\-use", StaticHandler, { "template" : "../location/how-to-use.html" }),
-                       (r"/lookup/(.+)/blacklists", location.BlacklistsHandler),
-                       (r"/lookup/(.+)", location.LookupHandler),
-
-                       # Serve any static files
-                       (r"/static/(.*)", tornado.web.StaticFileHandler, { "path" : self.settings.get("static_path") }),
+                       (r"(.*)", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/location{0}" }),
                ])
 
                # geoip.ipfire.org
@@ -311,60 +354,21 @@ class Application(tornado.web.Application):
 
                # people.ipfire.org
                self.add_handlers(r"people\.([a-z]+\.dev\.)?ipfire\.org", [
-                       (r"/", people.IndexHandler),
-                       (r"/activate/([a-z_][a-z0-9_-]{0,31})/(\w+)", auth.ActivateHandler),
-                       (r"/conferences", people.ConferencesHandler),
-                       (r"/register", auth.RegisterHandler),
-                       (r"/users/([a-z_][a-z0-9_-]{0,31})/calls/([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})", people.CallHandler),
-                       (r"/users/([a-z_][a-z0-9_-]{0,31})/calls(?:/(\d{4}-\d{2}-\d{2}))?", people.CallsHandler),
-                       (r"/users/([a-z_][a-z0-9_-]{0,31})/edit", people.UserEditHandler),
-                       (r"/users/([a-z_][a-z0-9_-]{0,31})/passwd", people.UserPasswdHandler),
-                       (r"/users/([a-z_][a-z0-9_-]{0,31})/sip", people.SIPHandler),
-
-                       # Promotional Consent Stuff
-                       (r"/subscribe", people.SubscribeHandler),
-                       (r"/unsubscribe", people.UnsubscribeHandler),
-
-                       # Serve any static files
-                       (r"/static/(.*)", tornado.web.StaticFileHandler, { "path" : self.settings.get("static_path") }),
-
-                       # API
-                       (r"/api/check/email", auth.APICheckEmail),
-                       (r"/api/check/uid", auth.APICheckUID),
-               ]  + authentication_handlers)
+                       (r"/", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/users" }),
+                       (r"/register", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/join" }),
+                       (r"/users", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/users" }),
+                       (r"/users/([a-z_][a-z0-9_-]{0,31})", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/users/{0}" }),
+                       (r"/users/([a-z_][a-z0-9_-]{0,31})\.jpg", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/users/{0}.jpg" }),
+               ])
 
                # wiki.ipfire.org
-               self.add_handlers(r"wiki\.([a-z]+\.dev\.)?ipfire\.org",
-                       authentication_handlers + [
-
-                       # Actions
-                       (r"((?:[A-Za-z0-9\-_\/]+)?(?:.*)\.(?:\w+))/_delete", wiki.ActionDeleteHandler),
-                       (r"([A-Za-z0-9\-_\/]+)?/_edit", wiki.ActionEditHandler),
-                       (r"([A-Za-z0-9\-_\/]+)?/_render", wiki.ActionRenderHandler),
-                       (r"([A-Za-z0-9\-_\/]+)?/_(watch|unwatch)", wiki.ActionWatchHandler),
-                       (r"/actions/restore", wiki.ActionRestoreHandler),
-                       (r"/actions/upload", wiki.ActionUploadHandler),
-
-                       # Handlers
-                       (r"/recent\-changes", wiki.RecentChangesHandler),
-                       (r"/search", wiki.SearchHandler),
-                       (r"/tree", wiki.TreeHandler),
-                       (r"/watchlist", wiki.WatchlistHandler),
-
-                       # Media
-                       (r"([A-Za-z0-9\-_\/]+)?/_files", wiki.FilesHandler),
-                       (r"((?!/static)(?:[A-Za-z0-9\-_\/]+)?(?:.*)\.(?:\w+))$", wiki.FileHandler),
-
-                       # Serve any static files
-                       (r"/static/(.*)", tornado.web.StaticFileHandler, { "path" : self.settings.get("static_path") }),
-
-                       # Render pages
-                       (r"([A-Za-z0-9\-_\/]+)?", wiki.PageHandler),
+               self.add_handlers(r"wiki\.([a-z]+\.dev\.)?ipfire\.org", [
+                       (r"(.*)", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/docs{0}" }),
                ])
 
                # ipfire.org
-               self.add_handlers(r"(.*)ipfire\.org", [
-                       (r".*", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org" })
+               self.add_handlers(r"([a-z]+\.dev\.)?ipfire\.org", [
+                       (r".*", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/" })
                ])
 
                logging.info("Successfully initialied application")