summaryrefslogtreecommitdiffstats
path: root/blueman_open
blob: 50f05c3acd86f223fc005b549fca37ba51d557b3 (plain)
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#!/bin/sh

DEBUG=${DEBUG:-""}

phone_addr=$1
own_name=$(basename $0)
dir=$(mktemp -d)/$phone_addr
browser=${browser:-"xdg-open"}

# Check for kdialog

if which kdialog 1>/dev/null 2>/dev/null; then
    messagetype="kdialog"
else
    messagetype="gtkdialog"
fi

# Abstract some stuff for gtkdialog
gtkbox_passive() {
  export messagebox='
    <vbox>
    <frame Blueman Open Device.>
      <text>
	<label>"'$(printf $1)'"</label>
      </text>
    </frame>
    </vbox>
    '
}
gtkbox_interactive() {
  export messagebox='
    <vbox>
    <frame Blueman Open Device.>
      <text>
	<label>"'$(printf $1)'"</label>
      </text>
      <hbox>
	<button ok></button>
      </hbox>
    </frame>
    </vbox>
    '
}
gtkmessage() {
	I=$IFS; IFS=""
	for STATEMENT in $(gtkdialog --center --program=messagebox); do
		eval $STATEMENT
	done
	IFS=$I
}
# End gtkdialog abstraction

# mount function
mount_phone ()
{
  i=0
  LIMIT=5
  while [ $i -lt $LIMIT ]
  do
    printf "$i "
    [ ! -z $DEBUG ] && logger -i -t $own_name "Perform $i try to mount phone $phone_addr to $dir using obexfs"
    [ ! -z $DEBUG ] && logger -i -t $own_name "Execute: obexfs -b $phone_addr -B 10 $dir"
    out=$(obexfs -b $phone_addr $dir 2>&1)
    [ ! -z $DEBUG ] && logger -i -t $own_name "$out"
    mounts=$(grep $dir /proc/mounts | wc -l)
    [ ! -z $DEBUG ] && logger -i -t $own_name "Found $mounts mounted $dir inside /proc/mounts"
    
    if [ $mounts -ne 0 ] ;then
      progress=99
      MSG_TXT="Successfully mounted $phone_addr to $dir"
      if [ $messagetype == "kdialog" ]; then
	kdialog --passivepopup "$MSG_TXT" 2
      elif [ $messagetype == "gtkdialog" ]; then
	gtkbox_interactive $"$MSG_TXT"
	gtkmessage
      fi
      [ ! -z $DEBUG ] && logger -i -t $own_name "Open $dir with $browser"
      out=$($browser $dir 2>&1)
      [ ! -z $DEBUG ] && logger -i -t $own_name "$out"
      exit 0
    else
      logger -i -t $own_name "Failed to mount $phone_addr to $dir from try $i "
    fi
    sleep 1
    ((i += 1))
  done
  if [ $mounts -eq 0 ] ;then
    MSG_TXT="Failed to mount $phone_addr to $dir.\nCheck /var/log/messages for errors."
    if [ $messagetype == "kdialog" ]; then
      kdialog --passivepopup "$MSG_TXT" 4
    elif [ $messagetype == "gtkdialog" ]; then
      gtkbox_interactive $"$MSG_TXT"
      gtkmessage
    fi
    killall gtkdialog
  fi
}

# unmount function
umount_phone ()
{
  mounts=$(grep $dir /proc/mounts | wc -l)
  if [ $mounts -ne 0 ] ;then
    [ ! -z $DEBUG ] && logger -i -t $own_name "Perform umount of $dir if it's already mounted."
    out=$(fusermount -uz $dir 2>&1)
    [ ! -z $DEBUG ] && logger -i -t $own_name "$out"
    mounts=$(cat /proc/mounts |grep $dir|wc -l)
      if [ $mounts -eq 0 ] ;then
        [ ! -z $DEBUG ] && logger -i -t $own_name "Successfully unmounted $dir."
      else
        logger -i -t $own_name "$dir is already mounted.  Failed to umount $dir.$out.  Please perform its umount manually."
        MSG_TXT="Failed to umount $dir - check /var/log/messages for errors"
	if [ $messagetype == "kdialog" ]; then
	  kdialog --passivepopup "$MSG_TXT" 4
	elif [ $messagetype == "gtkdialog" ]; then
	  gtkbox_interactive $"$MSG_TXT"
	  gtkmessage
	fi
        exit
      fi
  else
    [ ! -z $DEBUG ] && logger -i -t $own_name "$dir is not mounted - no need to perform umount..."
  fi
}

# mkdir function
create_dir ()
{
  progress=1
  [ ! -z $DEBUG ] && logger -i -t $own_name "Create directory $dir to mount the phone by bluetooth..."
  out=$(mkdir -p $dir 2>&1)
  [ ! -z $DEBUG ] && logger -i -t $own_name "$out"
}

MSG_TXT="Mount phone is in progress... Please wait..."
if [ $messagetype == "kdialog" ]; then
  kdialog --passivepopup "$MSG_TXT" 4
elif [ $messagetype == "gtkdialog" ]; then
  gtkbox_passive $"$MSG_TXT"
  gtkmessage&
fi

create_dir
umount_phone
mount_phone