import * as validator from 'validator'
-import { CONSTRAINTS_FIELDS } from '../../../initializers'
+import { CONSTRAINTS_FIELDS } from '../../../initializers/constants'
import { isTestInstance } from '../../core-utils'
import { exists } from '../misc'
-function isActivityPubUrlValid (url: string) {
+function isUrlValid (url: string) {
const isURLOptions = {
require_host: true,
require_tld: true,
isURLOptions.require_tld = false
}
- return exists(url) && validator.isURL(url, isURLOptions) && validator.isLength(url, CONSTRAINTS_FIELDS.ACCOUNTS.URL)
+ return exists(url) && validator.isURL('' + url, isURLOptions)
+}
+
+function isActivityPubUrlValid (url: string) {
+ return isUrlValid(url) && validator.isLength('' + url, CONSTRAINTS_FIELDS.ACTORS.URL)
}
function isBaseActivityValid (activity: any, type: string) {
- return (activity['@context'] === undefined || Array.isArray(activity['@context'])) &&
- activity.type === type &&
+ return activity.type === type &&
isActivityPubUrlValid(activity.id) &&
- isActivityPubUrlValid(activity.actor) &&
- (
- activity.to === undefined ||
- (Array.isArray(activity.to) && activity.to.every(t => isActivityPubUrlValid(t)))
- ) &&
+ isObjectValid(activity.actor) &&
+ isUrlCollectionValid(activity.to) &&
+ isUrlCollectionValid(activity.cc)
+}
+
+function isUrlCollectionValid (collection: any) {
+ return collection === undefined ||
+ (Array.isArray(collection) && collection.every(t => isActivityPubUrlValid(t)))
+}
+
+function isObjectValid (object: any) {
+ return exists(object) &&
(
- activity.cc === undefined ||
- (Array.isArray(activity.cc) && activity.cc.every(t => isActivityPubUrlValid(t)))
+ isActivityPubUrlValid(object) || isActivityPubUrlValid(object.id)
)
}
+function setValidAttributedTo (obj: any) {
+ if (Array.isArray(obj.attributedTo) === false) {
+ obj.attributedTo = []
+ return true
+ }
+
+ obj.attributedTo = obj.attributedTo.filter(a => {
+ return (a.type === 'Group' || a.type === 'Person') && isActivityPubUrlValid(a.id)
+ })
+
+ return true
+}
+
export {
+ isUrlValid,
isActivityPubUrlValid,
- isBaseActivityValid
+ isBaseActivityValid,
+ setValidAttributedTo,
+ isObjectValid
}