mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-05 02:39:33 +02:00
Follow works
This commit is contained in:
parent
e34c85e527
commit
350e31d6b6
39 changed files with 431 additions and 169 deletions
|
@ -1,19 +1,19 @@
|
|||
import * as Bluebird from 'bluebird'
|
||||
import * as express from 'express'
|
||||
import { UserRight } from '../../../shared/models/users/user-right.enum'
|
||||
import { getFormattedObjects } from '../../helpers'
|
||||
import { getOrCreateAccount } from '../../helpers/activitypub'
|
||||
import { logger } from '../../helpers/logger'
|
||||
import { getApplicationAccount } from '../../helpers/utils'
|
||||
import { REMOTE_SCHEME } from '../../initializers/constants'
|
||||
import { getAccountFromWebfinger } from '../../helpers/webfinger'
|
||||
import { SERVER_ACCOUNT_NAME } from '../../initializers/constants'
|
||||
import { database as db } from '../../initializers/database'
|
||||
import { sendFollow } from '../../lib/activitypub/send-request'
|
||||
import { asyncMiddleware, paginationValidator, setFollowersSort, setPagination } from '../../middlewares'
|
||||
import { authenticate } from '../../middlewares/oauth'
|
||||
import { setBodyHostsPort } from '../../middlewares/pods'
|
||||
import { setFollowingSort } from '../../middlewares/sort'
|
||||
import { ensureUserHasRight } from '../../middlewares/user-right'
|
||||
import { followValidator } from '../../middlewares/validators/pods'
|
||||
import { followersSortValidator, followingSortValidator } from '../../middlewares/validators/sort'
|
||||
import { sendFollow } from '../../lib/activitypub/send-request'
|
||||
import { authenticate } from '../../middlewares/oauth'
|
||||
import { ensureUserHasRight } from '../../middlewares/user-right'
|
||||
import { UserRight } from '../../../shared/models/users/user-right.enum'
|
||||
|
||||
const podsRouter = express.Router()
|
||||
|
||||
|
@ -67,22 +67,43 @@ async function follow (req: express.Request, res: express.Response, next: expres
|
|||
const hosts = req.body.hosts as string[]
|
||||
const fromAccount = await getApplicationAccount()
|
||||
|
||||
const tasks: Bluebird<any>[] = []
|
||||
const tasks: Promise<any>[] = []
|
||||
const accountName = SERVER_ACCOUNT_NAME
|
||||
|
||||
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'
|
||||
const p = loadLocalOrGetAccountFromWebfinger(accountName, host)
|
||||
.then(accountResult => {
|
||||
let targetAccount = accountResult.account
|
||||
|
||||
return db.sequelize.transaction(async t => {
|
||||
if (accountResult.loadedFromDB === false) {
|
||||
targetAccount = await targetAccount.save({ transaction: t })
|
||||
}
|
||||
|
||||
const [ accountFollow ] = await db.AccountFollow.findOrCreate({
|
||||
where: {
|
||||
accountId: fromAccount.id,
|
||||
targetAccountId: targetAccount.id
|
||||
},
|
||||
defaults: {
|
||||
state: 'pending',
|
||||
accountId: fromAccount.id,
|
||||
targetAccountId: targetAccount.id
|
||||
},
|
||||
transaction: t
|
||||
})
|
||||
|
||||
// Send a notification to remote server
|
||||
if (accountFollow.state === 'pending') {
|
||||
await sendFollow(fromAccount, targetAccount, t)
|
||||
}
|
||||
})
|
||||
})
|
||||
.then(() => sendFollow(fromAccount, targetAccount, t))
|
||||
})
|
||||
.catch(err => logger.warn('Cannot follow server %s.', `${accountName}@${host}`, err))
|
||||
|
||||
tasks.push(p)
|
||||
}
|
||||
|
@ -91,3 +112,16 @@ async function follow (req: express.Request, res: express.Response, next: expres
|
|||
|
||||
return res.status(204).end()
|
||||
}
|
||||
|
||||
async function loadLocalOrGetAccountFromWebfinger (name: string, host: string) {
|
||||
let loadedFromDB = true
|
||||
let account = await db.Account.loadByNameAndHost(name, host)
|
||||
|
||||
if (!account) {
|
||||
const nameWithDomain = name + '@' + host
|
||||
account = await getAccountFromWebfinger(nameWithDomain)
|
||||
loadedFromDB = false
|
||||
}
|
||||
|
||||
return { account, loadedFromDB }
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue