mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-20 02:05:21 -04:00
auth/gitlab: Migrate to AuthMiddleware
Signed-off-by: David Mehren <dmehren1@gmail.com>
This commit is contained in:
parent
3c216795e7
commit
1353e61e87
2 changed files with 41 additions and 35 deletions
|
@ -1,35 +0,0 @@
|
||||||
'use strict'
|
|
||||||
|
|
||||||
const Router = require('express').Router
|
|
||||||
const passport = require('passport')
|
|
||||||
const GitlabStrategy = require('passport-gitlab2').Strategy
|
|
||||||
const config = require('../../../config')
|
|
||||||
const response = require('../../../response')
|
|
||||||
const { passportGeneralCallback } = require('../utils')
|
|
||||||
|
|
||||||
let gitlabAuth = module.exports = Router()
|
|
||||||
|
|
||||||
passport.use(new GitlabStrategy({
|
|
||||||
baseURL: config.gitlab.baseURL,
|
|
||||||
clientID: config.gitlab.clientID,
|
|
||||||
clientSecret: config.gitlab.clientSecret,
|
|
||||||
scope: config.gitlab.scope,
|
|
||||||
callbackURL: config.serverURL + '/auth/gitlab/callback'
|
|
||||||
}, passportGeneralCallback))
|
|
||||||
|
|
||||||
gitlabAuth.get('/auth/gitlab', function (req, res, next) {
|
|
||||||
passport.authenticate('gitlab')(req, res, next)
|
|
||||||
})
|
|
||||||
|
|
||||||
// gitlab auth callback
|
|
||||||
gitlabAuth.get('/auth/gitlab/callback',
|
|
||||||
passport.authenticate('gitlab', {
|
|
||||||
successReturnToOrRedirect: config.serverURL + '/',
|
|
||||||
failureRedirect: config.serverURL + '/'
|
|
||||||
})
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!config.gitlab.scope || config.gitlab.scope === 'api') {
|
|
||||||
// gitlab callback actions
|
|
||||||
gitlabAuth.get('/auth/gitlab/callback/:noteId/:action', response.gitlabActions)
|
|
||||||
}
|
|
41
lib/web/auth/gitlab/index.ts
Normal file
41
lib/web/auth/gitlab/index.ts
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
import { Router } from 'express'
|
||||||
|
import passport from 'passport'
|
||||||
|
import { Strategy as GitlabStrategy } from 'passport-gitlab2'
|
||||||
|
import { config } from '../../../config'
|
||||||
|
import { response } from '../../../response'
|
||||||
|
import { AuthMiddleware } from '../interface'
|
||||||
|
import { passportGeneralCallback } from '../utils'
|
||||||
|
|
||||||
|
export const GitlabMiddleware: AuthMiddleware =
|
||||||
|
{
|
||||||
|
getMiddleware (): Router {
|
||||||
|
const gitlabAuth = module.exports = Router()
|
||||||
|
|
||||||
|
passport.use(new GitlabStrategy({
|
||||||
|
baseURL: config.gitlab.baseURL,
|
||||||
|
clientID: config.gitlab.clientID,
|
||||||
|
clientSecret: config.gitlab.clientSecret,
|
||||||
|
scope: config.gitlab.scope,
|
||||||
|
callbackURL: config.serverURL + '/auth/gitlab/callback'
|
||||||
|
}, passportGeneralCallback))
|
||||||
|
|
||||||
|
gitlabAuth.get('/auth/gitlab', function (req, res, next) {
|
||||||
|
passport.authenticate('gitlab')(req, res, next)
|
||||||
|
})
|
||||||
|
|
||||||
|
// gitlab auth callback
|
||||||
|
gitlabAuth.get('/auth/gitlab/callback',
|
||||||
|
passport.authenticate('gitlab', {
|
||||||
|
successReturnToOrRedirect: config.serverURL + '/',
|
||||||
|
failureRedirect: config.serverURL + '/'
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!config.gitlab.scope || config.gitlab.scope === 'api'
|
||||||
|
) {
|
||||||
|
// gitlab callback actions
|
||||||
|
gitlabAuth.get('/auth/gitlab/callback/:noteId/:action', response.gitlabActions)
|
||||||
|
}
|
||||||
|
return gitlabAuth
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue