Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions news/69.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Support export/import of user `login_name` @ewohnlich
5 changes: 5 additions & 0 deletions src/plone/exportimport/utils/principals/members.py
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ def export_members() -> List[dict]:
user_data = _get_base_user_data(member)
# Password
user_data["password"] = _get_user_password(member)
user_data["login_name"] = member.getUserName()
# Properties
user_data.update(_get_user_properties(member, fields))
data.append(user_data)
Expand All @@ -111,6 +112,7 @@ def import_members(data: List[dict]) -> MemberData:
"""Import member information from the provided list of dictionaries."""
members = []
pr = api.portal.get_tool("portal_registration")
pas = api.portal.get_tool("acl_users")
with _run_as_manager(pr):
for item in data:
username = item["username"]
Expand All @@ -124,13 +126,16 @@ def import_members(data: List[dict]) -> MemberData:
password = item.pop("password")
roles = item.pop("roles", [])
groups = item.pop("groups", [])
login_name = item.pop("login_name", None)
try:
pr.addMember(username, password, roles, [], item)
except ValueError:
logger.info(f"ValueError {username} : {item}")
continue
else:
user = api.user.get(username=username)
if login_name:
pas.updateLoginName(username, login_name)
for groupname in groups:
try:
api.group.add_user(groupname=groupname, user=user)
Expand Down