mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-05 02:39:33 +02:00
Send follow/accept
This commit is contained in:
parent
7a7724e66e
commit
ce548a10db
9 changed files with 160 additions and 19 deletions
|
@ -1,10 +1,16 @@
|
|||
import * as Bluebird from 'bluebird'
|
||||
import * as express from 'express'
|
||||
import { getFormattedObjects } from '../../helpers'
|
||||
import { getOrCreateAccount } from '../../helpers/activitypub'
|
||||
import { getApplicationAccount } from '../../helpers/utils'
|
||||
import { REMOTE_SCHEME } from '../../initializers/constants'
|
||||
import { database as db } from '../../initializers/database'
|
||||
import { asyncMiddleware, paginationValidator, setFollowersSort, setPagination } from '../../middlewares'
|
||||
import { setBodyHostsPort } from '../../middlewares/pods'
|
||||
import { setFollowingSort } from '../../middlewares/sort'
|
||||
import { followValidator } from '../../middlewares/validators/pods'
|
||||
import { followersSortValidator, followingSortValidator } from '../../middlewares/validators/sort'
|
||||
import { sendFollow } from '../../lib/activitypub/send-request'
|
||||
|
||||
const podsRouter = express.Router()
|
||||
|
||||
|
@ -16,6 +22,12 @@ podsRouter.get('/following',
|
|||
asyncMiddleware(listFollowing)
|
||||
)
|
||||
|
||||
podsRouter.post('/follow',
|
||||
followValidator,
|
||||
setBodyHostsPort,
|
||||
asyncMiddleware(follow)
|
||||
)
|
||||
|
||||
podsRouter.get('/followers',
|
||||
paginationValidator,
|
||||
followersSortValidator,
|
||||
|
@ -45,3 +57,32 @@ async function listFollowers (req: express.Request, res: express.Response, next:
|
|||
|
||||
return res.json(getFormattedObjects(resultList.data, resultList.total))
|
||||
}
|
||||
|
||||
async function follow (req: express.Request, res: express.Response, next: express.NextFunction) {
|
||||
const hosts = req.body.hosts as string[]
|
||||
const fromAccount = await getApplicationAccount()
|
||||
|
||||
const tasks: Bluebird<any>[] = []
|
||||
for (const host of hosts) {
|
||||
const url = REMOTE_SCHEME.HTTP + '://' + host
|
||||
const targetAccount = await getOrCreateAccount(url)
|
||||
|
||||
// We process each host in a specific transaction
|
||||
// First, we add the follow request in the database
|
||||
// Then we send the follow request to other account
|
||||
const p = db.sequelize.transaction(async t => {
|
||||
return db.AccountFollow.create({
|
||||
accountId: fromAccount.id,
|
||||
targetAccountId: targetAccount.id,
|
||||
state: 'pending'
|
||||
})
|
||||
.then(() => sendFollow(fromAccount, targetAccount, t))
|
||||
})
|
||||
|
||||
tasks.push(p)
|
||||
}
|
||||
|
||||
await Promise.all(tasks)
|
||||
|
||||
return res.status(204).end()
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue