nodebb-plugin-ezoic-infinite 1.6.77 → 1.6.79
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/library.js +29 -95
- package/package.json +1 -1
- package/public/client.js +158 -1631
- package/public/style.css +24 -64
package/library.js
CHANGED
|
@@ -7,124 +7,58 @@ const db = require.main.require('./src/database');
|
|
|
7
7
|
const SETTINGS_KEY = 'ezoic-infinite';
|
|
8
8
|
const plugin = {};
|
|
9
9
|
|
|
10
|
-
function
|
|
11
|
-
|
|
12
|
-
if (Array.isArray(value)) return value;
|
|
13
|
-
return String(value).split(',').map(s => s.trim()).filter(Boolean);
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function parseBool(v, def = false) {
|
|
17
|
-
if (v === undefined || v === null || v === '') return def;
|
|
18
|
-
if (typeof v === 'boolean') return v;
|
|
19
|
-
const s = String(v).toLowerCase();
|
|
20
|
-
return s === '1' || s === 'true' || s === 'on' || s === 'yes';
|
|
10
|
+
async function getSettings() {
|
|
11
|
+
return await meta.settings.get(SETTINGS_KEY);
|
|
21
12
|
}
|
|
22
13
|
|
|
23
14
|
async function getAllGroups() {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
const filtered = names.filter(name => !groups.isPrivilegeGroup(name));
|
|
29
|
-
const data = await groups.getGroupsData(filtered);
|
|
30
|
-
// Filter out nulls (groups deleted between the sorted-set read and getGroupsData)
|
|
31
|
-
const valid = data.filter(g => g && g.name);
|
|
32
|
-
valid.sort((a, b) => String(a.name).localeCompare(String(b.name), undefined, { sensitivity: 'base' }));
|
|
33
|
-
return valid;
|
|
34
|
-
}
|
|
35
|
-
let _settingsCache = null;
|
|
36
|
-
let _settingsCacheAt = 0;
|
|
37
|
-
const SETTINGS_TTL = 30000; // 30s
|
|
38
|
-
|
|
39
|
-
async function getSettings() {
|
|
40
|
-
const now = Date.now();
|
|
41
|
-
if (_settingsCache && (now - _settingsCacheAt) < SETTINGS_TTL) return _settingsCache;
|
|
42
|
-
const s = await meta.settings.get(SETTINGS_KEY);
|
|
43
|
-
_settingsCacheAt = Date.now();
|
|
44
|
-
_settingsCache = {
|
|
45
|
-
// Between-post ads (simple blocks) in category topic list
|
|
46
|
-
enableBetweenAds: parseBool(s.enableBetweenAds, true),
|
|
47
|
-
showFirstTopicAd: parseBool(s.showFirstTopicAd, false),
|
|
48
|
-
placeholderIds: (s.placeholderIds || '').trim(),
|
|
49
|
-
intervalPosts: Math.max(1, parseInt(s.intervalPosts, 10) || 6),
|
|
50
|
-
|
|
51
|
-
// Home/categories list ads (between categories on / or /categories)
|
|
52
|
-
enableCategoryAds: parseBool(s.enableCategoryAds, false),
|
|
53
|
-
showFirstCategoryAd: parseBool(s.showFirstCategoryAd, false),
|
|
54
|
-
categoryPlaceholderIds: (s.categoryPlaceholderIds || '').trim(),
|
|
55
|
-
intervalCategories: Math.max(1, parseInt(s.intervalCategories, 10) || 4),
|
|
56
|
-
|
|
57
|
-
// "Ad message" between replies (looks like a post)
|
|
58
|
-
enableMessageAds: parseBool(s.enableMessageAds, false),
|
|
59
|
-
showFirstMessageAd: parseBool(s.showFirstMessageAd, false),
|
|
60
|
-
messagePlaceholderIds: (s.messagePlaceholderIds || '').trim(),
|
|
61
|
-
messageIntervalPosts: Math.max(1, parseInt(s.messageIntervalPosts, 10) || 3),
|
|
62
|
-
|
|
63
|
-
excludedGroups: normalizeExcludedGroups(s.excludedGroups),
|
|
64
|
-
};
|
|
65
|
-
return _settingsCache;
|
|
15
|
+
const names = await db.getSortedSetRange('groups:createtime', 0, -1);
|
|
16
|
+
const data = await groups.getGroupsData(names);
|
|
17
|
+
return data.filter(g => g && g.name).map(g => ({ name: g.name }));
|
|
66
18
|
}
|
|
67
19
|
|
|
68
20
|
async function isUserExcluded(uid, excludedGroups) {
|
|
69
|
-
if (!uid || !excludedGroups.length) return false;
|
|
70
|
-
|
|
71
|
-
return (userGroups[0] || []).some(g => excludedGroups.includes(g.name));
|
|
21
|
+
if (!uid || !excludedGroups || !excludedGroups.length) return false;
|
|
22
|
+
return await groups.isMemberOfGroups(uid, excludedGroups);
|
|
72
23
|
}
|
|
73
24
|
|
|
74
|
-
plugin.onSettingsSet = function (data) {
|
|
75
|
-
// Invalider le cache dès que les settings de ce plugin sont sauvegardés via l'ACP
|
|
76
|
-
if (data && data.hash === SETTINGS_KEY) {
|
|
77
|
-
_settingsCache = null;
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
plugin.addAdminNavigation = async (header) => {
|
|
82
|
-
header.plugins = header.plugins || [];
|
|
83
|
-
header.plugins.push({
|
|
84
|
-
route: '/plugins/ezoic-infinite',
|
|
85
|
-
icon: 'fa-ad',
|
|
86
|
-
name: 'Ezoic Infinite Ads'
|
|
87
|
-
});
|
|
88
|
-
return header;
|
|
89
|
-
};
|
|
90
|
-
|
|
91
25
|
plugin.init = async ({ router, middleware }) => {
|
|
92
|
-
async
|
|
26
|
+
const renderAdmin = async (req, res) => {
|
|
93
27
|
const settings = await getSettings();
|
|
94
28
|
const allGroups = await getAllGroups();
|
|
95
|
-
|
|
96
29
|
res.render('admin/plugins/ezoic-infinite', {
|
|
97
|
-
title: 'Ezoic Infinite Ads',
|
|
98
30
|
...settings,
|
|
99
|
-
enableBetweenAds_checked: settings.enableBetweenAds ? 'checked' : '',
|
|
100
|
-
enableMessageAds_checked: settings.enableMessageAds ? 'checked' : '',
|
|
101
31
|
allGroups,
|
|
102
32
|
});
|
|
103
|
-
}
|
|
33
|
+
};
|
|
104
34
|
|
|
105
|
-
router.get('/admin/plugins/ezoic-infinite', middleware.admin.buildHeader,
|
|
106
|
-
router.get('/api/admin/plugins/ezoic-infinite',
|
|
35
|
+
router.get('/admin/plugins/ezoic-infinite', middleware.admin.buildHeader, renderAdmin);
|
|
36
|
+
router.get('/api/admin/plugins/ezoic-infinite', renderAdmin);
|
|
107
37
|
|
|
108
38
|
router.get('/api/plugins/ezoic-infinite/config', async (req, res) => {
|
|
109
39
|
const settings = await getSettings();
|
|
110
40
|
const excluded = await isUserExcluded(req.uid, settings.excludedGroups);
|
|
111
|
-
|
|
112
41
|
res.json({
|
|
113
42
|
excluded,
|
|
114
|
-
enableBetweenAds: settings.enableBetweenAds,
|
|
115
|
-
showFirstTopicAd: settings.showFirstTopicAd,
|
|
116
|
-
placeholderIds: settings.placeholderIds,
|
|
117
|
-
intervalPosts: settings.intervalPosts,
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
enableMessageAds: settings.enableMessageAds,
|
|
123
|
-
showFirstMessageAd: settings.showFirstMessageAd,
|
|
124
|
-
messagePlaceholderIds: settings.messagePlaceholderIds,
|
|
125
|
-
messageIntervalPosts: settings.messageIntervalPosts,
|
|
43
|
+
enableBetweenAds: settings.enableBetweenAds === 'on',
|
|
44
|
+
showFirstTopicAd: settings.showFirstTopicAd === 'on',
|
|
45
|
+
placeholderIds: settings.placeholderIds || '',
|
|
46
|
+
intervalPosts: settings.intervalPosts || 10,
|
|
47
|
+
enableMessageAds: settings.enableMessageAds === 'on',
|
|
48
|
+
showFirstMessageAd: settings.showFirstMessageAd === 'on',
|
|
49
|
+
messagePlaceholderIds: settings.messagePlaceholderIds || '',
|
|
50
|
+
messageIntervalPosts: settings.messageIntervalPosts || 10,
|
|
126
51
|
});
|
|
127
52
|
});
|
|
128
53
|
};
|
|
129
54
|
|
|
130
|
-
|
|
55
|
+
plugin.addAdminNavigation = async (header) => {
|
|
56
|
+
header.plugins.push({
|
|
57
|
+
route: '/plugins/ezoic-infinite',
|
|
58
|
+
icon: 'fa-ad',
|
|
59
|
+
name: 'Ezoic Infinite'
|
|
60
|
+
});
|
|
61
|
+
return header;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
module.exports = plugin;
|