ed458fb619
* feat(server): add server authz pipeline rework first sketch * feat(server authz): add new server authz middleware poc implementation * test(server authz): add unittests for the new server authz workflow * feat(wip rework of fileuploads vs blob storage): add basim impl of separate blob storage service * feat(fileimport service): refactored file import service to utilize the new asssetstorage service * refactor(server errors): refactor server errors to use the shared module definitions Now all the errors inherit from BaseError * refactor(fileimport service): cleanup after refactor * feat(frontend fileimports): use the new blob storage for downloading the original file * refactor(server fileimports): clean up the remnants of S3 storage from file imports * refactor(server authz): centralize generic authz pipeline configs * refactor(server blob storage): refactor / rename everything to use the `blob-storage` name * ci(circleci): add s3 objectstorage environment variables * ci(circleci): fix missing env variables * ci(circleci): add minio test container * ci(circleci): fix minio app startup * ci(circleci): enable circleci remote docker * ci(circleci): fix minio startup * ci(cirleci): detach and wait properly for minio to start * ci(circleci): revert to additional minio img config, it only fails when the container is stopped ?! * ci(circleci): disable file uploads * fix(fileimports): update with blob storage refactor leftovers * feat(server blob storage): add blob storage graphql api * refactor(server errors): merge new errors to shared module * fix(server comments rte): fix import for RTE error * chore(fileimports): remove node-fetch from dependency * chore(server): remove body parser dependency * fix(server blob storage): fix gql api * fix(frontend): fix fileupload item not loading the new upload status, cause of premature event fire * feat(server blob storage): fix file size limit and allow for public streams * Update packages/server/modules/blobstorage/graph/schemas/blobstorage.graphql Co-authored-by: Kristaps Fabians Geikins <fabis94@live.com> * chore(blobstorage): fix PR review issues * fix(server): fix import bugs Co-authored-by: Kristaps Fabians Geikins <fabis94@live.com>
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
const VError = require('verror')
|
|
|
|
/**
|
|
* Base application error (don't use directly, treat it as abstract). Built on top of `verror` so that you can
|
|
* chain errors (e.cause is the previous error) and also add arbitrary metadata using the `info` option.
|
|
*
|
|
* This allows for much nicer error handling & monitoring
|
|
*/
|
|
class BaseError extends VError {
|
|
/**
|
|
* Error code (override in child class)
|
|
*/
|
|
static code = 'BASE_APP_ERROR'
|
|
|
|
/**
|
|
* Default message if none is passed
|
|
*/
|
|
static defaultMessage = 'Unexpected error occurred!'
|
|
|
|
/**
|
|
* @param {string | null} message
|
|
* @param {import('verror').Options | Error} options
|
|
*/
|
|
constructor(message, options) {
|
|
// Resolve options correctly
|
|
if (options) {
|
|
const cause = options instanceof Error ? options : options.cause
|
|
options = options instanceof Error ? { cause } : options
|
|
} else {
|
|
options = {}
|
|
}
|
|
|
|
const info = {
|
|
...(options.info || {}),
|
|
code: new.target.code
|
|
}
|
|
|
|
options.info = info
|
|
|
|
// Get message from defaultMessage, if it's empty
|
|
if (!message) {
|
|
message = new.target.defaultMessage
|
|
}
|
|
|
|
// Resolve constructor name
|
|
const constructorName = new.target.name
|
|
options.name = constructorName
|
|
|
|
super(options, message)
|
|
}
|
|
|
|
/**
|
|
* Get collected info of this object and previous errors
|
|
*/
|
|
info() {
|
|
return BaseError.info(this)
|
|
}
|
|
}
|
|
|
|
module.exports = { BaseError }
|