1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
/**
* Copyright 2009 RedHog, Egil Möller <egil.moller@piratpartiet.se>
* Copyright 2010 Pita, Peter Martischka <petermartischka@googlemail.com>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS-IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import("plugins.twitterStyleTags.models.tagQuery");
import("faststatic");
import("dispatch.{Dispatcher,PrefixMatcher,forward}");
import("etherpad.utils.*");
import("etherpad.collab.server_utils");
import("etherpad.globals.*");
import("etherpad.log");
import("etherpad.pad.padusers");
import("etherpad.pro.pro_utils");
import("etherpad.helpers");
import("etherpad.pro.pro_accounts.getSessionProAccount");
import("sqlbase.sqlbase");
import("sqlbase.sqlcommon");
import("sqlbase.sqlobj");
import("etherpad.pad.padutils");
function onRequest() {
var tags = tagQuery.queryToTags(request.params.query);
/* Create the pad filter sql */
var querySql = tagQuery.getQueryToSql(tags.tags.concat(['public']), tags.antiTags);
/* Use the pad filter sql to figure out which tags to show in the tag browser this time. */
var queryNewTagsSql = tagQuery.newTagsSql(querySql);
var newTags = sqlobj.executeRaw(queryNewTagsSql.sql, queryNewTagsSql.params);
padSql = tagQuery.padInfoSql(querySql, 10);
var matchingPads = sqlobj.executeRaw(padSql.sql, padSql.params);
for (i = 0; i < matchingPads.length; i++) {
matchingPads[i].TAGS = matchingPads[i].TAGS.split('#');
}
var isPro = pro_utils.isProDomainRequest();
var userId = padusers.getUserId();
helpers.addClientVars({
userAgent: request.headers["User-Agent"],
debugEnabled: request.params.djs,
clientIp: request.clientAddr,
colorPalette: COLOR_PALETTE,
serverTimestamp: +(new Date),
isProPad: isPro,
userIsGuest: padusers.isGuest(userId),
userId: userId,
});
var isProUser = (isPro && ! padusers.isGuest(userId));
padutils.setOptsAndCookiePrefs(request);
var prefs = helpers.getClientVar('cookiePrefsToSet');
var bodyClass = (prefs.isFullWidth ? "fullwidth" : "limwidth")
var info = {
prefs: prefs,
config: appjet.config,
tagQuery: tagQuery,
padIdToReadonly: server_utils.padIdToReadonly,
tags: tags.tags,
antiTags: tags.antiTags,
newTags: newTags,
matchingPads: matchingPads,
bodyClass: 'nonpropad',
isPro: isPro,
isProAccountHolder: isProUser,
account: getSessionProAccount(), // may be falsy
};
var format = "html";
if (request.params.format != undefined)
format = request.params.format;
if (format == "html")
renderHtml("tagBrowser.ejs", info, 'twitterStyleTags');
else if (format == "rss") {
response.setContentType("application/xml; charset=utf-8");
response.write(renderTemplateAsString("tagRss.ejs", info, 'twitterStyleTags'));
if (request.acceptsGzip) {
response.setGzip(true);
}
}
return true;
}
|