Check for email only but not for group or login when adding repositories.

Check for Chili project.identifier for Git repos.
This commit is contained in:
Kolan Sh 2012-05-07 10:18:51 +04:00
parent 9d54ace1f8
commit 62a26bc087
2 changed files with 14 additions and 26 deletions

View File

@ -37,7 +37,8 @@ CHILI_ID_GITORIOUS_REPO=`mysql -h$MYSQL_HOSTNAME -u $MYSQL_USER -e \
AND $CHILI_MYSQL_DBNAME.member_roles.role_id=$CHILI_MYSQL_DBNAME.roles.id AND $CHILI_MYSQL_DBNAME.member_roles.role_id=$CHILI_MYSQL_DBNAME.roles.id
AND $CHILI_MYSQL_DBNAME.members.user_id=$CHILI_MYSQL_DBNAME.users.id AND $CHILI_MYSQL_DBNAME.members.user_id=$CHILI_MYSQL_DBNAME.users.id
AND $CHILI_MYSQL_DBNAME.members.project_id=$CHILI_MYSQL_DBNAME.projects.id AND $CHILI_MYSQL_DBNAME.members.project_id=$CHILI_MYSQL_DBNAME.projects.id
AND $CHILI_MYSQL_DBNAME.projects.name=$GITORIOUS_MYSQL_DBNAME.repositories.name AND ($CHILI_MYSQL_DBNAME.projects.name=$GITORIOUS_MYSQL_DBNAME.repositories.name
OR $CHILI_MYSQL_DBNAME.projects.identifier=$GITORIOUS_MYSQL_DBNAME.repositories.name)
AND $CHILI_MYSQL_DBNAME.users.type='User' AND $CHILI_MYSQL_DBNAME.users.type='User'
AND $CHILI_MYSQL_DBNAME.users.mail=$GITORIOUS_MYSQL_DBNAME.users.email AND $CHILI_MYSQL_DBNAME.users.mail=$GITORIOUS_MYSQL_DBNAME.users.email
AND $CHILI_MYSQL_DBNAME.roles.name IN ('Инициатор','Менеджер','Major','Manager') AND $CHILI_MYSQL_DBNAME.roles.name IN ('Инициатор','Менеджер','Major','Manager')

View File

@ -31,32 +31,26 @@ repos_to_remove=${repos_to_remove#,}
# === GET DATA FROM RHODECODE SQLITE BASE === # === GET DATA FROM RHODECODE SQLITE BASE ===
rh_repos_path=`sqlite3 $RHODECODE_SQLITE_PATH "select ui_value FROM rhodecode_ui where ui_section='paths'"` rh_repos_path=`sqlite3 $RHODECODE_SQLITE_PATH "select ui_value FROM rhodecode_ui where ui_section='paths'"`
SQLITE_RESULTS=`sqlite3 $RHODECODE_SQLITE_PATH "SELECT repo_name,repo_type,users.username,users.email,users_groups.users_group_name SQLITE_RESULTS=`sqlite3 $RHODECODE_SQLITE_PATH "SELECT repo_name,repo_type,users.email
FROM repositories,users,users_groups,users_groups_members FROM repositories,users
WHERE repositories.user_id=users.user_id WHERE repositories.user_id=users.user_id;"`
AND users.user_id=users_groups_members.user_id
AND users_groups.users_group_id=users_groups_members.users_group_id;"`
# initializing repos arrays and count them # initializing repos arrays and count them
repos_names= repos_names=
repos_paths= repos_paths=
repos_types= repos_types=
repos_users=
repos_mails= repos_mails=
repos_groups=
let nrepos=0 let nrepos=0
for r in $SQLITE_RESULTS; do for r in $SQLITE_RESULTS; do
repos_paths[$nrepos]=$rh_repos_path/${r%|*|*|*|*} repos_paths[$nrepos]=$rh_repos_path/${r%|*|*}
tmp=${repos_paths[$nrepos]%/}; repos_names[$nrepos]=${tmp##*/} tmp=${repos_paths[$nrepos]%/}; repos_names[$nrepos]=${tmp##*/}
tmp=${r%|*|*|*}; repos_types[$nrepos]=${tmp#*|} tmp=${r%|*}; repos_types[$nrepos]=${tmp#*|}
case ${repos_types[$nrepos]} in case ${repos_types[$nrepos]} in
hg) repos_types[$nrepos]='Mercurial';; hg) repos_types[$nrepos]='Mercurial';;
git) repos_types[$nrepos]='Git';; git) repos_types[$nrepos]='Git';;
esac esac
tmp=${r%|*|*}; repos_users[$nrepos]=${tmp#*|*|} repos_mails[$nrepos]=${tmp#*|*|}
tmp=${r%|*}; repos_mails[$nrepos]=${tmp#*|*|*|}
repos_groups[$nrepos]=${r#*|*|*|*|}
let nrepos++ let nrepos++
done done
@ -71,17 +65,10 @@ for i in `seq 0 $((nrepos-1))`; do
[ "$ALREADY_EXIST" != "" ] && continue [ "$ALREADY_EXIST" != "" ] && continue
USERID=`mysql -h$CHILI_MYSQL_HOSTNAME -u $CHILI_MYSQL_USER -e "SELECT id USERID=`mysql -h$CHILI_MYSQL_HOSTNAME -u $CHILI_MYSQL_USER -e "SELECT id
FROM $CHILI_MYSQL_DBNAME.users,$CHILI_MYSQL_DBNAME.groups_users
WHERE users.id=groups_users.user_id
AND users.status='1'
AND users.login='${repos_users[$i]}'
AND users.mail='${repos_mails[$i]}'
AND users.type='User'
AND groups_users.group_id=(SELECT id
FROM $CHILI_MYSQL_DBNAME.users FROM $CHILI_MYSQL_DBNAME.users
WHERE users.type='Group' WHERE users.status='1'
AND users.lastname='${repos_groups[$i]}' AND users.mail='${repos_mails[$i]}'
AND users.status='1')" \ AND users.type='User'" \
| grep -v tables_col|xargs|sed "s/ /\n/g"|tail -n+2` | grep -v tables_col|xargs|sed "s/ /\n/g"|tail -n+2`
[ "$USERID" == "" ] && continue [ "$USERID" == "" ] && continue