mirror of
https://github.com/NodeBB/NodeBB.git
synced 2026-01-06 15:42:52 +01:00
commit 56582bc9eee5d81a01f42a28808b617b9c96873a Author: Julian Lam <julian@designcreateplay.com> Date: Tue Oct 27 05:21:11 2015 -0400 added missing template commit 6462a1626e7d8d77210b6e10eace5c9214335f33 Author: Julian Lam <julian@designcreateplay.com> Date: Tue Oct 27 05:19:07 2015 -0400 sitemap index commit 3cfd56f1fbc8e03405dc394375bf5ff6eef21322 Author: Julian Lam <julian@designcreateplay.com> Date: Tue Oct 27 04:47:52 2015 -0400 sitemap routes, controllers, and library methods for pages, categories, and topics commit e58e07c0881bdbe16d503b4679b85f761b02163c Author: Julian Lam <julian@designcreateplay.com> Date: Tue Oct 27 04:07:39 2015 -0400 added groups to sitemap commit7ee584b632Author: Julian Lam <julian@designcreateplay.com> Date: Tue Oct 27 01:43:06 2015 -0400 If notification dropdown is double-clicked, all notifications are marked read commit488f147befAuthor: barisusakli <barisusakli@gmail.com> Date: Mon Oct 26 22:39:19 2015 -0400 closes #3781 commit5e1bd58a02Author: barisusakli <barisusakli@gmail.com> Date: Mon Oct 26 22:28:30 2015 -0400 closes #3782 commit57d3980267Author: barisusakli <barisusakli@gmail.com> Date: Mon Oct 26 22:16:08 2015 -0400 closes #3790 commit555c5b82daAuthor: barisusakli <barisusakli@gmail.com> Date: Mon Oct 26 21:19:20 2015 -0400 check user settings commit5454862c1cAuthor: barisusakli <barisusakli@gmail.com> Date: Mon Oct 26 20:26:02 2015 -0400 wait for all callbacks when creating tags commit051c5077ebMerge:839fd93e0e04efAuthor: Barış Soner Uşaklı <barisusakli@gmail.com> Date: Mon Oct 26 09:54:12 2015 -0400 Merge pull request #3792 from drlogout/master Fixed wrong method name in socket.io/groups.js from isAdmin to isAdmi… commite0e04ef892Author: Christian Nolte <hello@noltech.net> Date: Mon Oct 26 14:50:32 2015 +0100 Fixed wrong method name in socket.io/groups.js from isAdmin to isAdministrator commit839fd935adAuthor: barisusakli <barisusakli@gmail.com> Date: Sun Oct 25 21:54:35 2015 -0400 add back thread tools filter commit37060bf1a3Merge:5820a19bf918bdAuthor: Barış Soner Uşaklı <barisusakli@gmail.com> Date: Sun Oct 25 18:13:06 2015 -0400 Merge pull request #3787 from cubehouse/patch-1 Upgrade script fails on some consoles commit5820a193f6Author: barisusakli <barisusakli@gmail.com> Date: Sun Oct 25 17:04:46 2015 -0400 closes #3789 commit0d88d52557Author: barisusakli <barisusakli@gmail.com> Date: Sun Oct 25 17:03:33 2015 -0400 up theme commit9bc43ba5e1Author: barisusakli <barisusakli@gmail.com> Date: Sun Oct 25 16:57:42 2015 -0400 closes #3788 commitaafd4b6984Author: barisusakli <barisusakli@gmail.com> Date: Sun Oct 25 15:56:17 2015 -0400 closes #3786 commitbf918bd016Author: James Holding <cubehouse@users.noreply.github.com> Date: Sun Oct 25 10:14:00 2015 +0000 Upgrade script fails on some consoles The upgrade script errors/fails on some consoles if the stdout.columns isn't set (my console did this when upgrading a Docker instance of NodeBB). Checking for stdout.columns before using, falling back to a couple of spaces for slightly prettiness if we can't work out the console width.
190 lines
3.9 KiB
JavaScript
190 lines
3.9 KiB
JavaScript
'use strict';
|
|
|
|
var path = require('path'),
|
|
async = require('async'),
|
|
sm = require('sitemap'),
|
|
url = require('url'),
|
|
nconf = require('nconf'),
|
|
db = require('./database'),
|
|
categories = require('./categories'),
|
|
topics = require('./topics'),
|
|
privileges = require('./privileges'),
|
|
meta = require('./meta'),
|
|
utils = require('../public/src/utils');
|
|
|
|
var sitemap = {
|
|
maps: {
|
|
topics: []
|
|
}
|
|
};
|
|
|
|
sitemap.render = function(callback) {
|
|
var numTopics = parseInt(meta.config.sitemapTopics, 10) || 500;
|
|
var returnData = {
|
|
url: nconf.get('url'),
|
|
topics: []
|
|
};
|
|
var numPages;
|
|
|
|
async.waterfall([
|
|
async.apply(db.getSortedSetRange, 'topics:recent', 0, -1),
|
|
function(tids, next) {
|
|
privileges.topics.filterTids('read', tids, 0, next);
|
|
}
|
|
], function(err, tids) {
|
|
if (err) {
|
|
numPages = 1;
|
|
} else {
|
|
numPages = Math.ceil(tids.length / numTopics);
|
|
}
|
|
|
|
for(var x=1;x<=numPages;x++) {
|
|
returnData.topics.push(x);
|
|
}
|
|
|
|
callback(null, returnData);
|
|
});
|
|
};
|
|
|
|
sitemap.getStaticUrls = function(callback) {
|
|
callback(null, [{
|
|
url: '',
|
|
changefreq: 'weekly',
|
|
priority: '0.6'
|
|
}, {
|
|
url: '/recent',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}, {
|
|
url: '/users',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}, {
|
|
url: '/groups',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}]);
|
|
};
|
|
|
|
sitemap.getPages = function(callback) {
|
|
if (sitemap.maps.pages && sitemap.maps.pages.cache.length) {
|
|
return sitemap.maps.pages.toXML(callback);
|
|
}
|
|
|
|
var urls = [{
|
|
url: '',
|
|
changefreq: 'weekly',
|
|
priority: '0.6'
|
|
}, {
|
|
url: '/recent',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}, {
|
|
url: '/users',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}, {
|
|
url: '/groups',
|
|
changefreq: 'daily',
|
|
priority: '0.4'
|
|
}];
|
|
|
|
sitemap.maps.pages = sm.createSitemap({
|
|
hostname: nconf.get('url'),
|
|
cacheTime: 1000 * 60 * 60 * 24, // Cached for 24 hours
|
|
urls: urls
|
|
});
|
|
|
|
sitemap.maps.pages.toXML(callback);
|
|
};
|
|
|
|
sitemap.getCategories = function(callback) {
|
|
if (sitemap.maps.categories && sitemap.maps.categories.cache.length) {
|
|
return sitemap.maps.categories.toXML(callback);
|
|
}
|
|
|
|
var categoryUrls = [];
|
|
categories.getCategoriesByPrivilege('categories:cid', 0, 'find', function(err, categoriesData) {
|
|
if (err) {
|
|
return callback(err);
|
|
}
|
|
|
|
categoriesData.forEach(function(category) {
|
|
if (category) {
|
|
categoryUrls.push({
|
|
url: '/category/' + category.slug,
|
|
changefreq: 'weekly',
|
|
priority: '0.4'
|
|
});
|
|
}
|
|
});
|
|
|
|
sitemap.maps.categories = sm.createSitemap({
|
|
hostname: nconf.get('url'),
|
|
cacheTime: 1000 * 60 * 60 * 24, // Cached for 24 hours
|
|
urls: categoryUrls
|
|
});
|
|
|
|
sitemap.maps.categories.toXML(callback);
|
|
});
|
|
};
|
|
|
|
sitemap.getTopicPage = function(page, callback) {
|
|
if (parseInt(page, 10) <= 0) {
|
|
return callback();
|
|
}
|
|
|
|
var numTopics = parseInt(meta.config.sitemapTopics, 10) || 500;
|
|
var min = (parseInt(page, 10) - 1) * numTopics;
|
|
var max = min + numTopics;
|
|
|
|
if (sitemap.maps.topics[page-1] && sitemap.maps.topics[page-1].cache.length) {
|
|
return sitemap.maps.topics[page-1].toXML(callback);
|
|
}
|
|
|
|
var topicUrls = [];
|
|
|
|
async.waterfall([
|
|
function(next) {
|
|
db.getSortedSetRevRange('topics:recent', min, max, next);
|
|
},
|
|
function(tids, next) {
|
|
privileges.topics.filterTids('read', tids, 0, next);
|
|
},
|
|
function(tids, next) {
|
|
topics.getTopicsFields(tids, ['tid', 'title', 'slug', 'lastposttime'], next);
|
|
}
|
|
], function(err, topics) {
|
|
if (err) {
|
|
return callback(err);
|
|
}
|
|
|
|
topics.forEach(function(topic) {
|
|
if (topic) {
|
|
topicUrls.push({
|
|
url: '/topic/' + topic.slug,
|
|
lastmodISO: utils.toISOString(topic.lastposttime),
|
|
changefreq: 'daily',
|
|
priority: '0.6'
|
|
});
|
|
}
|
|
});
|
|
|
|
sitemap.maps.topics[page-1] = sm.createSitemap({
|
|
hostname: nconf.get('url'),
|
|
cacheTime: 1000 * 60 * 60, // Cached for 1 hour
|
|
urls: topicUrls
|
|
});
|
|
|
|
sitemap.maps.topics[page-1].toXML(callback);
|
|
});
|
|
};
|
|
|
|
sitemap.clearCache = function() {
|
|
if (sitemap.obj) {
|
|
sitemap.obj.clearCache();
|
|
}
|
|
};
|
|
|
|
module.exports = sitemap;
|