]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/helpers/custom-validators/activitypub/actor.ts
Add avatar max size limit
[github/Chocobozzz/PeerTube.git] / server / helpers / custom-validators / activitypub / actor.ts
CommitLineData
fadf619a
C
1import * as validator from 'validator'
2import { CONSTRAINTS_FIELDS } from '../../../initializers'
3import { isAccountNameValid } from '../accounts'
e12a0092
C
4import { exists } from '../misc'
5import { isVideoChannelNameValid } from '../video-channels'
50d6de9c 6import { isActivityPubUrlValid, isBaseActivityValid, setValidAttributedTo } from './misc'
fadf619a
C
7
8function isActorEndpointsObjectValid (endpointObject: any) {
9 return isActivityPubUrlValid(endpointObject.sharedInbox)
10}
11
12function isActorPublicKeyObjectValid (publicKeyObject: any) {
13 return isActivityPubUrlValid(publicKeyObject.id) &&
14 isActivityPubUrlValid(publicKeyObject.owner) &&
15 isActorPublicKeyValid(publicKeyObject.publicKeyPem)
16}
17
18function isActorTypeValid (type: string) {
19 return type === 'Person' || type === 'Application' || type === 'Group'
20}
21
22function isActorPublicKeyValid (publicKey: string) {
23 return exists(publicKey) &&
24 typeof publicKey === 'string' &&
25 publicKey.startsWith('-----BEGIN PUBLIC KEY-----') &&
e12a0092 26 publicKey.indexOf('-----END PUBLIC KEY-----') !== -1 &&
01de67b9 27 validator.isLength(publicKey, CONSTRAINTS_FIELDS.ACTORS.PUBLIC_KEY)
fadf619a
C
28}
29
e12a0092 30const actorNameRegExp = new RegExp('[ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_]+')
fadf619a 31function isActorPreferredUsernameValid (preferredUsername: string) {
e12a0092 32 return exists(preferredUsername) && validator.matches(preferredUsername, actorNameRegExp)
50d6de9c
C
33}
34
50d6de9c 35function isActorNameValid (name: string) {
e12a0092 36 return isAccountNameValid(name) || isVideoChannelNameValid(name)
fadf619a
C
37}
38
39function isActorPrivateKeyValid (privateKey: string) {
40 return exists(privateKey) &&
41 typeof privateKey === 'string' &&
42 privateKey.startsWith('-----BEGIN RSA PRIVATE KEY-----') &&
e12a0092
C
43 // Sometimes there is a \n at the end, so just assert the string contains the end mark
44 privateKey.indexOf('-----END RSA PRIVATE KEY-----') !== -1 &&
01de67b9 45 validator.isLength(privateKey, CONSTRAINTS_FIELDS.ACTORS.PRIVATE_KEY)
fadf619a
C
46}
47
48function isRemoteActorValid (remoteActor: any) {
da854ddd
C
49 return exists(remoteActor) &&
50 isActivityPubUrlValid(remoteActor.id) &&
fadf619a
C
51 isActorTypeValid(remoteActor.type) &&
52 isActivityPubUrlValid(remoteActor.following) &&
53 isActivityPubUrlValid(remoteActor.followers) &&
54 isActivityPubUrlValid(remoteActor.inbox) &&
55 isActivityPubUrlValid(remoteActor.outbox) &&
56 isActorPreferredUsernameValid(remoteActor.preferredUsername) &&
57 isActivityPubUrlValid(remoteActor.url) &&
58 isActorPublicKeyObjectValid(remoteActor.publicKey) &&
50d6de9c 59 isActorEndpointsObjectValid(remoteActor.endpoints) &&
50d6de9c
C
60 setValidAttributedTo(remoteActor) &&
61 // If this is not an account, it should be attributed to an account
62 // In PeerTube we use this to attach a video channel to a specific account
63 (remoteActor.type === 'Person' || remoteActor.attributedTo.length !== 0)
fadf619a
C
64}
65
66function isActorFollowingCountValid (value: string) {
67 return exists(value) && validator.isInt('' + value, { min: 0 })
68}
69
70function isActorFollowersCountValid (value: string) {
71 return exists(value) && validator.isInt('' + value, { min: 0 })
72}
73
74function isActorDeleteActivityValid (activity: any) {
75 return isBaseActivityValid(activity, 'Delete')
76}
77
78function isActorFollowActivityValid (activity: any) {
79 return isBaseActivityValid(activity, 'Follow') &&
80 isActivityPubUrlValid(activity.object)
81}
82
83function isActorAcceptActivityValid (activity: any) {
84 return isBaseActivityValid(activity, 'Accept')
85}
86
87// ---------------------------------------------------------------------------
88
89export {
90 isActorEndpointsObjectValid,
91 isActorPublicKeyObjectValid,
92 isActorTypeValid,
93 isActorPublicKeyValid,
94 isActorPreferredUsernameValid,
95 isActorPrivateKeyValid,
96 isRemoteActorValid,
97 isActorFollowingCountValid,
98 isActorFollowersCountValid,
99 isActorFollowActivityValid,
100 isActorAcceptActivityValid,
50d6de9c 101 isActorDeleteActivityValid,
39fdb3c0 102 isActorNameValid
fadf619a 103}