kopia lustrzana https://github.com/cloudflare/wildebeest
				
				
				
			ensure the original Actor is deleting
							rodzic
							
								
									64743520f7
								
							
						
					
					
						commit
						e6617788c1
					
				| 
						 | 
				
			
			@ -345,15 +345,19 @@ export async function handle(
 | 
			
		|||
		// https://www.w3.org/TR/activitystreams-vocabulary/#dfn-delete
 | 
			
		||||
		case 'Delete': {
 | 
			
		||||
			const objectId = getObjectAsId()
 | 
			
		||||
 | 
			
		||||
			// FIXME: check that Actor is the author of the Note.
 | 
			
		||||
			const actorId = getActorAsId()
 | 
			
		||||
 | 
			
		||||
			const obj = await objects.getObjectByOriginalId(db, objectId)
 | 
			
		||||
			if (obj === null) {
 | 
			
		||||
				console.warn('unknown object')
 | 
			
		||||
			if (obj === null || !obj[originalActorIdSymbol]) {
 | 
			
		||||
				console.warn('unknown object or missing originalActorId')
 | 
			
		||||
				break
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if (actorId.toString() !== obj[originalActorIdSymbol]) {
 | 
			
		||||
				console.warn(`authorized Delete (${actorId} vs ${obj[originalActorIdSymbol]})`)
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if (!['Note'].includes(obj.type)) {
 | 
			
		||||
				console.warn('unsupported Update for Object type: ' + activity.object.type)
 | 
			
		||||
				return
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -664,6 +664,43 @@ describe('ActivityPub', () => {
 | 
			
		|||
				assert.equal(count, 0)
 | 
			
		||||
			})
 | 
			
		||||
 | 
			
		||||
			test('reject Note deletion from another Actor', async () => {
 | 
			
		||||
				const db = await makeDB()
 | 
			
		||||
				const actorA = await createPerson(domain, db, userKEK, 'a@cloudflare.com')
 | 
			
		||||
				const actorB = await createPerson(domain, db, userKEK, 'b@cloudflare.com')
 | 
			
		||||
 | 
			
		||||
				const originalObjectId = 'https://example.com/note123'
 | 
			
		||||
 | 
			
		||||
				// ActorB creates a Note
 | 
			
		||||
				await db
 | 
			
		||||
					.prepare(
 | 
			
		||||
						'INSERT INTO objects (id, type, properties, original_actor_id, original_object_id, local, mastodon_id) VALUES (?, ?, ?, ?, ?, 1, ?)'
 | 
			
		||||
					)
 | 
			
		||||
					.bind(
 | 
			
		||||
						'https://example.com/object1',
 | 
			
		||||
						'Note',
 | 
			
		||||
						JSON.stringify({ content: 'my first status' }),
 | 
			
		||||
						actorB.id.toString(),
 | 
			
		||||
						originalObjectId,
 | 
			
		||||
						'mastodonid1'
 | 
			
		||||
					)
 | 
			
		||||
					.run()
 | 
			
		||||
 | 
			
		||||
				const activity: any = {
 | 
			
		||||
					type: 'Delete',
 | 
			
		||||
					actor: actorA.id, // ActorA attempts to delete
 | 
			
		||||
					to: [],
 | 
			
		||||
					cc: [],
 | 
			
		||||
					object: actorA.id,
 | 
			
		||||
				}
 | 
			
		||||
 | 
			
		||||
				await activityHandler.handle(domain, activity, db, userKEK, adminEmail, vapidKeys)
 | 
			
		||||
 | 
			
		||||
				// Ensure that we didn't actually delete the object
 | 
			
		||||
				const { count } = await db.prepare('SELECT count(*) as count FROM objects').first<{ count: number }>()
 | 
			
		||||
				assert.equal(count, 1)
 | 
			
		||||
			})
 | 
			
		||||
 | 
			
		||||
			test('ignore deletion of an Actor', async () => {
 | 
			
		||||
				const db = await makeDB()
 | 
			
		||||
				const actorA = await createPerson(domain, db, userKEK, 'a@cloudflare.com')
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Ładowanie…
	
		Reference in New Issue