mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Make regex for subfolder deduplication more restrictive
- Add subdir to protected slugs - Fix regex for subfolder deduplication fixes #5605
This commit is contained in:
parent
5e2523a305
commit
c8e30f0182
3 changed files with 18 additions and 2 deletions
|
@ -143,6 +143,10 @@ ConfigManager.prototype.set = function (config) {
|
|||
|
||||
subdir = localPath === '/' ? '' : localPath;
|
||||
|
||||
if (!_.isEmpty(subdir)) {
|
||||
this._config.slugs.protected.push(subdir.split('/').pop());
|
||||
}
|
||||
|
||||
// Allow contentPath to be over-written by passed in config object
|
||||
// Otherwise default to default content path location
|
||||
contentPath = this._config.paths.contentPath || path.resolve(appRoot, 'content');
|
||||
|
|
|
@ -51,8 +51,8 @@ function urlJoin() {
|
|||
|
||||
// Deduplicate subdirectory
|
||||
if (subdir) {
|
||||
subdirRegex = new RegExp(subdir + '\/' + subdir);
|
||||
url = url.replace(subdirRegex, subdir);
|
||||
subdirRegex = new RegExp(subdir + '\/' + subdir + '\/');
|
||||
url = url.replace(subdirRegex, subdir + '/');
|
||||
}
|
||||
|
||||
return url;
|
||||
|
|
|
@ -112,6 +112,14 @@ describe('Config', function () {
|
|||
config.paths.should.have.property('subdir', '/my/blog');
|
||||
});
|
||||
|
||||
it('should add subdir to list of protected slugs', function () {
|
||||
configUtils.set({url: 'http://my-ghost-blog.com/blog'});
|
||||
config.slugs.protected.should.containEql('blog');
|
||||
|
||||
configUtils.set({url: 'http://my-ghost-blog.com/my/blog'});
|
||||
config.slugs.protected.should.containEql('blog');
|
||||
});
|
||||
|
||||
it('should allow specific properties to be user defined', function () {
|
||||
var contentPath = path.join(config.paths.appRoot, 'otherContent', '/'),
|
||||
configFile = 'configFileDanceParty.js';
|
||||
|
@ -268,6 +276,10 @@ describe('Config', function () {
|
|||
configUtils.set({url: 'http://my-ghost-blog.com/blog'});
|
||||
config.urlFor(testContext, testData).should.equal('/blog/short-and-sweet/');
|
||||
config.urlFor(testContext, testData, true).should.equal('http://my-ghost-blog.com/blog/short-and-sweet/');
|
||||
|
||||
testData.post.url = '/blog-one/';
|
||||
config.urlFor(testContext, testData).should.equal('/blog/blog-one/');
|
||||
config.urlFor(testContext, testData, true).should.equal('http://my-ghost-blog.com/blog/blog-one/');
|
||||
});
|
||||
|
||||
it('should return url for a tag when asked for', function () {
|
||||
|
|
Loading…
Add table
Reference in a new issue