Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in
Toggle navigation
C
common-web
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Iterations
Merge Requests
0
Merge Requests
0
Requirements
Requirements
List
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Test Cases
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Operations
Operations
Incidents
Environments
Packages & Registries
Packages & Registries
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issue
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
protokollsystem
common-web
Commits
2fe3e064
Commit
2fe3e064
authored
Feb 17, 2018
by
Robin Sonnabend
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add PAM auth backend
parent
f8939ef5
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
2 deletions
+23
-2
auth.py
auth.py
+23
-2
No files found.
auth.py
View file @
2fe3e064
...
...
@@ -3,6 +3,7 @@ import ssl
import
ldap3
from
ldap3.utils.dn
import
parse_dn
from
datetime
import
datetime
import
grp
,
pwd
,
pam
class
User
:
def
__init__
(
self
,
username
,
groups
,
timestamp
=
None
,
obsolete
=
False
,
permanent
=
False
):
...
...
@@ -137,7 +138,7 @@ class ADManager:
class
StaticUserManager
:
def
__init__
(
self
,
users
):
def
__init__
(
self
,
users
,
obsolete
=
False
):
self
.
passwords
=
{
username
:
password
for
(
username
,
password
,
groups
)
in
users
...
...
@@ -146,6 +147,7 @@ class StaticUserManager:
username
:
groups
for
(
username
,
password
,
groups
)
in
users
}
self
.
obsolete
=
obsolete
def
authenticate
(
self
,
username
,
password
):
return
(
username
in
self
.
passwords
...
...
@@ -156,8 +158,27 @@ class StaticUserManager:
yield
from
self
.
groups
[
username
]
def
all_groups
(
self
):
return
list
(
set
(
group
for
group
in
groups
.
values
()))
yield
from
list
(
set
(
group
for
group
in
groups
.
values
()))
class
PAMManager
:
def
__init__
(
self
,
obsolete
=
False
):
self
.
pam
=
pam
.
pam
()
self
.
obsolete
=
obsolete
def
authenticate
(
self
,
username
,
password
):
return
self
.
pam
.
authenticate
(
username
,
password
)
def
groups
(
self
,
username
,
password
=
None
):
print
(
username
)
yield
grp
.
getgrgid
(
pwd
.
getpwnam
(
username
).
pw_gid
).
gr_name
for
group
in
grp
.
getgrall
():
if
username
in
group
.
gr_mem
:
yield
group
.
gr_name
def
all_groups
(
self
):
for
group
in
grp
.
getgrall
():
yield
group
.
gr_name
class
SecurityManager
:
def
__init__
(
self
,
key
,
max_duration
=
300
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment