REFACTOR: Remove `Discourse.SiteSettings` from uploads.js
This involves passing the siteSettings around, which is somewhat error prone so I tried to be careful.
This commit is contained in:
parent
8456252c21
commit
f8aa304c7d
|
@ -81,7 +81,10 @@ export default Component.extend({
|
||||||
if (requiredCategoryMissing) {
|
if (requiredCategoryMissing) {
|
||||||
return "composer.reply_placeholder_choose_category";
|
return "composer.reply_placeholder_choose_category";
|
||||||
} else {
|
} else {
|
||||||
const key = authorizesOneOrMoreImageExtensions(this.currentUser.staff)
|
const key = authorizesOneOrMoreImageExtensions(
|
||||||
|
this.currentUser.staff,
|
||||||
|
this.siteSettings
|
||||||
|
)
|
||||||
? "reply_placeholder"
|
? "reply_placeholder"
|
||||||
: "reply_placeholder_no_images";
|
: "reply_placeholder_no_images";
|
||||||
return `composer.${key}`;
|
return `composer.${key}`;
|
||||||
|
@ -700,6 +703,7 @@ export default Component.extend({
|
||||||
|
|
||||||
const opts = {
|
const opts = {
|
||||||
user: this.currentUser,
|
user: this.currentUser,
|
||||||
|
siteSettings: this.siteSettings,
|
||||||
isPrivateMessage,
|
isPrivateMessage,
|
||||||
allowStaffToUploadAnyFileInPm: this.siteSettings
|
allowStaffToUploadAnyFileInPm: this.siteSettings
|
||||||
.allow_staff_to_upload_any_file_in_pm
|
.allow_staff_to_upload_any_file_in_pm
|
||||||
|
|
|
@ -49,7 +49,7 @@ export default Controller.extend(ModalFunctionality, {
|
||||||
allowAvatarUpload() {
|
allowAvatarUpload() {
|
||||||
return (
|
return (
|
||||||
this.siteSettings.allow_uploaded_avatars &&
|
this.siteSettings.allow_uploaded_avatars &&
|
||||||
allowsImages(this.currentUser.staff)
|
allowsImages(this.currentUser.staff, this.siteSettings)
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -323,12 +323,15 @@ export default Controller.extend({
|
||||||
|
|
||||||
@discourseComputed
|
@discourseComputed
|
||||||
allowUpload() {
|
allowUpload() {
|
||||||
return authorizesOneOrMoreExtensions(this.currentUser.staff);
|
return authorizesOneOrMoreExtensions(
|
||||||
|
this.currentUser.staff,
|
||||||
|
this.siteSettings
|
||||||
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
@discourseComputed()
|
@discourseComputed()
|
||||||
uploadIcon() {
|
uploadIcon() {
|
||||||
return uploadIcon(this.currentUser.staff);
|
return uploadIcon(this.currentUser.staff, this.siteSettings);
|
||||||
},
|
},
|
||||||
|
|
||||||
@action
|
@action
|
||||||
|
|
|
@ -10,37 +10,38 @@ import {
|
||||||
uploadIcon
|
uploadIcon
|
||||||
} from "discourse/lib/uploads";
|
} from "discourse/lib/uploads";
|
||||||
|
|
||||||
function uploadTranslate(key, user) {
|
|
||||||
if (allowsAttachments(user.staff)) {
|
|
||||||
key += "_with_attachments";
|
|
||||||
}
|
|
||||||
return `upload_selector.${key}`;
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Controller.extend(ModalFunctionality, {
|
export default Controller.extend(ModalFunctionality, {
|
||||||
imageUrl: null,
|
imageUrl: null,
|
||||||
local: equal("selection", "local"),
|
local: equal("selection", "local"),
|
||||||
remote: equal("selection", "remote"),
|
remote: equal("selection", "remote"),
|
||||||
selection: "local",
|
selection: "local",
|
||||||
|
|
||||||
|
uploadTranslate(key) {
|
||||||
|
if (allowsAttachments(this.currentUser.staff, this.siteSettings)) {
|
||||||
|
key += "_with_attachments";
|
||||||
|
}
|
||||||
|
return `upload_selector.${key}`;
|
||||||
|
},
|
||||||
|
|
||||||
@discourseComputed()
|
@discourseComputed()
|
||||||
uploadIcon() {
|
uploadIcon() {
|
||||||
return uploadIcon(this.currentUser.staff);
|
return uploadIcon(this.currentUser.staff, this.siteSettings);
|
||||||
},
|
},
|
||||||
|
|
||||||
@discourseComputed()
|
@discourseComputed()
|
||||||
title() {
|
title() {
|
||||||
return uploadTranslate("title", this.currentUser);
|
return this.uploadTranslate("title");
|
||||||
},
|
},
|
||||||
|
|
||||||
@discourseComputed("selection")
|
@discourseComputed("selection")
|
||||||
tip(selection) {
|
tip(selection) {
|
||||||
const authorized_extensions = authorizesAllExtensions(
|
const authorized_extensions = authorizesAllExtensions(
|
||||||
this.currentUser.staff
|
this.currentUser.staff,
|
||||||
|
this.siteSettings
|
||||||
)
|
)
|
||||||
? ""
|
? ""
|
||||||
: `(${authorizedExtensions(this.currentUser.staff)})`;
|
: `(${authorizedExtensions(this.currentUser.staff, this.siteSettings)})`;
|
||||||
return I18n.t(uploadTranslate(`${selection}_tip`, this.currentUser), {
|
return I18n.t(this.uploadTranslate(`${selection}_tip`), {
|
||||||
authorized_extensions
|
authorized_extensions
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
|
@ -53,7 +53,7 @@ function validateUploadedFile(file, opts) {
|
||||||
let user = opts.user;
|
let user = opts.user;
|
||||||
let staff = user && user.staff;
|
let staff = user && user.staff;
|
||||||
|
|
||||||
if (!authorizesOneOrMoreExtensions(staff)) return false;
|
if (!authorizesOneOrMoreExtensions(staff, opts.siteSettings)) return false;
|
||||||
|
|
||||||
const name = file && file.name;
|
const name = file && file.name;
|
||||||
|
|
||||||
|
@ -69,10 +69,13 @@ function validateUploadedFile(file, opts) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opts.imagesOnly) {
|
if (opts.imagesOnly) {
|
||||||
if (!isImage(name) && !isAuthorizedImage(name, staff)) {
|
if (!isImage(name) && !isAuthorizedImage(name, staff, opts.siteSettings)) {
|
||||||
bootbox.alert(
|
bootbox.alert(
|
||||||
I18n.t("post.errors.upload_not_authorized", {
|
I18n.t("post.errors.upload_not_authorized", {
|
||||||
authorized_extensions: authorizedImagesExtensions(staff)
|
authorized_extensions: authorizedImagesExtensions(
|
||||||
|
staff,
|
||||||
|
opts.siteSettings
|
||||||
|
)
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
|
@ -83,10 +86,13 @@ function validateUploadedFile(file, opts) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!authorizesAllExtensions(staff) && !isAuthorizedFile(name, staff)) {
|
if (
|
||||||
|
!authorizesAllExtensions(staff, opts.siteSettings) &&
|
||||||
|
!isAuthorizedFile(name, staff, opts.siteSettings)
|
||||||
|
) {
|
||||||
bootbox.alert(
|
bootbox.alert(
|
||||||
I18n.t("post.errors.upload_not_authorized", {
|
I18n.t("post.errors.upload_not_authorized", {
|
||||||
authorized_extensions: authorizedExtensions(staff)
|
authorized_extensions: authorizedExtensions(staff, opts.siteSettings)
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
return false;
|
return false;
|
||||||
|
@ -117,20 +123,20 @@ function extensionsToArray(exts) {
|
||||||
.filter(ext => ext.indexOf("*") === -1);
|
.filter(ext => ext.indexOf("*") === -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
function extensions() {
|
function extensions(siteSettings) {
|
||||||
return extensionsToArray(Discourse.SiteSettings.authorized_extensions);
|
return extensionsToArray(siteSettings.authorized_extensions);
|
||||||
}
|
}
|
||||||
|
|
||||||
function staffExtensions() {
|
function staffExtensions(siteSettings) {
|
||||||
return extensionsToArray(
|
return extensionsToArray(siteSettings.authorized_extensions_for_staff);
|
||||||
Discourse.SiteSettings.authorized_extensions_for_staff
|
}
|
||||||
|
|
||||||
|
function imagesExtensions(staff, siteSettings) {
|
||||||
|
let exts = extensions(siteSettings).filter(ext =>
|
||||||
|
IMAGES_EXTENSIONS_REGEX.test(ext)
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
|
||||||
function imagesExtensions(staff) {
|
|
||||||
let exts = extensions().filter(ext => IMAGES_EXTENSIONS_REGEX.test(ext));
|
|
||||||
if (staff) {
|
if (staff) {
|
||||||
const staffExts = staffExtensions().filter(ext =>
|
const staffExts = staffExtensions(siteSettings).filter(ext =>
|
||||||
IMAGES_EXTENSIONS_REGEX.test(ext)
|
IMAGES_EXTENSIONS_REGEX.test(ext)
|
||||||
);
|
);
|
||||||
exts = _.union(exts, staffExts);
|
exts = _.union(exts, staffExts);
|
||||||
|
@ -138,60 +144,61 @@ function imagesExtensions(staff) {
|
||||||
return exts;
|
return exts;
|
||||||
}
|
}
|
||||||
|
|
||||||
function extensionsRegex() {
|
function isAuthorizedFile(fileName, staff, siteSettings) {
|
||||||
return new RegExp("\\.(" + extensions().join("|") + ")$", "i");
|
if (
|
||||||
}
|
staff &&
|
||||||
|
new RegExp(
|
||||||
function imagesExtensionsRegex(staff) {
|
"\\.(" + staffExtensions(siteSettings).join("|") + ")$",
|
||||||
return new RegExp("\\.(" + imagesExtensions(staff).join("|") + ")$", "i");
|
"i"
|
||||||
}
|
).test(fileName)
|
||||||
|
) {
|
||||||
function staffExtensionsRegex() {
|
|
||||||
return new RegExp("\\.(" + staffExtensions().join("|") + ")$", "i");
|
|
||||||
}
|
|
||||||
|
|
||||||
function isAuthorizedFile(fileName, staff) {
|
|
||||||
if (staff && staffExtensionsRegex().test(fileName)) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return extensionsRegex().test(fileName);
|
|
||||||
|
return new RegExp(
|
||||||
|
"\\.(" + extensions(siteSettings).join("|") + ")$",
|
||||||
|
"i"
|
||||||
|
).test(fileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
function isAuthorizedImage(fileName, staff) {
|
function isAuthorizedImage(fileName, staff, siteSettings) {
|
||||||
return imagesExtensionsRegex(staff).test(fileName);
|
return new RegExp(
|
||||||
|
"\\.(" + imagesExtensions(staff, siteSettings).join("|") + ")$",
|
||||||
|
"i"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function authorizedExtensions(staff) {
|
export function authorizedExtensions(staff, siteSettings) {
|
||||||
const exts = staff ? [...extensions(), ...staffExtensions()] : extensions();
|
const exts = staff
|
||||||
|
? [...extensions(siteSettings), ...staffExtensions(siteSettings)]
|
||||||
|
: extensions(siteSettings);
|
||||||
return exts.filter(ext => ext.length > 0).join(", ");
|
return exts.filter(ext => ext.length > 0).join(", ");
|
||||||
}
|
}
|
||||||
|
|
||||||
function authorizedImagesExtensions(staff) {
|
function authorizedImagesExtensions(staff, siteSettings) {
|
||||||
return authorizesAllExtensions(staff)
|
return authorizesAllExtensions(staff, siteSettings)
|
||||||
? "png, jpg, jpeg, gif, svg, ico"
|
? "png, jpg, jpeg, gif, svg, ico"
|
||||||
: imagesExtensions(staff).join(", ");
|
: imagesExtensions(staff, siteSettings).join(", ");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function authorizesAllExtensions(staff) {
|
export function authorizesAllExtensions(staff, siteSettings) {
|
||||||
return (
|
return (
|
||||||
Discourse.SiteSettings.authorized_extensions.indexOf("*") >= 0 ||
|
siteSettings.authorized_extensions.indexOf("*") >= 0 ||
|
||||||
(Discourse.SiteSettings.authorized_extensions_for_staff.indexOf("*") >= 0 &&
|
(siteSettings.authorized_extensions_for_staff.indexOf("*") >= 0 && staff)
|
||||||
staff)
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function authorizesOneOrMoreExtensions(staff) {
|
export function authorizesOneOrMoreExtensions(staff, siteSettings) {
|
||||||
if (authorizesAllExtensions(staff)) return true;
|
if (authorizesAllExtensions(staff, siteSettings)) return true;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
Discourse.SiteSettings.authorized_extensions.split("|").filter(ext => ext)
|
siteSettings.authorized_extensions.split("|").filter(ext => ext).length > 0
|
||||||
.length > 0
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function authorizesOneOrMoreImageExtensions(staff) {
|
export function authorizesOneOrMoreImageExtensions(staff, siteSettings) {
|
||||||
if (authorizesAllExtensions(staff)) return true;
|
if (authorizesAllExtensions(staff, siteSettings)) return true;
|
||||||
return imagesExtensions(staff).length > 0;
|
return imagesExtensions(staff, siteSettings).length > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isImage(path) {
|
export function isImage(path) {
|
||||||
|
@ -210,23 +217,23 @@ function uploadTypeFromFileName(fileName) {
|
||||||
return isImage(fileName) ? "image" : "attachment";
|
return isImage(fileName) ? "image" : "attachment";
|
||||||
}
|
}
|
||||||
|
|
||||||
export function allowsImages(staff) {
|
export function allowsImages(staff, siteSettings) {
|
||||||
return (
|
return (
|
||||||
authorizesAllExtensions(staff) ||
|
authorizesAllExtensions(staff, siteSettings) ||
|
||||||
IMAGES_EXTENSIONS_REGEX.test(authorizedExtensions(staff))
|
IMAGES_EXTENSIONS_REGEX.test(authorizedExtensions(staff, siteSettings))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function allowsAttachments(staff) {
|
export function allowsAttachments(staff, siteSettings) {
|
||||||
return (
|
return (
|
||||||
authorizesAllExtensions(staff) ||
|
authorizesAllExtensions(staff, siteSettings) ||
|
||||||
authorizedExtensions(staff).split(", ").length >
|
authorizedExtensions(staff, siteSettings).split(", ").length >
|
||||||
imagesExtensions(staff).length
|
imagesExtensions(staff, siteSettings).length
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function uploadIcon(staff) {
|
export function uploadIcon(staff, siteSettings) {
|
||||||
return allowsAttachments(staff) ? "upload" : "far-image";
|
return allowsAttachments(staff, siteSettings) ? "upload" : "far-image";
|
||||||
}
|
}
|
||||||
|
|
||||||
function imageMarkdown(upload) {
|
function imageMarkdown(upload) {
|
||||||
|
|
|
@ -82,7 +82,11 @@ export default Mixin.create({
|
||||||
|
|
||||||
$upload.on("fileuploadsubmit", (e, data) => {
|
$upload.on("fileuploadsubmit", (e, data) => {
|
||||||
const opts = _.merge(
|
const opts = _.merge(
|
||||||
{ bypassNewUserRestriction: true, user: this.currentUser },
|
{
|
||||||
|
bypassNewUserRestriction: true,
|
||||||
|
user: this.currentUser,
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
},
|
||||||
this.validateUploadedFilesOptions()
|
this.validateUploadedFilesOptions()
|
||||||
);
|
);
|
||||||
const isValid = validateUploadedFiles(data.files, opts);
|
const isValid = validateUploadedFiles(data.files, opts);
|
||||||
|
|
|
@ -13,18 +13,27 @@ import { discourseModule } from "helpers/qunit-helpers";
|
||||||
|
|
||||||
discourseModule("lib:uploads");
|
discourseModule("lib:uploads");
|
||||||
|
|
||||||
const validUpload = validateUploadedFiles;
|
QUnit.test("validateUploadedFiles", function(assert) {
|
||||||
|
assert.not(
|
||||||
QUnit.test("validateUploadedFiles", assert => {
|
validateUploadedFiles(null, { siteSettings: this.siteSettings }),
|
||||||
assert.not(validUpload(null), "no files are invalid");
|
"no files are invalid"
|
||||||
assert.not(validUpload(undefined), "undefined files are invalid");
|
);
|
||||||
assert.not(validUpload([]), "empty array of files is invalid");
|
assert.not(
|
||||||
|
validateUploadedFiles(undefined, { siteSettings: this.siteSettings }),
|
||||||
|
"undefined files are invalid"
|
||||||
|
);
|
||||||
|
assert.not(
|
||||||
|
validateUploadedFiles([], { siteSettings: this.siteSettings }),
|
||||||
|
"empty array of files is invalid"
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test("uploading one file", assert => {
|
QUnit.test("uploading one file", function(assert) {
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
assert.not(validUpload([1, 2]));
|
assert.not(
|
||||||
|
validateUploadedFiles([1, 2], { siteSettings: this.siteSettings })
|
||||||
|
);
|
||||||
assert.ok(bootbox.alert.calledWith(I18n.t("post.errors.too_many_uploads")));
|
assert.ok(bootbox.alert.calledWith(I18n.t("post.errors.too_many_uploads")));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -33,7 +42,10 @@ QUnit.test("new user cannot upload images", function(assert) {
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
assert.not(
|
assert.not(
|
||||||
validUpload([{ name: "image.png" }], { user: User.create() }),
|
validateUploadedFiles([{ name: "image.png" }], {
|
||||||
|
user: User.create(),
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
}),
|
||||||
"the upload is not valid"
|
"the upload is not valid"
|
||||||
);
|
);
|
||||||
assert.ok(
|
assert.ok(
|
||||||
|
@ -48,7 +60,12 @@ QUnit.test("new user cannot upload attachments", function(assert) {
|
||||||
this.siteSettings.newuser_max_attachments = 0;
|
this.siteSettings.newuser_max_attachments = 0;
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
assert.not(validUpload([{ name: "roman.txt" }], { user: User.create() }));
|
assert.not(
|
||||||
|
validateUploadedFiles([{ name: "roman.txt" }], {
|
||||||
|
user: User.create(),
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
})
|
||||||
|
);
|
||||||
assert.ok(
|
assert.ok(
|
||||||
bootbox.alert.calledWith(
|
bootbox.alert.calledWith(
|
||||||
I18n.t("post.errors.attachment_upload_not_allowed_for_new_user")
|
I18n.t("post.errors.attachment_upload_not_allowed_for_new_user")
|
||||||
|
@ -56,24 +73,38 @@ QUnit.test("new user cannot upload attachments", function(assert) {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test("ensures an authorized upload", assert => {
|
QUnit.test("ensures an authorized upload", function(assert) {
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
assert.not(validUpload([{ name: "unauthorized.html" }]));
|
assert.not(
|
||||||
|
validateUploadedFiles([{ name: "unauthorized.html" }], {
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
})
|
||||||
|
);
|
||||||
assert.ok(
|
assert.ok(
|
||||||
bootbox.alert.calledWith(
|
bootbox.alert.calledWith(
|
||||||
I18n.t("post.errors.upload_not_authorized", {
|
I18n.t("post.errors.upload_not_authorized", {
|
||||||
authorized_extensions: authorizedExtensions()
|
authorized_extensions: authorizedExtensions(false, this.siteSettings)
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test("skipping validation works", assert => {
|
QUnit.test("skipping validation works", function(assert) {
|
||||||
const files = [{ name: "backup.tar.gz" }];
|
const files = [{ name: "backup.tar.gz" }];
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
assert.not(validUpload(files, { skipValidation: false }));
|
assert.not(
|
||||||
assert.ok(validUpload(files, { skipValidation: true }));
|
validateUploadedFiles(files, {
|
||||||
|
skipValidation: false,
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
})
|
||||||
|
);
|
||||||
|
assert.ok(
|
||||||
|
validateUploadedFiles(files, {
|
||||||
|
skipValidation: true,
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
})
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test("staff can upload anything in PM", function(assert) {
|
QUnit.test("staff can upload anything in PM", function(assert) {
|
||||||
|
@ -82,11 +113,14 @@ QUnit.test("staff can upload anything in PM", function(assert) {
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
let user = User.create({ moderator: true });
|
let user = User.create({ moderator: true });
|
||||||
assert.not(validUpload(files, { user }));
|
assert.not(
|
||||||
|
validateUploadedFiles(files, { user, siteSettings: this.siteSettings })
|
||||||
|
);
|
||||||
assert.ok(
|
assert.ok(
|
||||||
validUpload(files, {
|
validateUploadedFiles(files, {
|
||||||
isPrivateMessage: true,
|
isPrivateMessage: true,
|
||||||
allowStaffToUploadAnyFileInPm: true,
|
allowStaffToUploadAnyFileInPm: true,
|
||||||
|
siteSettings: this.siteSettings,
|
||||||
user
|
user
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
@ -109,17 +143,24 @@ const dummyBlob = function() {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
QUnit.test("allows valid uploads to go through", assert => {
|
QUnit.test("allows valid uploads to go through", function(assert) {
|
||||||
sandbox.stub(bootbox, "alert");
|
sandbox.stub(bootbox, "alert");
|
||||||
|
|
||||||
let user = User.create({ trust_level: 1 });
|
let user = User.create({ trust_level: 1 });
|
||||||
|
|
||||||
// image
|
// image
|
||||||
let image = { name: "image.png", size: imageSize };
|
let image = { name: "image.png", size: imageSize };
|
||||||
assert.ok(validUpload([image], { user }));
|
assert.ok(
|
||||||
|
validateUploadedFiles([image], { user, siteSettings: this.siteSettings })
|
||||||
|
);
|
||||||
// pasted image
|
// pasted image
|
||||||
let pastedImage = dummyBlob();
|
let pastedImage = dummyBlob();
|
||||||
assert.ok(validUpload([pastedImage], { user }));
|
assert.ok(
|
||||||
|
validateUploadedFiles([pastedImage], {
|
||||||
|
user,
|
||||||
|
siteSettings: this.siteSettings
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
assert.not(bootbox.alert.calledOnce);
|
assert.not(bootbox.alert.calledOnce);
|
||||||
});
|
});
|
||||||
|
@ -140,42 +181,51 @@ QUnit.test("isImage", assert => {
|
||||||
|
|
||||||
QUnit.test("allowsImages", function(assert) {
|
QUnit.test("allowsImages", function(assert) {
|
||||||
this.siteSettings.authorized_extensions = "jpg|jpeg|gif";
|
this.siteSettings.authorized_extensions = "jpg|jpeg|gif";
|
||||||
assert.ok(allowsImages(), "works");
|
assert.ok(allowsImages(false, this.siteSettings), "works");
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = ".jpg|.jpeg|.gif";
|
this.siteSettings.authorized_extensions = ".jpg|.jpeg|.gif";
|
||||||
assert.ok(allowsImages(), "works with old extensions syntax");
|
assert.ok(
|
||||||
|
allowsImages(false, this.siteSettings),
|
||||||
|
"works with old extensions syntax"
|
||||||
|
);
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = "txt|pdf|*";
|
this.siteSettings.authorized_extensions = "txt|pdf|*";
|
||||||
assert.ok(
|
assert.ok(
|
||||||
allowsImages(),
|
allowsImages(false, this.siteSettings),
|
||||||
"images are allowed when all extensions are allowed"
|
"images are allowed when all extensions are allowed"
|
||||||
);
|
);
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = "json|jpg|pdf|txt";
|
this.siteSettings.authorized_extensions = "json|jpg|pdf|txt";
|
||||||
assert.ok(
|
assert.ok(
|
||||||
allowsImages(),
|
allowsImages(false, this.siteSettings),
|
||||||
"images are allowed when at least one extension is an image extension"
|
"images are allowed when at least one extension is an image extension"
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test("allowsAttachments", function(assert) {
|
QUnit.test("allowsAttachments", function(assert) {
|
||||||
this.siteSettings.authorized_extensions = "jpg|jpeg|gif";
|
this.siteSettings.authorized_extensions = "jpg|jpeg|gif";
|
||||||
assert.not(allowsAttachments(), "no attachments allowed by default");
|
assert.not(
|
||||||
|
allowsAttachments(false, this.siteSettings),
|
||||||
|
"no attachments allowed by default"
|
||||||
|
);
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = "jpg|jpeg|gif|*";
|
this.siteSettings.authorized_extensions = "jpg|jpeg|gif|*";
|
||||||
assert.ok(
|
assert.ok(
|
||||||
allowsAttachments(),
|
allowsAttachments(false, this.siteSettings),
|
||||||
"attachments are allowed when all extensions are allowed"
|
"attachments are allowed when all extensions are allowed"
|
||||||
);
|
);
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = "jpg|jpeg|gif|pdf";
|
this.siteSettings.authorized_extensions = "jpg|jpeg|gif|pdf";
|
||||||
assert.ok(
|
assert.ok(
|
||||||
allowsAttachments(),
|
allowsAttachments(false, this.siteSettings),
|
||||||
"attachments are allowed when at least one extension is not an image extension"
|
"attachments are allowed when at least one extension is not an image extension"
|
||||||
);
|
);
|
||||||
|
|
||||||
this.siteSettings.authorized_extensions = ".jpg|.jpeg|.gif|.pdf";
|
this.siteSettings.authorized_extensions = ".jpg|.jpeg|.gif|.pdf";
|
||||||
assert.ok(allowsAttachments(), "works with old extensions syntax");
|
assert.ok(
|
||||||
|
allowsAttachments(false, this.siteSettings),
|
||||||
|
"works with old extensions syntax"
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
function testUploadMarkdown(filename, opts = {}) {
|
function testUploadMarkdown(filename, opts = {}) {
|
||||||
|
|
Loading…
Reference in New Issue