2023-02-26 18:08:07 -05:00
---
title: 'Authentication'
2023-03-03 04:33:06 -05:00
license: 'Apache-2.0'
2023-07-18 13:25:15 -04:00
origin_url: 'https://github.com/go-gitea/gitea/blob/faa28b5a44912f1c63afddab9396bae9e6fe061c/docs/content/doc/usage/authentication.en-us.md'
2023-02-26 18:08:07 -05:00
---
## LDAP (Lightweight Directory Access Protocol)
Both the LDAP via BindDN and the simple auth LDAP share the following fields:
- Authorization Name ** (required)**
- A name to assign to the new method of authorization.
- Host ** (required)**
- The address where the LDAP server can be reached.
- Example: `mydomain.com`
- Port ** (required)**
- The port to use when connecting to the server.
- Example: `389` for LDAP or `636` for LDAP SSL
- Enable TLS Encryption (optional)
- Whether to use TLS when connecting to the LDAP server.
- Admin Filter (optional)
- An LDAP filter specifying if a user should be given administrator
privileges. If a user account passes the filter, the user will be
privileged as an administrator.
- Example: `(objectClass=adminAccount)`
- Example for Microsoft Active Directory (AD): `(memberOf=CN=admin-group,OU=example,DC=example,DC=org)`
- Username attribute (optional)
- The attribute of the user's LDAP record containing the user name. Given
attribute value will be used for new Forgejo account user name after first
successful sign-in. Leave empty to use login name given on sign-in form.
- This is useful when supplied login name is matched against multiple
attributes, but only single specific attribute should be used for Forgejo
account name, see "User Filter".
- Example: `uid`
- Example for Microsoft Active Directory (AD): `sAMAccountName`
- First name attribute (optional)
- The attribute of the user's LDAP record containing the user's first name.
This will be used to populate their account information.
- Example: `givenName`
- Surname attribute (optional)
- The attribute of the user's LDAP record containing the user's surname.
This will be used to populate their account information.
- Example: `sn`
- E-mail attribute ** (required)**
- The attribute of the user's LDAP record containing the user's email
address. This will be used to populate their account information.
- Example: `mail`
### LDAP via BindDN
Adds the following fields:
- Bind DN (optional)
- The DN to bind to the LDAP server with when searching for the user. This
may be left blank to perform an anonymous search.
- Example: `cn=Search,dc=mydomain,dc=com`
- Bind Password (optional)
- The password for the Bind DN specified above, if any. _Note: The password
is stored encrypted with the SECRET_KEY on the server. It is still recommended
to ensure that the Bind DN has as few privileges as possible._
- User Search Base ** (required)**
- The LDAP base at which user accounts will be searched for.
- Example: `ou=Users,dc=mydomain,dc=com`
- User Filter ** (required)**
- An LDAP filter declaring how to find the user record that is attempting to
2023-06-05 12:24:04 -04:00
authenticate. The `%[1]s` matching parameter will be substituted with login
2023-02-26 18:08:07 -05:00
name given on sign-in form.
2023-06-05 12:24:04 -04:00
- Example: `(&(objectClass=posixAccount)(|(uid=%[1]s)(mail=%[1]s)))`
2023-02-26 18:08:07 -05:00
- Example for Microsoft Active Directory (AD): `(&(objectCategory=Person)(memberOf=CN=user-group,OU=example,DC=example,DC=org)(sAMAccountName=%s)(!(UserAccountControl:1.2.840.113556.1.4.803:=2)))`
- To substitute more than once, `%[1]s` should be used instead, e.g. when
matching supplied login name against multiple attributes such as user
identifier, email or even phone number.
- Example: `(&(objectClass=Person)(|(uid=%[1]s)(mail=%[1]s)(mobile=%[1]s)))`
- Enable user synchronization
- This option enables a periodic task that synchronizes the Forgejo users with
the LDAP server. The default period is every 24 hours but that can be
changed in the app.ini file. See the _cron.sync_external_users_ section in
the [sample
app.ini](https://codeberg.org/forgejo/forgejo/src/branch/forgejo/custom/conf/app.example.ini)
for detailed comments about that section. The _User Search Base_ and _User
Filter_ settings described above will limit which users can use Forgejo and
which users will be synchronized. When initially run the task will create
all LDAP users that match the given settings so take care if working with
large Enterprise LDAP directories.
### LDAP using simple auth
Adds the following fields:
- User DN ** (required)**
- A template to use as the user's DN. The `%s` matching parameter will be
substituted with login name given on sign-in form.
- Example: `cn=%s,ou=Users,dc=mydomain,dc=com`
- Example: `uid=%s,ou=Users,dc=mydomain,dc=com`
- User Search Base (optional)
- The LDAP base at which user accounts will be searched for.
- Example: `ou=Users,dc=mydomain,dc=com`
- User Filter ** (required)**
- An LDAP filter declaring when a user should be allowed to log in. The `%s`
matching parameter will be substituted with login name given on sign-in
form.
2023-06-05 12:24:04 -04:00
- Example: `(&(objectClass=posixAccount)(|(cn=%[1]s)(mail=%[1]s)))`
- Example: `(&(objectClass=posixAccount)(|(uid=%[1]s)(mail=%[1]s)))`
2023-02-26 18:08:07 -05:00
### Verify group membership in LDAP
Uses the following fields:
- Group Search Base (optional)
- The LDAP DN used for groups.
- Example: `ou=group,dc=mydomain,dc=com`
- Group Name Filter (optional)
- An LDAP filter declaring how to find valid groups in the above DN.
- Example: `(|(cn=forgejo_users)(cn=admins))`
- User Attribute in Group (optional)
- Which user LDAP attribute is listed in the group.
- Example: `uid`
- Group Attribute for User (optional)
- Which group LDAP attribute contains an array above user attribute names.
- Example: `memberUid`
## PAM (Pluggable Authentication Module)
2023-03-31 16:57:57 -04:00
This procedure enables PAM authentication. Users may still be added to the
system manually using the user administration. PAM provides a mechanism to
2023-02-26 18:08:07 -05:00
automatically add users to the current database by testing them against PAM
2023-03-31 16:57:57 -04:00
authentication. To work with normal Linux passwords, the user running Forgejo
2023-02-26 18:08:07 -05:00
must also have read access to `/etc/shadow` in order to check the validity of
the account when logging in using a public key.
**Note**: If a user has added SSH public keys into Forgejo, the use of these
2023-03-31 16:57:57 -04:00
keys _may_ bypass the login check system. Therefore, if you wish to disable a user who
2023-02-26 18:08:07 -05:00
authenticates with PAM, you _should_ also manually disable the account in Forgejo using the
built-in user manager.
1. Configure and prepare the installation.
2023-03-31 16:57:57 -04:00
- It is recommended that you create an administrative user.
- Deselecting automatic sign-up may also be desired.
2023-02-26 18:08:07 -05:00
1. Once the database has been initialized, log in as the newly created
2023-03-31 16:57:57 -04:00
administrative user.
2023-02-26 18:08:07 -05:00
1. Navigate to the user setting (icon in top-right corner), and select
2023-03-31 16:57:57 -04:00
`Site Administration` -> `Authentication Sources` , and select
`Add Authentication Source` .
2023-02-26 18:08:07 -05:00
1. Fill out the field as follows:
2023-03-31 16:57:57 -04:00
- `Authentication Type` : `PAM`
- `Name` : Any value should be valid here, use "System Authentication" if
you'd like.
- `PAM Service Name` : Select the appropriate file listed under `/etc/pam.d/`
that performs the authentication desired.[^1]
- `PAM Email Domain` : The e-mail suffix to append to user authentication.
For example, if the login system expects a user called `gituser` , and this
field is set to `mail.com` , then Forgejo will expect the `user email` field
for an authenticated GIT instance to be `gituser@mail.com` .[^2]
2023-02-26 18:08:07 -05:00
**Note**: PAM support is added via build-time flags (TAGS="pam" make build),
2023-03-31 16:57:57 -04:00
and the official binaries provided do not have this enabled. PAM requires that
2023-02-26 18:08:07 -05:00
the necessary libpam dynamic library be available and the necessary PAM
development headers be accessible to the compiler.
2023-03-31 16:57:57 -04:00
[^1]:
For example, using standard Linux log-in on Debian "Bullseye" use
`common-session-noninteractive` - this value may be valid for other flavors of
Debian including Ubuntu and Mint, consult your distribution's documentation.
[^2]:
**This is a required field for PAM** . Be aware: In the above example, the
user will log into the Forgejo web interface as `gituser` and not `gituser@mail.com`
2023-02-26 18:08:07 -05:00
## FreeIPA
- In order to log in to Forgejo using FreeIPA credentials, a bind account needs to
be created for Forgejo:
- On the FreeIPA server, create a `forgejo.ldif` file, replacing `dc=example,dc=com`
with your DN, and provide an appropriately secure password:
```sh
dn: uid=forgejo,cn=sysaccounts,cn=etc,dc=example,dc=com
changetype: add
objectclass: account
objectclass: simplesecurityobject
uid: forgejo
userPassword: secure password
passwordExpirationTime: 20380119031407Z
nsIdleTimeout: 0
```
- Import the LDIF (change localhost to an IPA server if needed). A prompt for
Directory Manager password will be presented:
```sh
ldapmodify -h localhost -p 389 -x -D \
"cn=Directory Manager" -W -f forgejo.ldif
```
- Add an IPA group for forgejo_users :
```sh
ipa group-add --desc="Forgejo Users" forgejo_users
```
- Note: For errors about IPA credentials, run `kinit admin` and provide the
domain admin account password.
- Log in to Forgejo as an Administrator and click on "Authentication" under Admin Panel.
Then click `Add New Source` and fill in the details, changing all where appropriate.