| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | const assert = require('assert'); | 
					
						
							|  |  |  | const nconf = require('nconf'); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | const db = require('./mocks/databasemock'); | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | const request = require('../src/request'); | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | const topics = require('../src/topics'); | 
					
						
							|  |  |  | const categories = require('../src/categories'); | 
					
						
							|  |  |  | const user = require('../src/user'); | 
					
						
							|  |  |  | const meta = require('../src/meta'); | 
					
						
							|  |  |  | const privileges = require('../src/privileges'); | 
					
						
							|  |  |  | const helpers = require('./helpers'); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 00:01:39 -07:00
										 |  |  | describe('feeds', () => { | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | 	let tid; | 
					
						
							|  |  |  | 	let fooUid; | 
					
						
							|  |  |  | 	let cid; | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	before(async () => { | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 		meta.config['feeds:disableRSS'] = 1; | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		const category = await categories.create({ | 
					
						
							|  |  |  | 			name: 'Test Category', | 
					
						
							|  |  |  | 			description: 'Test category created by testing script', | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		cid = category.cid; | 
					
						
							|  |  |  | 		fooUid = await user.create({ username: 'foo', password: 'barbar', email: 'foo@test.com' }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		const result = await topics.post({ | 
					
						
							|  |  |  | 			cid: cid, | 
					
						
							|  |  |  | 			uid: fooUid, | 
					
						
							|  |  |  | 			title: 'test topic title', | 
					
						
							|  |  |  | 			content: 'test topic content', | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 		tid = result.topicData.tid; | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should 404', async () => { | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | 		const feedUrls = [ | 
					
						
							| 
									
										
										
										
											2021-02-03 23:59:08 -07:00
										 |  |  | 			`${nconf.get('url')}/topic/${tid}.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/category/${cid}.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/topics.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/recent.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/top.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/popular.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/popular/day.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/recentposts.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/category/${cid}/recentposts.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/user/foo/topics.rss`, | 
					
						
							|  |  |  | 			`${nconf.get('url')}/tags/nodebb.rss`, | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 		]; | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		for (const url of feedUrls) { | 
					
						
							|  |  |  | 			// eslint-disable-next-line no-await-in-loop
 | 
					
						
							|  |  |  | 			const { response } = await request.get(url); | 
					
						
							|  |  |  | 			assert.equal(response.statusCode, 404); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		meta.config['feeds:disableRSS'] = 0; | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should 404 if topic does not exist', async () => { | 
					
						
							|  |  |  | 		const { response } = await request.get(`${nconf.get('url')}/topic/${1000}.rss`); | 
					
						
							|  |  |  | 		assert.equal(response.statusCode, 404); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should 404 if category id is not a number', async () => { | 
					
						
							|  |  |  | 		const { response } = await request.get(`${nconf.get('url')}/category/invalid.rss`); | 
					
						
							|  |  |  | 		assert.equal(response.statusCode, 404); | 
					
						
							| 
									
										
										
										
											2018-07-31 14:26:12 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should redirect if we do not have read privilege', async () => { | 
					
						
							|  |  |  | 		await privileges.categories.rescind(['groups:topics:read'], cid, 'guests'); | 
					
						
							|  |  |  | 		const { response, body } = await request.get(`${nconf.get('url')}/topic/${tid}.rss`); | 
					
						
							|  |  |  | 		assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 		assert(body); | 
					
						
							|  |  |  | 		assert(body.includes('Login to your account')); | 
					
						
							|  |  |  | 		await privileges.categories.give(['groups:topics:read'], cid, 'guests'); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should 404 if user is not found', async () => { | 
					
						
							|  |  |  | 		const { response } = await request.get(`${nconf.get('url')}/user/doesnotexist/topics.rss`); | 
					
						
							|  |  |  | 		assert.equal(response.statusCode, 404); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 	it('should redirect if we do not have read privilege', async () => { | 
					
						
							|  |  |  | 		await privileges.categories.rescind(['groups:read'], cid, 'guests'); | 
					
						
							|  |  |  | 		const { response, body } = await request.get(`${nconf.get('url')}/category/${cid}.rss`); | 
					
						
							|  |  |  | 		assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 		assert(body); | 
					
						
							|  |  |  | 		assert(body.includes('Login to your account')); | 
					
						
							|  |  |  | 		await privileges.categories.give(['groups:read'], cid, 'guests'); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 00:01:39 -07:00
										 |  |  | 	describe('private feeds and tokens', () => { | 
					
						
							| 
									
										
										
										
											2021-02-04 00:06:15 -07:00
										 |  |  | 		let jar; | 
					
						
							|  |  |  | 		let rssToken; | 
					
						
							| 
									
										
										
										
											2021-11-22 19:23:51 -05:00
										 |  |  | 		before(async () => { | 
					
						
							|  |  |  | 			({ jar } = await helpers.loginUser('foo', 'barbar')); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		it('should load feed if its not private', async () => { | 
					
						
							|  |  |  | 			const { response, body } = await request.get(`${nconf.get('url')}/category/${cid}.rss`); | 
					
						
							|  |  |  | 			assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 			assert(body); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		it('should not allow access if uid or token is missing', async () => { | 
					
						
							|  |  |  | 			await privileges.categories.rescind(['groups:read'], cid, 'guests'); | 
					
						
							|  |  |  | 			const [test1, test2] = await Promise.all([ | 
					
						
							|  |  |  | 				request.get(`${nconf.get('url')}/category/${cid}.rss?uid=${fooUid}`, { }), | 
					
						
							|  |  |  | 				request.get(`${nconf.get('url')}/category/${cid}.rss?token=sometoken`, { }), | 
					
						
							|  |  |  | 			]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			assert.equal(test1.response.statusCode, 200); | 
					
						
							|  |  |  | 			assert.equal(test2.response.statusCode, 200); | 
					
						
							|  |  |  | 			assert(test1.body.includes('Login to your account')); | 
					
						
							|  |  |  | 			assert(test2.body.includes('Login to your account')); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		it('should not allow access if token is wrong', async () => { | 
					
						
							|  |  |  | 			const { response, body } = await request.get(`${nconf.get('url')}/category/${cid}.rss?uid=${fooUid}&token=sometoken`); | 
					
						
							|  |  |  | 			assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 			assert(body.includes('Login to your account')); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		it('should allow access if token is correct', async () => { | 
					
						
							|  |  |  | 			const { body: body1 } = await request.get(`${nconf.get('url')}/api/category/${cid}`, { jar }); | 
					
						
							|  |  |  | 			rssToken = body1.rssFeedUrl.split('token')[1].slice(1); | 
					
						
							|  |  |  | 			const { response, body: body2 } = await request.get(`${nconf.get('url')}/category/${cid}.rss?uid=${fooUid}&token=${rssToken}`); | 
					
						
							|  |  |  | 			assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 			assert(body2.startsWith('<?xml version="1.0"')); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-18 12:08:34 -05:00
										 |  |  | 		it('should not allow access if token is correct but has no privilege', async () => { | 
					
						
							|  |  |  | 			await privileges.categories.rescind(['groups:read'], cid, 'registered-users'); | 
					
						
							|  |  |  | 			const { response, body } = await request.get(`${nconf.get('url')}/category/${cid}.rss?uid=${fooUid}&token=${rssToken}`); | 
					
						
							|  |  |  | 			assert.equal(response.statusCode, 200); | 
					
						
							|  |  |  | 			assert(body.includes('Login to your account')); | 
					
						
							| 
									
										
										
										
											2017-06-22 12:44:37 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-05-21 19:45:25 -04:00
										 |  |  | }); |