File: sql-update-20070724.sh

package info (click to toggle)
sogo 1.3.16-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 21,620 kB
  • sloc: objc: 99,218; python: 4,840; sh: 1,217; perl: 861; makefile: 132; sql: 53; php: 43; ansic: 4
file content (65 lines) | stat: -rwxr-xr-x 1,746 bytes parent folder | download | duplicates (10)
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/bin/bash

# this script only work with PostgreSQL, which at this time is the only
# database really supported by SOGo/SOPE

defaultusername=$USER
defaulthostname=localhost
defaultdatabase=$USER

read -p "Username ($defaultusername): " username
read -p "Hostname ($defaulthostname): " hostname
read -p "Database ($defaultdatabase): " database

if [ -z "$username" ]
then
  username=$defaultusername
fi
if [ -z "$hostname" ]
then
  hostname=$defaulthostname
fi
if [ -z "$database" ]
then
  database=$defaultdatabase
fi

echo ""
echo "You will now be requested your password thrice..."
echo "After that, a list of SQL operations will scroll."
echo ""

sqlscript=""

function renameFields() {
    oldIFS="$IFS"
    IFS=" "
    set $fields
    for field in $@
    do
	part="`echo -e \"ALTER TABLE $table RENAME $field TO c_${field};\\n\"`";
	sqlscript="$sqlscript$part"
    done
    IFS="$oldIFS"
}

table=sogo_user_profile
fields="uid defaults settings"
renameFields

fields="uid startdate enddate cycleenddate title cycleinfo participants isallday iscycle classification status priority isopaque location orgmail partmails partstates sequence component"
tables=`psql -U $username -h $hostname $database -c "select split_part(c_quick_location, '/', 5) from sogo_folder_info where c_folder_type ilike 'Appointment';" | grep _quick`
for table in $tables;
do
  renameFields
done

fields="givenname cn sn l mail o ou telephonenumber screenname"
tables=`psql -U $username -h $hostname $database -c "select split_part(c_quick_location, '/', 5) from sogo_folder_info where c_folder_type ilike 'Contact';" | grep _quick`
for table in $tables;
do
  renameFields
done

sqlscript="$sqlscript;"
echo "$sqlscript" | psql -e -U $username -h $hostname $database