https://github.com/shimt/pam-exec-oauth2
Allows Linux user authentication to OAuth2 via pam_exec
https://github.com/shimt/pam-exec-oauth2
go linux oauth2 pam
Last synced: 7 months ago
JSON representation
Allows Linux user authentication to OAuth2 via pam_exec
- Host: GitHub
- URL: https://github.com/shimt/pam-exec-oauth2
- Owner: shimt
- License: mit
- Archived: true
- Created: 2017-03-02T10:33:42.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2021-06-12T05:47:24.000Z (over 4 years ago)
- Last Synced: 2024-11-01T10:35:03.793Z (12 months ago)
- Topics: go, linux, oauth2, pam
- Language: Go
- Homepage:
- Size: 226 KB
- Stars: 83
- Watchers: 9
- Forks: 37
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pam-exec-oauth2
**This repository is no longer maintained.**
## Install
```bash
go get github.com/shimt/pam-exec-oauth2PREFIX=/opt/pam-exec-oauth2
sudo mkdir $PREFIX
sudo cp go/bin/pam-exec-oauth2 $PREFIX/pam-exec-oauth2
sudo touch $PREFIX/pam-exec-oauth2.yaml
sudo chmod 755 $PREFIX/pam-exec-oauth2
sudo chmod 600 $PREFIX/pam-exec-oauth2.yaml
```## Configuration
### PAM
add the following lines to `/etc/pam.d/common-auth`.
```
auth sufficient pam_exec.so expose_authtok /opt/pam-exec-oauth2/pam-exec-oauth2
```### pam-exec-oauth2.yaml
edit `/opt/pam-exec-oauth2/pam-exec-oauth2.yaml`
#### Azure AD
```yaml
{
client-id: "xxxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
client-secret: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
redirect-url: "urn:ietf:wg:oauth:2.0:oob",
scopes: ["email"],
endpoint-auth-url: "https://login.windows.net/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/oauth2/authorize",
endpoint-token-url: "https://login.windows.net/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/oauth2/token",
extra-parameters: {
resource: "https://graph.windows.net/"
},
username-format: "%s@example.org",
}
```