mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-03 20:49:08 +01:00
cace666818
- if both numeric ids are identical, dont try to change them
50 lines
1.5 KiB
Bash
Executable File
50 lines
1.5 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Usage: ./ad-migration.sh < user.csv | bash
|
|
#
|
|
# STDIN is csv with: <account_lid>,<account_id>,<AD-user>,<SID>,<RID>
|
|
#
|
|
# <account_id> has to be negative number for groups (eg. -123 for account_id=123)!
|
|
#
|
|
# Following command should be used as startpoint for the list:
|
|
# mysql -B -e "select account_lid,CASE account_type WHEN 'u' THEN account_id ELSE -account_id END,account_lid FROM egw_accounts ORDER BY account_type!='u',account_lid" egroupware | sed 's/ /,/g'
|
|
# Change <AD-user> if not equal to <account_lid> and append ,,<RID> to each line.
|
|
#
|
|
# If migration to LDAP instead of AD use uidNumber (gidNumber for groups) as <RID>.
|
|
# <SID> is NOT used and can be empty.
|
|
#
|
|
# Change following 2 lines to an EGroupware user with admin rights and his password
|
|
#
|
|
ADMIN=sysop
|
|
PASSWD=PW
|
|
|
|
CHANGE=
|
|
while IFS=, read account_lid account_id ad_user SID RID rest
|
|
do
|
|
# if we have no RID but a SID, calculate the RID
|
|
[ -z "$RID" -a -n "$SID" ] && RID=${SID##*-}
|
|
|
|
if [ -n "$account_id" -a -n "$RID" ]
|
|
then
|
|
[ -z "$account_lid" -o -z "$ad_user" -o "$account_lid" = "$ad_user" ] && {
|
|
echo -n "#"
|
|
}
|
|
if [ $account_id -gt 0 ]
|
|
then
|
|
echo "admin/admin-cli.php --edit-user '$ADMIN,$PASSWD,$account_lid=$ad_user'"
|
|
else
|
|
echo "admin/admin-cli.php --edit-group '$ADMIN,$PASSWD,$account_lid=$ad_user'"
|
|
RID=-$RID
|
|
fi
|
|
|
|
# if no change necessary, dont
|
|
if [ $account_id != $RID ]
|
|
then
|
|
[ -n "$CHANGE" ] && CHANGE=$CHANGE,
|
|
CHANGE=$CHANGE$account_id,$RID
|
|
fi
|
|
fi
|
|
done
|
|
|
|
echo "admin/admin-cli.php --change-account-id '$ADMIN,$PASSWD,$CHANGE'"
|