d0318191c9
Refactored the menu system. Updated the README and revamped it a tad to make it easier to understand. Also, added manual instructions for patching. Revamped the update scripts, especially on Windows. Merged the CSS and Tmpl phrase namespaces. Added lastSchema to .gitignore Added DropTable to the database adapters. Implemented DbVersion in the PgSQL Adapter. Swapped out the checkboxes for cleaner looking yes-no dropdowns. Began revamping small bits of the user logic. We now open to contributions, just open a pull request and sign the CLA. Schema has been updated, run the patcher or update script.
1879 lines
55 KiB
Go
1879 lines
55 KiB
Go
// Code generated by. DO NOT EDIT.
|
|
/* This file was automatically generated by the software. Please don't edit it as your changes may be overwritten at any moment. */
|
|
package main
|
|
|
|
import (
|
|
"log"
|
|
"strings"
|
|
"strconv"
|
|
"sync"
|
|
"errors"
|
|
"os"
|
|
"net/http"
|
|
|
|
"./common"
|
|
"./common/counters"
|
|
"./routes"
|
|
)
|
|
|
|
var ErrNoRoute = errors.New("That route doesn't exist.")
|
|
// TODO: What about the /uploads/ route? x.x
|
|
var RouteMap = map[string]interface{}{
|
|
"routeAPI": routeAPI,
|
|
"routes.Overview": routes.Overview,
|
|
"routes.CustomPage": routes.CustomPage,
|
|
"routes.ForumList": routes.ForumList,
|
|
"routes.ViewForum": routes.ViewForum,
|
|
"routeChangeTheme": routeChangeTheme,
|
|
"routeShowAttachment": routeShowAttachment,
|
|
"common.RouteWebsockets": common.RouteWebsockets,
|
|
"routeReportSubmit": routeReportSubmit,
|
|
"routes.CreateTopic": routes.CreateTopic,
|
|
"routes.TopicList": routes.TopicList,
|
|
"routePanelForums": routePanelForums,
|
|
"routePanelForumsCreateSubmit": routePanelForumsCreateSubmit,
|
|
"routePanelForumsDelete": routePanelForumsDelete,
|
|
"routePanelForumsDeleteSubmit": routePanelForumsDeleteSubmit,
|
|
"routePanelForumsEdit": routePanelForumsEdit,
|
|
"routePanelForumsEditSubmit": routePanelForumsEditSubmit,
|
|
"routePanelForumsEditPermsSubmit": routePanelForumsEditPermsSubmit,
|
|
"routePanelForumsEditPermsAdvance": routePanelForumsEditPermsAdvance,
|
|
"routePanelForumsEditPermsAdvanceSubmit": routePanelForumsEditPermsAdvanceSubmit,
|
|
"routePanelSettings": routePanelSettings,
|
|
"routePanelSettingEdit": routePanelSettingEdit,
|
|
"routePanelSettingEditSubmit": routePanelSettingEditSubmit,
|
|
"routePanelWordFilters": routePanelWordFilters,
|
|
"routePanelWordFiltersCreateSubmit": routePanelWordFiltersCreateSubmit,
|
|
"routePanelWordFiltersEdit": routePanelWordFiltersEdit,
|
|
"routePanelWordFiltersEditSubmit": routePanelWordFiltersEditSubmit,
|
|
"routePanelWordFiltersDeleteSubmit": routePanelWordFiltersDeleteSubmit,
|
|
"routePanelThemes": routePanelThemes,
|
|
"routePanelThemesSetDefault": routePanelThemesSetDefault,
|
|
"routePanelThemesMenus": routePanelThemesMenus,
|
|
"routePanelThemesMenusEdit": routePanelThemesMenusEdit,
|
|
"routePanelThemesMenuItemEdit": routePanelThemesMenuItemEdit,
|
|
"routePanelThemesMenuItemEditSubmit": routePanelThemesMenuItemEditSubmit,
|
|
"routePanelPlugins": routePanelPlugins,
|
|
"routePanelPluginsActivate": routePanelPluginsActivate,
|
|
"routePanelPluginsDeactivate": routePanelPluginsDeactivate,
|
|
"routePanelPluginsInstall": routePanelPluginsInstall,
|
|
"routePanelUsers": routePanelUsers,
|
|
"routePanelUsersEdit": routePanelUsersEdit,
|
|
"routePanelUsersEditSubmit": routePanelUsersEditSubmit,
|
|
"routePanelAnalyticsViews": routePanelAnalyticsViews,
|
|
"routePanelAnalyticsRoutes": routePanelAnalyticsRoutes,
|
|
"routePanelAnalyticsAgents": routePanelAnalyticsAgents,
|
|
"routePanelAnalyticsSystems": routePanelAnalyticsSystems,
|
|
"routePanelAnalyticsLanguages": routePanelAnalyticsLanguages,
|
|
"routePanelAnalyticsReferrers": routePanelAnalyticsReferrers,
|
|
"routePanelAnalyticsRouteViews": routePanelAnalyticsRouteViews,
|
|
"routePanelAnalyticsAgentViews": routePanelAnalyticsAgentViews,
|
|
"routePanelAnalyticsForumViews": routePanelAnalyticsForumViews,
|
|
"routePanelAnalyticsSystemViews": routePanelAnalyticsSystemViews,
|
|
"routePanelAnalyticsLanguageViews": routePanelAnalyticsLanguageViews,
|
|
"routePanelAnalyticsReferrerViews": routePanelAnalyticsReferrerViews,
|
|
"routePanelAnalyticsPosts": routePanelAnalyticsPosts,
|
|
"routePanelAnalyticsTopics": routePanelAnalyticsTopics,
|
|
"routePanelAnalyticsForums": routePanelAnalyticsForums,
|
|
"routePanelGroups": routePanelGroups,
|
|
"routePanelGroupsEdit": routePanelGroupsEdit,
|
|
"routePanelGroupsEditPerms": routePanelGroupsEditPerms,
|
|
"routePanelGroupsEditSubmit": routePanelGroupsEditSubmit,
|
|
"routePanelGroupsEditPermsSubmit": routePanelGroupsEditPermsSubmit,
|
|
"routePanelGroupsCreateSubmit": routePanelGroupsCreateSubmit,
|
|
"routePanelBackups": routePanelBackups,
|
|
"routePanelLogsMod": routePanelLogsMod,
|
|
"routePanelDebug": routePanelDebug,
|
|
"routePanelDashboard": routePanelDashboard,
|
|
"routes.AccountEditCritical": routes.AccountEditCritical,
|
|
"routeAccountEditCriticalSubmit": routeAccountEditCriticalSubmit,
|
|
"routeAccountEditAvatar": routeAccountEditAvatar,
|
|
"routeAccountEditAvatarSubmit": routeAccountEditAvatarSubmit,
|
|
"routeAccountEditUsername": routeAccountEditUsername,
|
|
"routeAccountEditUsernameSubmit": routeAccountEditUsernameSubmit,
|
|
"routeAccountEditEmail": routeAccountEditEmail,
|
|
"routeAccountEditEmailTokenSubmit": routeAccountEditEmailTokenSubmit,
|
|
"routes.ViewProfile": routes.ViewProfile,
|
|
"routes.BanUserSubmit": routes.BanUserSubmit,
|
|
"routes.UnbanUser": routes.UnbanUser,
|
|
"routes.ActivateUser": routes.ActivateUser,
|
|
"routes.IPSearch": routes.IPSearch,
|
|
"routes.CreateTopicSubmit": routes.CreateTopicSubmit,
|
|
"routes.EditTopicSubmit": routes.EditTopicSubmit,
|
|
"routes.DeleteTopicSubmit": routes.DeleteTopicSubmit,
|
|
"routes.StickTopicSubmit": routes.StickTopicSubmit,
|
|
"routes.UnstickTopicSubmit": routes.UnstickTopicSubmit,
|
|
"routes.LockTopicSubmit": routes.LockTopicSubmit,
|
|
"routes.UnlockTopicSubmit": routes.UnlockTopicSubmit,
|
|
"routes.MoveTopicSubmit": routes.MoveTopicSubmit,
|
|
"routeLikeTopicSubmit": routeLikeTopicSubmit,
|
|
"routes.ViewTopic": routes.ViewTopic,
|
|
"routes.CreateReplySubmit": routes.CreateReplySubmit,
|
|
"routes.ReplyEditSubmit": routes.ReplyEditSubmit,
|
|
"routes.ReplyDeleteSubmit": routes.ReplyDeleteSubmit,
|
|
"routeReplyLikeSubmit": routeReplyLikeSubmit,
|
|
"routeProfileReplyCreateSubmit": routeProfileReplyCreateSubmit,
|
|
"routes.ProfileReplyEditSubmit": routes.ProfileReplyEditSubmit,
|
|
"routes.ProfileReplyDeleteSubmit": routes.ProfileReplyDeleteSubmit,
|
|
"routes.PollVote": routes.PollVote,
|
|
"routes.PollResults": routes.PollResults,
|
|
"routes.AccountLogin": routes.AccountLogin,
|
|
"routes.AccountRegister": routes.AccountRegister,
|
|
"routeLogout": routeLogout,
|
|
"routes.AccountLoginSubmit": routes.AccountLoginSubmit,
|
|
"routes.AccountRegisterSubmit": routes.AccountRegisterSubmit,
|
|
"routeDynamic": routeDynamic,
|
|
"routeUploads": routeUploads,
|
|
"routes.StaticFile": routes.StaticFile,
|
|
"routes.RobotsTxt": routes.RobotsTxt,
|
|
"routes.SitemapXml": routes.SitemapXml,
|
|
"BadRoute": BadRoute,
|
|
}
|
|
|
|
// ! NEVER RELY ON THESE REMAINING THE SAME BETWEEN COMMITS
|
|
var routeMapEnum = map[string]int{
|
|
"routeAPI": 0,
|
|
"routes.Overview": 1,
|
|
"routes.CustomPage": 2,
|
|
"routes.ForumList": 3,
|
|
"routes.ViewForum": 4,
|
|
"routeChangeTheme": 5,
|
|
"routeShowAttachment": 6,
|
|
"common.RouteWebsockets": 7,
|
|
"routeReportSubmit": 8,
|
|
"routes.CreateTopic": 9,
|
|
"routes.TopicList": 10,
|
|
"routePanelForums": 11,
|
|
"routePanelForumsCreateSubmit": 12,
|
|
"routePanelForumsDelete": 13,
|
|
"routePanelForumsDeleteSubmit": 14,
|
|
"routePanelForumsEdit": 15,
|
|
"routePanelForumsEditSubmit": 16,
|
|
"routePanelForumsEditPermsSubmit": 17,
|
|
"routePanelForumsEditPermsAdvance": 18,
|
|
"routePanelForumsEditPermsAdvanceSubmit": 19,
|
|
"routePanelSettings": 20,
|
|
"routePanelSettingEdit": 21,
|
|
"routePanelSettingEditSubmit": 22,
|
|
"routePanelWordFilters": 23,
|
|
"routePanelWordFiltersCreateSubmit": 24,
|
|
"routePanelWordFiltersEdit": 25,
|
|
"routePanelWordFiltersEditSubmit": 26,
|
|
"routePanelWordFiltersDeleteSubmit": 27,
|
|
"routePanelThemes": 28,
|
|
"routePanelThemesSetDefault": 29,
|
|
"routePanelThemesMenus": 30,
|
|
"routePanelThemesMenusEdit": 31,
|
|
"routePanelThemesMenuItemEdit": 32,
|
|
"routePanelThemesMenuItemEditSubmit": 33,
|
|
"routePanelPlugins": 34,
|
|
"routePanelPluginsActivate": 35,
|
|
"routePanelPluginsDeactivate": 36,
|
|
"routePanelPluginsInstall": 37,
|
|
"routePanelUsers": 38,
|
|
"routePanelUsersEdit": 39,
|
|
"routePanelUsersEditSubmit": 40,
|
|
"routePanelAnalyticsViews": 41,
|
|
"routePanelAnalyticsRoutes": 42,
|
|
"routePanelAnalyticsAgents": 43,
|
|
"routePanelAnalyticsSystems": 44,
|
|
"routePanelAnalyticsLanguages": 45,
|
|
"routePanelAnalyticsReferrers": 46,
|
|
"routePanelAnalyticsRouteViews": 47,
|
|
"routePanelAnalyticsAgentViews": 48,
|
|
"routePanelAnalyticsForumViews": 49,
|
|
"routePanelAnalyticsSystemViews": 50,
|
|
"routePanelAnalyticsLanguageViews": 51,
|
|
"routePanelAnalyticsReferrerViews": 52,
|
|
"routePanelAnalyticsPosts": 53,
|
|
"routePanelAnalyticsTopics": 54,
|
|
"routePanelAnalyticsForums": 55,
|
|
"routePanelGroups": 56,
|
|
"routePanelGroupsEdit": 57,
|
|
"routePanelGroupsEditPerms": 58,
|
|
"routePanelGroupsEditSubmit": 59,
|
|
"routePanelGroupsEditPermsSubmit": 60,
|
|
"routePanelGroupsCreateSubmit": 61,
|
|
"routePanelBackups": 62,
|
|
"routePanelLogsMod": 63,
|
|
"routePanelDebug": 64,
|
|
"routePanelDashboard": 65,
|
|
"routes.AccountEditCritical": 66,
|
|
"routeAccountEditCriticalSubmit": 67,
|
|
"routeAccountEditAvatar": 68,
|
|
"routeAccountEditAvatarSubmit": 69,
|
|
"routeAccountEditUsername": 70,
|
|
"routeAccountEditUsernameSubmit": 71,
|
|
"routeAccountEditEmail": 72,
|
|
"routeAccountEditEmailTokenSubmit": 73,
|
|
"routes.ViewProfile": 74,
|
|
"routes.BanUserSubmit": 75,
|
|
"routes.UnbanUser": 76,
|
|
"routes.ActivateUser": 77,
|
|
"routes.IPSearch": 78,
|
|
"routes.CreateTopicSubmit": 79,
|
|
"routes.EditTopicSubmit": 80,
|
|
"routes.DeleteTopicSubmit": 81,
|
|
"routes.StickTopicSubmit": 82,
|
|
"routes.UnstickTopicSubmit": 83,
|
|
"routes.LockTopicSubmit": 84,
|
|
"routes.UnlockTopicSubmit": 85,
|
|
"routes.MoveTopicSubmit": 86,
|
|
"routeLikeTopicSubmit": 87,
|
|
"routes.ViewTopic": 88,
|
|
"routes.CreateReplySubmit": 89,
|
|
"routes.ReplyEditSubmit": 90,
|
|
"routes.ReplyDeleteSubmit": 91,
|
|
"routeReplyLikeSubmit": 92,
|
|
"routeProfileReplyCreateSubmit": 93,
|
|
"routes.ProfileReplyEditSubmit": 94,
|
|
"routes.ProfileReplyDeleteSubmit": 95,
|
|
"routes.PollVote": 96,
|
|
"routes.PollResults": 97,
|
|
"routes.AccountLogin": 98,
|
|
"routes.AccountRegister": 99,
|
|
"routeLogout": 100,
|
|
"routes.AccountLoginSubmit": 101,
|
|
"routes.AccountRegisterSubmit": 102,
|
|
"routeDynamic": 103,
|
|
"routeUploads": 104,
|
|
"routes.StaticFile": 105,
|
|
"routes.RobotsTxt": 106,
|
|
"routes.SitemapXml": 107,
|
|
"BadRoute": 108,
|
|
}
|
|
var reverseRouteMapEnum = map[int]string{
|
|
0: "routeAPI",
|
|
1: "routes.Overview",
|
|
2: "routes.CustomPage",
|
|
3: "routes.ForumList",
|
|
4: "routes.ViewForum",
|
|
5: "routeChangeTheme",
|
|
6: "routeShowAttachment",
|
|
7: "common.RouteWebsockets",
|
|
8: "routeReportSubmit",
|
|
9: "routes.CreateTopic",
|
|
10: "routes.TopicList",
|
|
11: "routePanelForums",
|
|
12: "routePanelForumsCreateSubmit",
|
|
13: "routePanelForumsDelete",
|
|
14: "routePanelForumsDeleteSubmit",
|
|
15: "routePanelForumsEdit",
|
|
16: "routePanelForumsEditSubmit",
|
|
17: "routePanelForumsEditPermsSubmit",
|
|
18: "routePanelForumsEditPermsAdvance",
|
|
19: "routePanelForumsEditPermsAdvanceSubmit",
|
|
20: "routePanelSettings",
|
|
21: "routePanelSettingEdit",
|
|
22: "routePanelSettingEditSubmit",
|
|
23: "routePanelWordFilters",
|
|
24: "routePanelWordFiltersCreateSubmit",
|
|
25: "routePanelWordFiltersEdit",
|
|
26: "routePanelWordFiltersEditSubmit",
|
|
27: "routePanelWordFiltersDeleteSubmit",
|
|
28: "routePanelThemes",
|
|
29: "routePanelThemesSetDefault",
|
|
30: "routePanelThemesMenus",
|
|
31: "routePanelThemesMenusEdit",
|
|
32: "routePanelThemesMenuItemEdit",
|
|
33: "routePanelThemesMenuItemEditSubmit",
|
|
34: "routePanelPlugins",
|
|
35: "routePanelPluginsActivate",
|
|
36: "routePanelPluginsDeactivate",
|
|
37: "routePanelPluginsInstall",
|
|
38: "routePanelUsers",
|
|
39: "routePanelUsersEdit",
|
|
40: "routePanelUsersEditSubmit",
|
|
41: "routePanelAnalyticsViews",
|
|
42: "routePanelAnalyticsRoutes",
|
|
43: "routePanelAnalyticsAgents",
|
|
44: "routePanelAnalyticsSystems",
|
|
45: "routePanelAnalyticsLanguages",
|
|
46: "routePanelAnalyticsReferrers",
|
|
47: "routePanelAnalyticsRouteViews",
|
|
48: "routePanelAnalyticsAgentViews",
|
|
49: "routePanelAnalyticsForumViews",
|
|
50: "routePanelAnalyticsSystemViews",
|
|
51: "routePanelAnalyticsLanguageViews",
|
|
52: "routePanelAnalyticsReferrerViews",
|
|
53: "routePanelAnalyticsPosts",
|
|
54: "routePanelAnalyticsTopics",
|
|
55: "routePanelAnalyticsForums",
|
|
56: "routePanelGroups",
|
|
57: "routePanelGroupsEdit",
|
|
58: "routePanelGroupsEditPerms",
|
|
59: "routePanelGroupsEditSubmit",
|
|
60: "routePanelGroupsEditPermsSubmit",
|
|
61: "routePanelGroupsCreateSubmit",
|
|
62: "routePanelBackups",
|
|
63: "routePanelLogsMod",
|
|
64: "routePanelDebug",
|
|
65: "routePanelDashboard",
|
|
66: "routes.AccountEditCritical",
|
|
67: "routeAccountEditCriticalSubmit",
|
|
68: "routeAccountEditAvatar",
|
|
69: "routeAccountEditAvatarSubmit",
|
|
70: "routeAccountEditUsername",
|
|
71: "routeAccountEditUsernameSubmit",
|
|
72: "routeAccountEditEmail",
|
|
73: "routeAccountEditEmailTokenSubmit",
|
|
74: "routes.ViewProfile",
|
|
75: "routes.BanUserSubmit",
|
|
76: "routes.UnbanUser",
|
|
77: "routes.ActivateUser",
|
|
78: "routes.IPSearch",
|
|
79: "routes.CreateTopicSubmit",
|
|
80: "routes.EditTopicSubmit",
|
|
81: "routes.DeleteTopicSubmit",
|
|
82: "routes.StickTopicSubmit",
|
|
83: "routes.UnstickTopicSubmit",
|
|
84: "routes.LockTopicSubmit",
|
|
85: "routes.UnlockTopicSubmit",
|
|
86: "routes.MoveTopicSubmit",
|
|
87: "routeLikeTopicSubmit",
|
|
88: "routes.ViewTopic",
|
|
89: "routes.CreateReplySubmit",
|
|
90: "routes.ReplyEditSubmit",
|
|
91: "routes.ReplyDeleteSubmit",
|
|
92: "routeReplyLikeSubmit",
|
|
93: "routeProfileReplyCreateSubmit",
|
|
94: "routes.ProfileReplyEditSubmit",
|
|
95: "routes.ProfileReplyDeleteSubmit",
|
|
96: "routes.PollVote",
|
|
97: "routes.PollResults",
|
|
98: "routes.AccountLogin",
|
|
99: "routes.AccountRegister",
|
|
100: "routeLogout",
|
|
101: "routes.AccountLoginSubmit",
|
|
102: "routes.AccountRegisterSubmit",
|
|
103: "routeDynamic",
|
|
104: "routeUploads",
|
|
105: "routes.StaticFile",
|
|
106: "routes.RobotsTxt",
|
|
107: "routes.SitemapXml",
|
|
108: "BadRoute",
|
|
}
|
|
var osMapEnum = map[string]int{
|
|
"unknown": 0,
|
|
"windows": 1,
|
|
"linux": 2,
|
|
"mac": 3,
|
|
"android": 4,
|
|
"iphone": 5,
|
|
}
|
|
var reverseOSMapEnum = map[int]string{
|
|
0: "unknown",
|
|
1: "windows",
|
|
2: "linux",
|
|
3: "mac",
|
|
4: "android",
|
|
5: "iphone",
|
|
}
|
|
var agentMapEnum = map[string]int{
|
|
"unknown": 0,
|
|
"firefox": 1,
|
|
"chrome": 2,
|
|
"opera": 3,
|
|
"safari": 4,
|
|
"edge": 5,
|
|
"internetexplorer": 6,
|
|
"trident": 7,
|
|
"androidchrome": 8,
|
|
"mobilesafari": 9,
|
|
"samsung": 10,
|
|
"ucbrowser": 11,
|
|
"googlebot": 12,
|
|
"yandex": 13,
|
|
"bing": 14,
|
|
"baidu": 15,
|
|
"duckduckgo": 16,
|
|
"seznambot": 17,
|
|
"discord": 18,
|
|
"twitter": 19,
|
|
"cloudflare": 20,
|
|
"uptimebot": 21,
|
|
"slackbot": 22,
|
|
"discourse": 23,
|
|
"lynx": 24,
|
|
"blank": 25,
|
|
"malformed": 26,
|
|
"suspicious": 27,
|
|
"zgrab": 28,
|
|
}
|
|
var reverseAgentMapEnum = map[int]string{
|
|
0: "unknown",
|
|
1: "firefox",
|
|
2: "chrome",
|
|
3: "opera",
|
|
4: "safari",
|
|
5: "edge",
|
|
6: "internetexplorer",
|
|
7: "trident",
|
|
8: "androidchrome",
|
|
9: "mobilesafari",
|
|
10: "samsung",
|
|
11: "ucbrowser",
|
|
12: "googlebot",
|
|
13: "yandex",
|
|
14: "bing",
|
|
15: "baidu",
|
|
16: "duckduckgo",
|
|
17: "seznambot",
|
|
18: "discord",
|
|
19: "twitter",
|
|
20: "cloudflare",
|
|
21: "uptimebot",
|
|
22: "slackbot",
|
|
23: "discourse",
|
|
24: "lynx",
|
|
25: "blank",
|
|
26: "malformed",
|
|
27: "suspicious",
|
|
28: "zgrab",
|
|
}
|
|
var markToAgent = map[string]string{
|
|
"OPR":"opera",
|
|
"Chrome":"chrome",
|
|
"Firefox":"firefox",
|
|
"MSIE":"internetexplorer",
|
|
"Trident":"trident", // Hack to support IE11
|
|
"Edge":"edge",
|
|
"Lynx":"lynx", // There's a rare android variant of lynx which isn't covered by this
|
|
"SamsungBrowser":"samsung",
|
|
"UCBrowser":"ucbrowser",
|
|
|
|
"Google":"googlebot",
|
|
"Googlebot":"googlebot",
|
|
"yandex": "yandex", // from the URL
|
|
"DuckDuckBot":"duckduckgo",
|
|
"Baiduspider":"baidu",
|
|
"bingbot":"bing",
|
|
"BingPreview":"bing",
|
|
"SeznamBot":"seznambot",
|
|
"CloudFlare":"cloudflare", // Track alwayson specifically in case there are other bots?
|
|
"Uptimebot":"uptimebot",
|
|
"Slackbot":"slackbot",
|
|
"Discordbot":"discord",
|
|
"Twitterbot":"twitter",
|
|
"Discourse":"discourse",
|
|
|
|
"zgrab":"zgrab",
|
|
}
|
|
/*var agentRank = map[string]int{
|
|
"opera":9,
|
|
"chrome":8,
|
|
"safari":1,
|
|
}*/
|
|
|
|
// TODO: Stop spilling these into the package scope?
|
|
func init() {
|
|
counters.SetRouteMapEnum(routeMapEnum)
|
|
counters.SetReverseRouteMapEnum(reverseRouteMapEnum)
|
|
counters.SetAgentMapEnum(agentMapEnum)
|
|
counters.SetReverseAgentMapEnum(reverseAgentMapEnum)
|
|
counters.SetOSMapEnum(osMapEnum)
|
|
counters.SetReverseOSMapEnum(reverseOSMapEnum)
|
|
}
|
|
|
|
type WriterIntercept struct {
|
|
w http.ResponseWriter
|
|
code int
|
|
}
|
|
|
|
func NewWriterIntercept(w http.ResponseWriter) *WriterIntercept {
|
|
return &WriterIntercept{w:w,code:200}
|
|
}
|
|
|
|
func (writ *WriterIntercept) Header() http.Header {
|
|
return writ.w.Header()
|
|
}
|
|
|
|
func (writ *WriterIntercept) Write(pieces []byte) (int, error) {
|
|
return writ.w.Write(pieces)
|
|
}
|
|
|
|
func (writ *WriterIntercept) WriteHeader(code int) {
|
|
writ.w.WriteHeader(code)
|
|
writ.code = code
|
|
}
|
|
|
|
func (writ *WriterIntercept) GetCode() int {
|
|
return writ.code
|
|
}
|
|
|
|
type GenRouter struct {
|
|
UploadHandler func(http.ResponseWriter, *http.Request)
|
|
extraRoutes map[string]func(http.ResponseWriter, *http.Request, common.User) common.RouteError
|
|
requestLogger *log.Logger
|
|
|
|
sync.RWMutex
|
|
}
|
|
|
|
func NewGenRouter(uploads http.Handler) (*GenRouter, error) {
|
|
f, err := os.OpenFile("./logs/requests.log", os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0755)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &GenRouter{
|
|
UploadHandler: func(w http.ResponseWriter, req *http.Request) {
|
|
writ := NewWriterIntercept(w)
|
|
http.StripPrefix("/uploads/",uploads).ServeHTTP(writ,req)
|
|
if writ.GetCode() == 200 {
|
|
w.Header().Set("Cache-Control", "max-age=" + strconv.Itoa(common.Day))
|
|
w.Header().Set("Vary", "Accept-Encoding")
|
|
}
|
|
},
|
|
extraRoutes: make(map[string]func(http.ResponseWriter, *http.Request, common.User) common.RouteError),
|
|
requestLogger: log.New(f, "", log.LstdFlags),
|
|
}, nil
|
|
}
|
|
|
|
func (router *GenRouter) handleError(err common.RouteError, w http.ResponseWriter, r *http.Request, user common.User) {
|
|
if err.Handled() {
|
|
return
|
|
}
|
|
|
|
if err.Type() == "system" {
|
|
common.InternalErrorJSQ(err, w, r, err.JSON())
|
|
return
|
|
}
|
|
common.LocalErrorJSQ(err.Error(), w, r, user,err.JSON())
|
|
}
|
|
|
|
func (router *GenRouter) Handle(_ string, _ http.Handler) {
|
|
}
|
|
|
|
func (router *GenRouter) HandleFunc(pattern string, handle func(http.ResponseWriter, *http.Request, common.User) common.RouteError) {
|
|
router.Lock()
|
|
defer router.Unlock()
|
|
router.extraRoutes[pattern] = handle
|
|
}
|
|
|
|
func (router *GenRouter) RemoveFunc(pattern string) error {
|
|
router.Lock()
|
|
defer router.Unlock()
|
|
_, ok := router.extraRoutes[pattern]
|
|
if !ok {
|
|
return ErrNoRoute
|
|
}
|
|
delete(router.extraRoutes, pattern)
|
|
return nil
|
|
}
|
|
|
|
func (router *GenRouter) StripNewlines(data string) string {
|
|
// TODO: Strip out all sub-32s?
|
|
return strings.Replace(strings.Replace(data,"\n","",-1),"\r","",-1)
|
|
}
|
|
|
|
func (router *GenRouter) DumpRequest(req *http.Request, prepend string) {
|
|
var heads string
|
|
for key, value := range req.Header {
|
|
for _, vvalue := range value {
|
|
heads += "Header '" + router.StripNewlines(key) + "': " + router.StripNewlines(vvalue) + "!!\n"
|
|
}
|
|
}
|
|
|
|
router.requestLogger.Print(prepend +
|
|
"\nUA: " + router.StripNewlines(req.UserAgent()) + "\n" +
|
|
"Method: " + router.StripNewlines(req.Method) + "\n" + heads +
|
|
"req.Host: " + router.StripNewlines(req.Host) + "\n" +
|
|
"req.URL.Path: " + router.StripNewlines(req.URL.Path) + "\n" +
|
|
"req.URL.RawQuery: " + router.StripNewlines(req.URL.RawQuery) + "\n" +
|
|
"req.Referer(): " + router.StripNewlines(req.Referer()) + "\n" +
|
|
"req.RemoteAddr: " + req.RemoteAddr + "\n")
|
|
}
|
|
|
|
func (router *GenRouter) SuspiciousRequest(req *http.Request, prepend string) {
|
|
if prepend != "" {
|
|
prepend += "\n"
|
|
}
|
|
router.DumpRequest(req,prepend+"Suspicious Request")
|
|
counters.AgentViewCounter.Bump(27)
|
|
}
|
|
|
|
// TODO: Pass the default route or config struct to the router rather than accessing it via a package global
|
|
// TODO: SetDefaultRoute
|
|
// TODO: GetDefaultRoute
|
|
func (router *GenRouter) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
|
// Redirect www. requests to the right place
|
|
if req.Host == "www." + common.Site.Host {
|
|
w.Header().Set("Connection", "close")
|
|
var s string
|
|
if common.Site.EnableSsl {
|
|
s = "s"
|
|
}
|
|
dest := "http"+s+"://" + req.Host + req.URL.Path
|
|
if len(req.URL.RawQuery) > 0 {
|
|
dest += "?" + req.URL.RawQuery
|
|
}
|
|
http.Redirect(w, req, dest, http.StatusMovedPermanently)
|
|
return
|
|
}
|
|
|
|
// Deflect malformed requests
|
|
if len(req.URL.Path) == 0 || req.URL.Path[0] != '/' || req.Host != common.Site.Host {
|
|
w.WriteHeader(200) // 400
|
|
w.Write([]byte(""))
|
|
router.DumpRequest(req,"Malformed Request")
|
|
counters.AgentViewCounter.Bump(26)
|
|
return
|
|
}
|
|
|
|
// TODO: Cover more suspicious strings and at a lower layer than this
|
|
for _, char := range req.URL.Path {
|
|
if char != '&' && !(char > 44 && char < 58) && char != '=' && char != '?' && !(char > 64 && char < 91) && char != '\\' && char != '_' && !(char > 96 && char < 123) {
|
|
router.SuspiciousRequest(req,"")
|
|
break
|
|
}
|
|
}
|
|
lowerPath := strings.ToLower(req.URL.Path)
|
|
// TODO: Flag any requests which has a dot with anything but a number after that
|
|
if strings.Contains(req.URL.Path,"..") || strings.Contains(req.URL.Path,"--") || strings.Contains(lowerPath,".php") || strings.Contains(lowerPath,".asp") || strings.Contains(lowerPath,".cgi") || strings.Contains(lowerPath,".py") || strings.Contains(lowerPath,".sql") || strings.Contains(lowerPath,".action") {
|
|
router.SuspiciousRequest(req,"")
|
|
}
|
|
|
|
var prefix, extraData string
|
|
prefix = req.URL.Path[0:strings.IndexByte(req.URL.Path[1:],'/') + 1]
|
|
if req.URL.Path[len(req.URL.Path) - 1] != '/' {
|
|
extraData = req.URL.Path[strings.LastIndexByte(req.URL.Path,'/') + 1:]
|
|
req.URL.Path = req.URL.Path[:strings.LastIndexByte(req.URL.Path,'/') + 1]
|
|
}
|
|
|
|
if common.Dev.SuperDebug {
|
|
router.DumpRequest(req,"before routes.StaticFile")
|
|
}
|
|
// Increment the request counter
|
|
counters.GlobalViewCounter.Bump()
|
|
|
|
if prefix == "/static" {
|
|
counters.RouteViewCounter.Bump(105)
|
|
req.URL.Path += extraData
|
|
routes.StaticFile(w, req)
|
|
return
|
|
}
|
|
if common.Dev.SuperDebug {
|
|
router.requestLogger.Print("before PreRoute")
|
|
}
|
|
|
|
// Track the user agents. Unfortunately, everyone pretends to be Mozilla, so this'll be a little less efficient than I would like.
|
|
// TODO: Add a setting to disable this?
|
|
// TODO: Use a more efficient detector instead of smashing every possible combination in
|
|
ua := strings.TrimSpace(strings.Replace(strings.TrimPrefix(req.UserAgent(),"Mozilla/5.0 ")," Safari/537.36","",-1)) // Noise, no one's going to be running this and it would require some sort of agent ranking system to determine which identifier should be prioritised over another
|
|
if ua == "" {
|
|
counters.AgentViewCounter.Bump(25)
|
|
if common.Dev.DebugMode {
|
|
var prepend string
|
|
for _, char := range req.UserAgent() {
|
|
prepend += strconv.Itoa(int(char)) + " "
|
|
}
|
|
router.DumpRequest(req,"Blank UA: " + prepend)
|
|
}
|
|
} else {
|
|
var runeEquals = func(a []rune, b []rune) bool {
|
|
if len(a) != len(b) {
|
|
return false
|
|
}
|
|
for i, item := range a {
|
|
if item != b[i] {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// WIP UA Parser
|
|
var indices []int
|
|
var items []string
|
|
var buffer []rune
|
|
for index, item := range ua {
|
|
if (item > 64 && item < 91) || (item > 96 && item < 123) {
|
|
buffer = append(buffer, item)
|
|
} else if item == ' ' || item == '(' || item == ')' || item == '-' || (item > 47 && item < 58) || item == '_' || item == ';' || item == '.' || item == '+' || (item == ':' && (runeEquals(buffer,[]rune("http")) || runeEquals(buffer,[]rune("rv")))) || item == ',' || item == '/' {
|
|
if len(buffer) != 0 {
|
|
items = append(items, string(buffer))
|
|
indices = append(indices, index - 1)
|
|
buffer = buffer[:0]
|
|
}
|
|
} else {
|
|
// TODO: Test this
|
|
items = items[:0]
|
|
indices = indices[:0]
|
|
router.SuspiciousRequest(req,"")
|
|
router.requestLogger.Print("UA Buffer: ", buffer)
|
|
router.requestLogger.Print("UA Buffer String: ", string(buffer))
|
|
break
|
|
}
|
|
}
|
|
|
|
// Iterate over this in reverse as the real UA tends to be on the right side
|
|
var agent string
|
|
for i := len(items) - 1; i >= 0; i-- {
|
|
fAgent, ok := markToAgent[items[i]]
|
|
if ok {
|
|
agent = fAgent
|
|
if agent != "safari" {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
if common.Dev.SuperDebug {
|
|
router.requestLogger.Print("parsed agent: ", agent)
|
|
}
|
|
|
|
var os string
|
|
for _, mark := range items {
|
|
switch(mark) {
|
|
case "Windows":
|
|
os = "windows"
|
|
case "Linux":
|
|
os = "linux"
|
|
case "Mac":
|
|
os = "mac"
|
|
case "iPhone":
|
|
os = "iphone"
|
|
case "Android":
|
|
os = "android"
|
|
}
|
|
}
|
|
if os == "" {
|
|
os = "unknown"
|
|
}
|
|
if common.Dev.SuperDebug {
|
|
router.requestLogger.Print("os: ", os)
|
|
router.requestLogger.Printf("items: %+v\n",items)
|
|
}
|
|
|
|
// Special handling
|
|
switch(agent) {
|
|
case "chrome":
|
|
if os == "android" {
|
|
agent = "androidchrome"
|
|
}
|
|
case "safari":
|
|
if os == "iphone" {
|
|
agent = "mobilesafari"
|
|
}
|
|
case "trident":
|
|
// Hack to support IE11, change this after we start logging versions
|
|
if strings.Contains(ua,"rv:11") {
|
|
agent = "internetexplorer"
|
|
}
|
|
case "zgrab":
|
|
router.SuspiciousRequest(req,"Vulnerability Scanner")
|
|
}
|
|
|
|
if agent == "" {
|
|
counters.AgentViewCounter.Bump(0)
|
|
if common.Dev.DebugMode {
|
|
var prepend string
|
|
for _, char := range req.UserAgent() {
|
|
prepend += strconv.Itoa(int(char)) + " "
|
|
}
|
|
router.DumpRequest(req,"Blank UA: " + prepend)
|
|
}
|
|
} else {
|
|
counters.AgentViewCounter.Bump(agentMapEnum[agent])
|
|
}
|
|
counters.OSViewCounter.Bump(osMapEnum[os])
|
|
}
|
|
|
|
// TODO: Do we want to track missing language headers too? Maybe as it's own type, e.g. "noheader"?
|
|
lang := req.Header.Get("Accept-Language")
|
|
if lang != "" {
|
|
lang = strings.TrimSpace(lang)
|
|
lLang := strings.Split(lang,"-")
|
|
common.DebugDetail("lLang:", lLang)
|
|
counters.LangViewCounter.Bump(lLang[0])
|
|
} else {
|
|
counters.LangViewCounter.Bump("none")
|
|
}
|
|
|
|
referrer := req.Header.Get("Referer") // Check the 'referrer' header too? :P
|
|
if referrer != "" {
|
|
// ? Optimise this a little?
|
|
referrer = strings.TrimPrefix(strings.TrimPrefix(referrer,"http://"),"https://")
|
|
referrer = strings.Split(referrer,"/")[0]
|
|
portless := strings.Split(referrer,":")[0]
|
|
if portless != "localhost" && portless != "127.0.0.1" && portless != common.Site.Host {
|
|
counters.ReferrerTracker.Bump(referrer)
|
|
}
|
|
}
|
|
|
|
// Deal with the session stuff, etc.
|
|
user, ok := common.PreRoute(w, req)
|
|
if !ok {
|
|
return
|
|
}
|
|
if common.Dev.SuperDebug {
|
|
router.requestLogger.Print(
|
|
"after PreRoute\n" +
|
|
"routeMapEnum: ", routeMapEnum)
|
|
}
|
|
|
|
var err common.RouteError
|
|
switch(prefix) {
|
|
case "/api":
|
|
counters.RouteViewCounter.Bump(0)
|
|
err = routeAPI(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/overview":
|
|
counters.RouteViewCounter.Bump(1)
|
|
err = routes.Overview(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/pages":
|
|
counters.RouteViewCounter.Bump(2)
|
|
err = routes.CustomPage(w,req,user,extraData)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/forums":
|
|
counters.RouteViewCounter.Bump(3)
|
|
err = routes.ForumList(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/forum":
|
|
counters.RouteViewCounter.Bump(4)
|
|
err = routes.ViewForum(w,req,user,extraData)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/theme":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(5)
|
|
err = routeChangeTheme(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/attachs":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(6)
|
|
err = routeShowAttachment(w,req,user,extraData)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/ws":
|
|
req.URL.Path += extraData
|
|
counters.RouteViewCounter.Bump(7)
|
|
err = common.RouteWebsockets(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/report":
|
|
err = common.NoBanned(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
switch(req.URL.Path) {
|
|
case "/report/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(8)
|
|
err = routeReportSubmit(w,req,user,extraData)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/topics":
|
|
switch(req.URL.Path) {
|
|
case "/topics/create/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(9)
|
|
err = routes.CreateTopic(w,req,user,extraData)
|
|
default:
|
|
counters.RouteViewCounter.Bump(10)
|
|
err = routes.TopicList(w,req,user)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/panel":
|
|
err = common.SuperModOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
switch(req.URL.Path) {
|
|
case "/panel/forums/":
|
|
counters.RouteViewCounter.Bump(11)
|
|
err = routePanelForums(w,req,user)
|
|
case "/panel/forums/create/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(12)
|
|
err = routePanelForumsCreateSubmit(w,req,user)
|
|
case "/panel/forums/delete/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(13)
|
|
err = routePanelForumsDelete(w,req,user,extraData)
|
|
case "/panel/forums/delete/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(14)
|
|
err = routePanelForumsDeleteSubmit(w,req,user,extraData)
|
|
case "/panel/forums/edit/":
|
|
counters.RouteViewCounter.Bump(15)
|
|
err = routePanelForumsEdit(w,req,user,extraData)
|
|
case "/panel/forums/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(16)
|
|
err = routePanelForumsEditSubmit(w,req,user,extraData)
|
|
case "/panel/forums/edit/perms/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(17)
|
|
err = routePanelForumsEditPermsSubmit(w,req,user,extraData)
|
|
case "/panel/forums/edit/perms/":
|
|
counters.RouteViewCounter.Bump(18)
|
|
err = routePanelForumsEditPermsAdvance(w,req,user,extraData)
|
|
case "/panel/forums/edit/perms/adv/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(19)
|
|
err = routePanelForumsEditPermsAdvanceSubmit(w,req,user,extraData)
|
|
case "/panel/settings/":
|
|
counters.RouteViewCounter.Bump(20)
|
|
err = routePanelSettings(w,req,user)
|
|
case "/panel/settings/edit/":
|
|
counters.RouteViewCounter.Bump(21)
|
|
err = routePanelSettingEdit(w,req,user,extraData)
|
|
case "/panel/settings/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(22)
|
|
err = routePanelSettingEditSubmit(w,req,user,extraData)
|
|
case "/panel/settings/word-filters/":
|
|
counters.RouteViewCounter.Bump(23)
|
|
err = routePanelWordFilters(w,req,user)
|
|
case "/panel/settings/word-filters/create/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(24)
|
|
err = routePanelWordFiltersCreateSubmit(w,req,user)
|
|
case "/panel/settings/word-filters/edit/":
|
|
counters.RouteViewCounter.Bump(25)
|
|
err = routePanelWordFiltersEdit(w,req,user,extraData)
|
|
case "/panel/settings/word-filters/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(26)
|
|
err = routePanelWordFiltersEditSubmit(w,req,user,extraData)
|
|
case "/panel/settings/word-filters/delete/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(27)
|
|
err = routePanelWordFiltersDeleteSubmit(w,req,user,extraData)
|
|
case "/panel/themes/":
|
|
counters.RouteViewCounter.Bump(28)
|
|
err = routePanelThemes(w,req,user)
|
|
case "/panel/themes/default/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(29)
|
|
err = routePanelThemesSetDefault(w,req,user,extraData)
|
|
case "/panel/themes/menus/":
|
|
counters.RouteViewCounter.Bump(30)
|
|
err = routePanelThemesMenus(w,req,user)
|
|
case "/panel/themes/menus/edit/":
|
|
counters.RouteViewCounter.Bump(31)
|
|
err = routePanelThemesMenusEdit(w,req,user,extraData)
|
|
case "/panel/themes/menus/item/edit/":
|
|
counters.RouteViewCounter.Bump(32)
|
|
err = routePanelThemesMenuItemEdit(w,req,user,extraData)
|
|
case "/panel/themes/menus/item/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(33)
|
|
err = routePanelThemesMenuItemEditSubmit(w,req,user,extraData)
|
|
case "/panel/plugins/":
|
|
counters.RouteViewCounter.Bump(34)
|
|
err = routePanelPlugins(w,req,user)
|
|
case "/panel/plugins/activate/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(35)
|
|
err = routePanelPluginsActivate(w,req,user,extraData)
|
|
case "/panel/plugins/deactivate/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(36)
|
|
err = routePanelPluginsDeactivate(w,req,user,extraData)
|
|
case "/panel/plugins/install/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(37)
|
|
err = routePanelPluginsInstall(w,req,user,extraData)
|
|
case "/panel/users/":
|
|
counters.RouteViewCounter.Bump(38)
|
|
err = routePanelUsers(w,req,user)
|
|
case "/panel/users/edit/":
|
|
counters.RouteViewCounter.Bump(39)
|
|
err = routePanelUsersEdit(w,req,user,extraData)
|
|
case "/panel/users/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(40)
|
|
err = routePanelUsersEditSubmit(w,req,user,extraData)
|
|
case "/panel/analytics/views/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(41)
|
|
err = routePanelAnalyticsViews(w,req,user)
|
|
case "/panel/analytics/routes/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(42)
|
|
err = routePanelAnalyticsRoutes(w,req,user)
|
|
case "/panel/analytics/agents/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(43)
|
|
err = routePanelAnalyticsAgents(w,req,user)
|
|
case "/panel/analytics/systems/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(44)
|
|
err = routePanelAnalyticsSystems(w,req,user)
|
|
case "/panel/analytics/langs/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(45)
|
|
err = routePanelAnalyticsLanguages(w,req,user)
|
|
case "/panel/analytics/referrers/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(46)
|
|
err = routePanelAnalyticsReferrers(w,req,user)
|
|
case "/panel/analytics/route/":
|
|
counters.RouteViewCounter.Bump(47)
|
|
err = routePanelAnalyticsRouteViews(w,req,user,extraData)
|
|
case "/panel/analytics/agent/":
|
|
counters.RouteViewCounter.Bump(48)
|
|
err = routePanelAnalyticsAgentViews(w,req,user,extraData)
|
|
case "/panel/analytics/forum/":
|
|
counters.RouteViewCounter.Bump(49)
|
|
err = routePanelAnalyticsForumViews(w,req,user,extraData)
|
|
case "/panel/analytics/system/":
|
|
counters.RouteViewCounter.Bump(50)
|
|
err = routePanelAnalyticsSystemViews(w,req,user,extraData)
|
|
case "/panel/analytics/lang/":
|
|
counters.RouteViewCounter.Bump(51)
|
|
err = routePanelAnalyticsLanguageViews(w,req,user,extraData)
|
|
case "/panel/analytics/referrer/":
|
|
counters.RouteViewCounter.Bump(52)
|
|
err = routePanelAnalyticsReferrerViews(w,req,user,extraData)
|
|
case "/panel/analytics/posts/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(53)
|
|
err = routePanelAnalyticsPosts(w,req,user)
|
|
case "/panel/analytics/topics/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(54)
|
|
err = routePanelAnalyticsTopics(w,req,user)
|
|
case "/panel/analytics/forums/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(55)
|
|
err = routePanelAnalyticsForums(w,req,user)
|
|
case "/panel/groups/":
|
|
counters.RouteViewCounter.Bump(56)
|
|
err = routePanelGroups(w,req,user)
|
|
case "/panel/groups/edit/":
|
|
counters.RouteViewCounter.Bump(57)
|
|
err = routePanelGroupsEdit(w,req,user,extraData)
|
|
case "/panel/groups/edit/perms/":
|
|
counters.RouteViewCounter.Bump(58)
|
|
err = routePanelGroupsEditPerms(w,req,user,extraData)
|
|
case "/panel/groups/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(59)
|
|
err = routePanelGroupsEditSubmit(w,req,user,extraData)
|
|
case "/panel/groups/edit/perms/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(60)
|
|
err = routePanelGroupsEditPermsSubmit(w,req,user,extraData)
|
|
case "/panel/groups/create/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(61)
|
|
err = routePanelGroupsCreateSubmit(w,req,user)
|
|
case "/panel/backups/":
|
|
err = common.SuperAdminOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(62)
|
|
err = routePanelBackups(w,req,user,extraData)
|
|
case "/panel/logs/mod/":
|
|
counters.RouteViewCounter.Bump(63)
|
|
err = routePanelLogsMod(w,req,user)
|
|
case "/panel/debug/":
|
|
err = common.AdminOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(64)
|
|
err = routePanelDebug(w,req,user)
|
|
default:
|
|
counters.RouteViewCounter.Bump(65)
|
|
err = routePanelDashboard(w,req,user)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/user":
|
|
switch(req.URL.Path) {
|
|
case "/user/edit/critical/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(66)
|
|
err = routes.AccountEditCritical(w,req,user)
|
|
case "/user/edit/critical/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(67)
|
|
err = routeAccountEditCriticalSubmit(w,req,user)
|
|
case "/user/edit/avatar/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(68)
|
|
err = routeAccountEditAvatar(w,req,user)
|
|
case "/user/edit/avatar/submit/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.HandleUploadRoute(w,req,user,common.Config.MaxRequestSize)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
err = common.NoUploadSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(69)
|
|
err = routeAccountEditAvatarSubmit(w,req,user)
|
|
case "/user/edit/username/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(70)
|
|
err = routeAccountEditUsername(w,req,user)
|
|
case "/user/edit/username/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(71)
|
|
err = routeAccountEditUsernameSubmit(w,req,user)
|
|
case "/user/edit/email/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(72)
|
|
err = routeAccountEditEmail(w,req,user)
|
|
case "/user/edit/token/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(73)
|
|
err = routeAccountEditEmailTokenSubmit(w,req,user,extraData)
|
|
default:
|
|
req.URL.Path += extraData
|
|
counters.RouteViewCounter.Bump(74)
|
|
err = routes.ViewProfile(w,req,user)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/users":
|
|
switch(req.URL.Path) {
|
|
case "/users/ban/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(75)
|
|
err = routes.BanUserSubmit(w,req,user,extraData)
|
|
case "/users/unban/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(76)
|
|
err = routes.UnbanUser(w,req,user,extraData)
|
|
case "/users/activate/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(77)
|
|
err = routes.ActivateUser(w,req,user,extraData)
|
|
case "/users/ips/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(78)
|
|
err = routes.IPSearch(w,req,user)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/topic":
|
|
switch(req.URL.Path) {
|
|
case "/topic/create/submit/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.HandleUploadRoute(w,req,user,common.Config.MaxRequestSize)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
err = common.NoUploadSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(79)
|
|
err = routes.CreateTopicSubmit(w,req,user)
|
|
case "/topic/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(80)
|
|
err = routes.EditTopicSubmit(w,req,user,extraData)
|
|
case "/topic/delete/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
req.URL.Path += extraData
|
|
counters.RouteViewCounter.Bump(81)
|
|
err = routes.DeleteTopicSubmit(w,req,user)
|
|
case "/topic/stick/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(82)
|
|
err = routes.StickTopicSubmit(w,req,user,extraData)
|
|
case "/topic/unstick/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(83)
|
|
err = routes.UnstickTopicSubmit(w,req,user,extraData)
|
|
case "/topic/lock/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
req.URL.Path += extraData
|
|
counters.RouteViewCounter.Bump(84)
|
|
err = routes.LockTopicSubmit(w,req,user)
|
|
case "/topic/unlock/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(85)
|
|
err = routes.UnlockTopicSubmit(w,req,user,extraData)
|
|
case "/topic/move/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(86)
|
|
err = routes.MoveTopicSubmit(w,req,user,extraData)
|
|
case "/topic/like/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(87)
|
|
err = routeLikeTopicSubmit(w,req,user,extraData)
|
|
default:
|
|
counters.RouteViewCounter.Bump(88)
|
|
err = routes.ViewTopic(w,req,user, extraData)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/reply":
|
|
switch(req.URL.Path) {
|
|
case "/reply/create/":
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.HandleUploadRoute(w,req,user,common.Config.MaxRequestSize)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
err = common.NoUploadSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(89)
|
|
err = routes.CreateReplySubmit(w,req,user)
|
|
case "/reply/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(90)
|
|
err = routes.ReplyEditSubmit(w,req,user,extraData)
|
|
case "/reply/delete/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(91)
|
|
err = routes.ReplyDeleteSubmit(w,req,user,extraData)
|
|
case "/reply/like/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(92)
|
|
err = routeReplyLikeSubmit(w,req,user,extraData)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/profile":
|
|
switch(req.URL.Path) {
|
|
case "/profile/reply/create/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(93)
|
|
err = routeProfileReplyCreateSubmit(w,req,user)
|
|
case "/profile/reply/edit/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(94)
|
|
err = routes.ProfileReplyEditSubmit(w,req,user,extraData)
|
|
case "/profile/reply/delete/submit/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(95)
|
|
err = routes.ProfileReplyDeleteSubmit(w,req,user,extraData)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/poll":
|
|
switch(req.URL.Path) {
|
|
case "/poll/vote/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(96)
|
|
err = routes.PollVote(w,req,user,extraData)
|
|
case "/poll/results/":
|
|
counters.RouteViewCounter.Bump(97)
|
|
err = routes.PollResults(w,req,user,extraData)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
case "/accounts":
|
|
switch(req.URL.Path) {
|
|
case "/accounts/login/":
|
|
counters.RouteViewCounter.Bump(98)
|
|
err = routes.AccountLogin(w,req,user)
|
|
case "/accounts/create/":
|
|
counters.RouteViewCounter.Bump(99)
|
|
err = routes.AccountRegister(w,req,user)
|
|
case "/accounts/logout/":
|
|
err = common.NoSessionMismatch(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
err = common.MemberOnly(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(100)
|
|
err = routeLogout(w,req,user)
|
|
case "/accounts/login/submit/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(101)
|
|
err = routes.AccountLoginSubmit(w,req,user)
|
|
case "/accounts/create/submit/":
|
|
err = common.ParseForm(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
return
|
|
}
|
|
|
|
counters.RouteViewCounter.Bump(102)
|
|
err = routes.AccountRegisterSubmit(w,req,user)
|
|
}
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
/*case "/sitemaps": // TODO: Count these views
|
|
req.URL.Path += extraData
|
|
err = sitemapSwitch(w,req)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}*/
|
|
case "/uploads":
|
|
if extraData == "" {
|
|
common.NotFound(w,req,nil)
|
|
return
|
|
}
|
|
counters.RouteViewCounter.Bump(104)
|
|
req.URL.Path += extraData
|
|
// TODO: Find a way to propagate errors up from this?
|
|
router.UploadHandler(w,req) // TODO: Count these views
|
|
case "":
|
|
// Stop the favicons, robots.txt file, etc. resolving to the topics list
|
|
// TODO: Add support for favicons and robots.txt files
|
|
switch(extraData) {
|
|
case "robots.txt":
|
|
counters.RouteViewCounter.Bump(106)
|
|
err = routes.RobotsTxt(w,req)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
return
|
|
/*case "sitemap.xml":
|
|
counters.RouteViewCounter.Bump(107)
|
|
err = routes.SitemapXml(w,req)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
return*/
|
|
}
|
|
if extraData != "" {
|
|
common.NotFound(w,req,nil)
|
|
return
|
|
}
|
|
|
|
handle, ok := RouteMap[common.Config.DefaultRoute]
|
|
if !ok {
|
|
// TODO: Make this a startup error not a runtime one
|
|
router.requestLogger.Print("Unable to find the default route")
|
|
common.NotFound(w,req,nil)
|
|
return
|
|
}
|
|
counters.RouteViewCounter.Bump(routeMapEnum[common.Config.DefaultRoute])
|
|
|
|
handle.(func(http.ResponseWriter, *http.Request, common.User) common.RouteError)(w,req,user)
|
|
default:
|
|
// A fallback for the routes which haven't been converted to the new router yet or plugins
|
|
router.RLock()
|
|
handle, ok := router.extraRoutes[req.URL.Path]
|
|
router.RUnlock()
|
|
|
|
if ok {
|
|
counters.RouteViewCounter.Bump(103) // TODO: Be more specific about *which* dynamic route it is
|
|
req.URL.Path += extraData
|
|
err = handle(w,req,user)
|
|
if err != nil {
|
|
router.handleError(err,w,req,user)
|
|
}
|
|
return
|
|
}
|
|
|
|
lowerPath := strings.ToLower(req.URL.Path)
|
|
if strings.Contains(lowerPath,"admin") || strings.Contains(lowerPath,"sql") || strings.Contains(lowerPath,"manage") || strings.Contains(lowerPath,"//") || strings.Contains(lowerPath,"\\\\") || strings.Contains(lowerPath,"wp") || strings.Contains(lowerPath,"wordpress") || strings.Contains(lowerPath,"config") || strings.Contains(lowerPath,"setup") || strings.Contains(lowerPath,"install") || strings.Contains(lowerPath,"update") || strings.Contains(lowerPath,"php") {
|
|
router.SuspiciousRequest(req,"Bad Route")
|
|
} else {
|
|
router.DumpRequest(req,"Bad Route")
|
|
}
|
|
counters.RouteViewCounter.Bump(108)
|
|
common.NotFound(w,req,nil)
|
|
}
|
|
}
|