In this guide we will learn how to manage FreeIPA users and groups.
After installing FreeIPA server and initializing kerberos ticket, you would want to do identity management next, which starts with creating groups and users.
Prerequisites
For this guide, you will need a functioning freeipa server. Checkout these guides on how to set up freeipa server:
Top proceed, you also need to have a valid kerberos ticket. Generate ticket for principal using this:
This is for my admin user:
1
2
3
| $ kinit admin
Password for admin@IPA.CITIZIX.COM:
|
Confirm ticket validation by listing cached Kerberos tickets using this command:
1
2
3
4
5
6
7
| $ klist
Ticket cache: KCM:1000
Default principal: admin@IPA.CITIZIX.COM
Valid starting Expires Service principal
12/02/2021 21:38:40 12/03/2021 20:58:27 krbtgt/IPA.CITIZIX.COM@IPA.CITIZIX.COM
|
The default lifetime of the ticket is 24 hours
Related Content
Managing Groups in FreeIPA
In FreeIPA, a user group is a set of users with common password policies, privileges, and other characteristics. A user group can include:
- FreeIPA users
- Other user groups
- External users, i.e users that exist outside of FreeIPA domain
Supported group types are:
- POSIX groups - This is the default type which supports Linux POSIX attributes for group members. Groups that interact with Active Directory cannot use POSIX attributes(e.g uidNumber and gidNumber)
- Non-POSIX groups - These do not support POSIX attributes. For example, they do not have GID.
- External groups - Used to add group members that exist in an identity store outside of the FreeIPA domain, such as [local system, _Active Directory domain or a directory se_rvice]. These groups do not support POSIX attributes.
Below groups are created by default at the installation and configuration of FreeIPA Server:
admins
- Consist of all users with administrative privileges, including the default admin useripausers
- Consist of all FreeIPA userstrust admins
- Users with privileges to manage the Active Directory trusts
When a user is added to a user group, the user gains the privileges and policies associated with the group
Add User Group in FreeIPA
Use this command to add group called qa
in FreeIPA
1
| ipa group-add --desc='QA Engineers' qa
|
This is the output on my server
1
2
3
4
5
6
7
8
| $ ipa group-add --desc='QA Engineers' qa
----------------
Added group "qa"
----------------
Group name: qa
Description: QA Engineers
GID: 1063800004
|
By default, the command above adds a POSIX user group. To specify a different group type, add as an option to the command:
To create an external group
1
| ipa group-add --external groupname
|
To create a non-POSIX group
1
| ipa group-add --nonposix groupname
|
Using Custom Group ID
To specify a custom Group ID(GID), use the option gid=custom_GID
1
| ipa group-add gid=custom_GID groupname
|
But you’ll have be careful to avoid ID conflicts.
Searching for user groups
Display all user groups:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
| $ ipa group-find
----------------
5 groups matched
----------------
Group name: admins
Description: Account administrators group
GID: 1063800000
Group name: editors
Description: Limited admins who can edit other users
GID: 1063800002
Group name: ipausers
Description: Default group for all users
Group name: qa
Description: QA Engineers
GID: 1063800004
Group name: trust admins
Description: Trusts administrators group
----------------------------
Number of entries returned 5
----------------------------
|
Display all non-POSIX groups:
1
2
3
4
5
6
7
8
9
10
11
12
13
| $ ipa group-find --nonposix
----------------
2 groups matched
----------------
Group name: ipausers
Description: Default group for all users
Group name: trust admins
Description: Trusts administrators group
----------------------------
Number of entries returned 2
----------------------------
|
Display all POSIX groups:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
| $ ipa group-find --posix
----------------
3 groups matched
----------------
Group name: admins
Description: Account administrators group
GID: 1063800000
Group name: editors
Description: Limited admins who can edit other users
GID: 1063800002
Group name: qa
Description: QA Engineers
GID: 1063800004
----------------------------
Number of entries returned 3
----------------------------
|
Display all external group:
1
2
3
4
5
6
7
8
| $ ipa group-find --external
----------------
0 groups matched
----------------
----------------------------
Number of entries returned 0
----------------------------
|
Search FreeIPA group accounts.
1
| ipa group-find development
|
You can also limit the search results to groups that contain a particular user:
1
| ipa group-find --user=user_name
|
The inverse is true when searching for groups that do not contain a particular user:
1
| ipa group-find --no-user=user_name
|
Add members to a FreeIPA group account.
1
| ipa group-add-member --users=jdoe qa
|
Add FreeIPA group to FreeIPA group nested
1
| ipa group-add-member --groups=development engineering
|
Remove FreeIPA group accounts.
Managing Users in FreeIPA
Add a FreeIPA User Account
The command syntax is:
These are the commonly used ipa user-add
command options:
-first=STR
- User’s first name-last=STR
- User’s last name-cn=STR
- User account full name-homedir=STR
- Home directory-shell=STR
- Login shell-email=STR
- Email address-password
- Prompt to set the user password-mobile=STR
- Mobile Telephone Number
The command runs a script where you can add basic data necessary for creating a user account.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
| $ ipa user-add
First name: John
Last name: Doe
User login [jdoe]: jdoe
-----------------
Added user "jdoe"
-----------------
User login: jdoe
First name: John
Last name: Doe
Full name: John Doe
Display name: John Doe
Initials: JD
Home directory: /home/jdoe
GECOS: John Doe
Login shell: /bin/bash
Principal name: jdoe@IPA.CITIZIX.COM
Principal alias: jdoe@IPA.CITIZIX.COM
Email address: jdoe@ipa.citizix.com
UID: 1063800005
GID: 1063800005
Password: False
Member of groups: ipausers
Kerberos keys available: False
|
A user password is not set while the user account is being created.
To assign user a password, use the ipa command to add the user with below option:
First delete the user
1
2
3
4
5
| $ ipa user-del jdoe
-------------------
Deleted user "jdoe"
-------------------
|
Then create user specifying password
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
| $ ipa user-add --first=John --last=Doe --password jdoe
Password:
Enter Password again to verify:
-----------------
Added user "jdoe"
-----------------
User login: jdoe
First name: John
Last name: Doe
Full name: John Doe
Display name: John Doe
Initials: JD
Home directory: /home/jdoe
GECOS: John Doe
Login shell: /bin/bash
Principal name: jdoe@IPA.CITIZIX.COM
Principal alias: jdoe@IPA.CITIZIX.COM
User password expiration: 20211202190348Z
Email address: jdoe@ipa.citizix.com
UID: 1063800006
GID: 1063800006
Password: True
Member of groups: ipausers
Kerberos keys available: True
|
To change password for a FreeIPA user account
1
2
3
4
5
6
7
| $ ipa passwd jdoe
New Password:
Enter New Password again to verify:
-------------------------------------------
Changed password for "jdoe@IPA.CITIZIX.COM"
-------------------------------------------
|
Lock User Account
1
2
3
4
| $ ipa user-disable jdoe
----------------------------
Disabled user account "jdoe"
----------------------------
|
Unlock user account
1
2
3
4
| $ ipa user-enable jdoe
---------------------------
Enabled user account "jdoe"
---------------------------
|
Search FreeIPA user accounts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
| $ ipa user-find jdoe
--------------
1 user matched
--------------
User login: jdoe
First name: John
Last name: Doe
Home directory: /home/jdoe
Login shell: /bin/bash
Principal name: jdoe@IPA.CITIZIX.COM
Principal alias: jdoe@IPA.CITIZIX.COM
Email address: jdoe@ipa.citizix.com
UID: 1063800006
GID: 1063800006
Account disabled: False
----------------------------
Number of entries returned 1
----------------------------
|
Show raw user in freeipa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| $ ipa user-show --raw jdoe
uid: jdoe
givenname: John
sn: Doe
homedirectory: /home/jdoe
loginshell: /bin/bash
krbcanonicalname: jdoe@IPA.CITIZIX.COM
krbprincipalname: jdoe@IPA.CITIZIX.COM
mail: jdoe@ipa.citizix.com
uidnumber: 1063800006
gidnumber: 1063800006
nsaccountlock: FALSE
has_password: TRUE
has_keytab: TRUE
|
To change created user information use command syntax:
1
| ipa [global-options] user-mod LOGIN
|
To modify password
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
| $ ipa user-mod --password jdoe
Password:
Enter Password again to verify:
--------------------
Modified user "jdoe"
--------------------
User login: jdoe
First name: John
Last name: Doe
Home directory: /home/jdoe
Login shell: /bin/bash
Principal name: jdoe@IPA.CITIZIX.COM
Principal alias: jdoe@IPA.CITIZIX.COM
Email address: jdoe@ipa.citizix.com
UID: 1063800006
GID: 1063800006
Account disabled: False
Password: True
Member of groups: ipausers
Kerberos keys available: True
|
Remove FreeIPA user accounts
Add a member to a user group by using the command syntax:
1
| ipa [global-options] group-add-member GROUP-NAME [options]
|
Common options:
-users=STR
- Users to add to the group-groups=STR
- Groups to add to the named group-services=STR
- Services to add to the group-external=STR
- Members of a trusted domain in DOM\name or name@domain form
See below examples on adding user/group to a group
Add the user jdoe
as a member manager of qa
:
1
2
3
4
5
6
7
8
9
| $ ipa group-add-member qa --users=jdoe
Group name: qa
Description: QA Engineers
GID: 1063800004
Member users: jdoe
-------------------------
Number of members added 1
-------------------------
|
Add a user as a member manager to a user group
1
2
3
4
5
6
7
8
| $ ipa group-add-member-manager developers --users=jdoe
Group name: <meta charset="utf-8">developers
GID: <meta charset="utf-8">106380005
Membership managed by users: <meta charset="utf-8">jdoe
-------------------------
Number of members added 1
-------------------------
|
User jdoe
can now manage members of developers
.
Or add the group qa
as a member manager of developers
:
1
2
3
4
5
6
7
8
9
| $ ipa group-add-member-manager developers --groups=qa
Group name: developers
GID: 320800004
Membership managed by groups: qa
Membership managed by users: jdoe
-------------------------
Number of members added 1
-------------------------
|
Confirm
1
2
3
4
5
6
| $ ipa group-show developers
Group name: developers
GID: 320800004
Membership managed by groups: qa
Membership managed by users: jdoe
|
Group qa
will then be able to manage members of developers
.
Add add as a member of another group
To add group_b as a member of group_a:
1
| ipa group-add-member group_a --groups=group_b
|
Removing a member from a user group
First confirm that the group includes the member you want to remove.
Remove a member from a user group by using the ipa group-remove-member
command while specifying members to remove using these options:
--users
- removes a FreeIPA user--external
- removes a user that exists outside the FreeIPA domain, in the format of DOMAIN\user_name
or user_name@domain
--groups
- removes a user group
For example, to remove jmutai from a group called sysadmins:
1
2
3
4
5
6
7
| $ ipa group-remove-member qa --users=jdoe
Group name: qa
GID: 320800003
---------------------------
Number of members removed 1
---------------------------
|
Remove user1
, user2
, and group1
from a group called group_name
:
1
| ipa group-remove-member group_name --users=user1 --users=user2 --groups=group1
|
Removing users or groups as member managers from a user group
Command syntax:
1
| ipa group-remove-member-manager GROUP-NAME [options]
|
options to use:
-users=STR
- users to remove-groups=STR
- groups to remove
For example, to remove the user user1
as a member manager of group1
:
1
| ipa group-remove-member-manager group1 --users=user1
|
Remove the group sysadmins
as a member manager of developers
:
1
2
3
4
5
6
7
8
| $ ipa group-remove-member-manager developers --groups=qa
Group name: developers
GID: 320800004
Membership managed by users: jdoe
---------------------------
Number of members removed 1
---------------------------
|
The group and its member will not be able to manage developers group members after removal.
Add Existing local Users to FreeIPA Directory
Set the same password with the username on this example, but it is required to change at initial login
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| # extract local users who have 1000-9999 digit UID
# this is an example
#!/bin/bash
for line in `grep "x:[1-9][0-9][0-9][0-9]:" /etc/passwd`
do
USER=`echo $line | cut -d: -f1`
FIRST=`echo $line | cut -d: -f5 | awk {'print $1'}`
LAST=`echo $line | cut -d: -f5 | awk {'print $2'}`
[ ! "$FIRST" ] && FIRST=$USER
[ ! "$LAST" ] && LAST=$USER
echo $USER | ipa user-add $USER --first=$FIRST --last=$LAST --password
done
|