from .handlers import *
+from . import analytics
from . import auth
from . import blog
from . import boot
from . import downloads
from . import fireinfo
from . import iuse
+from . import lists
from . import location
from . import nopaste
from . import ui_modules
# 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,
"VoIPRegistrations" : voip.RegistrationsModule,
# Misc
- "ChristmasBanner" : ui_modules.ChristmasBannerModule,
"IPFireLogo" : ui_modules.IPFireLogoModule,
"Markdown" : ui_modules.MarkdownModule,
"Map" : ui_modules.MapModule,
# 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/drafts", blog.DraftsHandler),
(r"/blog/feed.xml", blog.FeedHandler),
- (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/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\-_\/]+)?(?:.*)\.(?:\w+))/_delete", docs.DeleteFileHandler),
- (r"/docs((?:[A-Za-z0-9\-_\/]+)?(?:.*)\.(?:\w+))$", docs.FileHandler),
- (r"/docs(?:/([A-Za-z0-9\-_\/]+))?/_files", docs.FilesHandler),
- (r"/docs(?:/([A-Za-z0-9\-_\/]+))?", docs.PageHandler),
+ (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),
(r"/donate", donate.DonateHandler),
(r"/donate/thank-you", donate.ThankYouHandler),
(r"/donate/error", donate.ErrorHandler),
+ (r"/donate/check-vat-number", donate.CheckVATNumberHandler),
+
+ # 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),
# Projects
(r"/projects/location", location.IndexHandler),
- (r"/projects/location/download", StaticHandler, { "template" : "../location/download.html" }),
- (r"/projects/location/how\-to\-use", StaticHandler, { "template" : "../location/how-to-use.html" }),
+ (r"/projects/location/download", StaticHandler, { "template" : "location/download.html" }),
+ (r"/projects/location/how\-to\-use", StaticHandler, { "template" : "location/how-to-use.html" }),
(r"/projects/location/lookup/(.+)", location.LookupHandler),
# Single-Sign-On for Discourse
(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"/sitemap", StaticHandler, { "template" : "sitemap.html" }),
+ (r"/about", StaticHandler, { "template" : "static/about.html" }),
+ (r"/legal", StaticHandler, { "template" : "static/legal.html" }),
+ (r"/help", StaticHandler, { "template" : "static/help.html" }),
+ (r"/sitemap", StaticHandler, { "template" : "static/sitemap.html" }),
# API
(r"/api/check/email", auth.APICheckEmail),
# people.ipfire.org
self.add_handlers(r"people\.([a-z]+\.dev\.)?ipfire\.org", [
(r"/", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/users" }),
- (r"/register", tornado.web.RedirectHandler, { "url" : "https://www.ipfire.org/register" }),
+ (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" }),