Project

General

Profile

Gui progress » History » Version 160

Adrian Georgescu, 07/23/2009 08:36 PM

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2
3 159 Adrian Georgescu
4 74 Adrian Georgescu
= Audio sessions =
5 1 Adrian Georgescu
6 115 Adrian Georgescu
 1. ~~ Incoming sessions do not display '''session information''' and the control buttons are missing~~
7 156 Adrian Georgescu
  1. Not getting a SessionDidStart notification from middleware on incoming sessions.  (on some 3rd party clients/service) 
8 147 Adrian Georgescu
    > Hm, I can see the notifications (Adrian)
9 115 Adrian Georgescu
 1. ~~ When '''rejecting a session''' it creates an entry in the drawer~~
10 1 Adrian Georgescu
 1. '''Cancel''' is not handled for incoming sessions, the pop-up remains active 
11 115 Adrian Georgescu
 1. ~~'''Maximize drawer''' when it opens the first time, it seem to open only 80% now ~~
12 146 Adrian Georgescu
 1. ~~Play '''ringtones'''~~
13
 1. ~~Playback DTMF tones~~
14 115 Adrian Georgescu
 1. ~~ A terminated session must '''disappear from the drawer''' automatically after 5 seconds ~~
15
 1. ~~ Remaining sessions must '''shuffle to the top''' when a session ends~~
16
 1. ~~ Toggle hold does not change hold '''button color''' ~~
17
 1. ~~ Update session audio information with '''Hold by remote''' when held by remote party ~~
18
 1. ~~ Only one audio session can be '''active at a time''', all other existing audio sessions must be put on hold~~
19 1 Adrian Georgescu
 1. ~~ Highlight the '''active session''' with a bold border, click on a session to select it as the active session~~
20 140 Adrian Georgescu
 1. ~~ When the active session is selected, what is typed on the keyboard must be transmitted as '''DTMF tones'''~~
21 115 Adrian Georgescu
 1. ~~ When a call is connected move keyboard focus to it ~~
22
 1. ~~ When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck  ~~
23
 1. ~~ Add an item '''Show audio sessions''' to the '''Session menu''' to show the drawer, if it was closed  (activated the View -> Toggle Sessions Drawer) ~~
24
 1. ~~ '''Scroll bar''' appears as result of multiple sessions, but it does not disappear when the number of session decreases~~
25 1 Adrian Georgescu
 1. ~~ '''Hangup All''' is not implemented~~
26 146 Adrian Georgescu
 1. ~~Display icon with lock when sRTP is active~~
27 147 Adrian Georgescu
 1. ~~ Disable Hangup All button if no session is active~~
28
 1. ~~ Disable Conference button if less than two sessions active~~
29 156 Adrian Georgescu
 1. ~~Allow the session end button for incoming sessions, which have not yet been established  (waiting for the ACK message) ~~
30 154 Adrian Georgescu
 1. Mute input to conference bridge from the sound card slot when pressing mute button (Luci will add a mute() function for it)
31 160 Adrian Georgescu
 1. Call set_audio_devices() when changing the audio device or tail_length in global Preferences
32 150 Adrian Georgescu
 1. DNS lookup failure for STUN servers is not a critical error
33 160 Adrian Georgescu
 1. Set SIP User Agent name to blink-<version>
34 159 Adrian Georgescu
 
35 123 Adrian Georgescu
36 131 Adrian Georgescu
= Chat sessions =
37
38 156 Adrian Georgescu
 1. ~~Add a '''+''' button (to add contact) in the toolbar~~
39
 1. ~~Display the full From and To headers~~
40 158 Adrian Georgescu
 1. Use secondary ring tone on output_device  when incoming session with chat media only
41 148 Adrian Georgescu
 1. When close the window or click on close button call session.end() if the session has no other stream or session.remove_stream() otherwise
42
 1. '''Throttle playback''' of audible notifications to maximum one every 3 seconds 
43 1 Adrian Georgescu
 1. ~~ Display timestamp in HH:MM:ss format to the right side of the window, same lin as From/To header ~~ 
44
 1. Display the number of '''un-read messages''' in non-visible tabs in a red circle over the tab name
45 148 Adrian Georgescu
 1. Bug: Cannot get rid of existing tabs, they keep growing
46
 1. Bug: opening and closing chat windows bring up different number of former chat tabs back
47 135 Adrian Georgescu
 1. Add a status bar below recipient tab and display connection progress and information in the status bar
48 1 Adrian Georgescu
 1. Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''
49 131 Adrian Georgescu
 1. Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings
50
 1. Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings
51 148 Adrian Georgescu
 1. Add '''File transfer''' button on toolbar
52
 1. Add '''History''' button on toolbar
53
 1. Add a '''history drawer''' and list the days in the drawer
54 145 Adrian Georgescu
 1. When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
55 131 Adrian Georgescu
 1. When start typing send a message with '''is-composing''' payload. This requires implementing the is-composing payload parser, see http://sipsimpleclient.com/ticket/40. If user has deleted the typed text before sending it update is-composing. 
56 157 Adrian Georgescu
 1. Right click on the history area bring a Reload button. If selecting it the screen goes blank. We need to define proper action like Copy text selection or copy all window content 
57
58 131 Adrian Georgescu
59 1 Adrian Georgescu
= Main interface =
60
61 160 Adrian Georgescu
 1. At least one account must be active, use the bonjour acocunt if no accounts are defined 
62
 1. The list of account is built based the active account and not based on Register status 
63 152 Adrian Georgescu
 1. When selecting a different account, mark it as '''default''' using the settings api
64 131 Adrian Georgescu
 1. Bonjour account does not show up in account list
65 1 Adrian Georgescu
 1. ~~'''Remove account''' from list when is disabled in preferences  ~~
66 131 Adrian Georgescu
 1. On startup, '''select the default account''' in the account list
67
 1. Add a '''minimize button''' to collapse the buddy list
68
 1. Hide the Add button + sign when the interface is collapsed
69 148 Adrian Georgescu
 1. If red Close button is pressed, the main window disappears and is no option to bring it back
70 160 Adrian Georgescu
 1. ~~No dock icon available~~
71 152 Adrian Georgescu
72 32 Adrian Georgescu
73 128 Adrian Georgescu
= History sessions =
74 120 Adrian Georgescu
75 1 Adrian Georgescu
 1. Use the same session drawer to display previous sessions
76
 1. Keep same layout as active session with the following changes:
77
   1. Instead of audio session information display the negotiated streams (Audio|Chat|Audio+Chat etc...)
78 84 Adrian Georgescu
   1. Instead of duration display '''YYYY-MM-DD HH:MM  Duration: HH:MM:SS''' 
79 56 Adrian Georgescu
   1. Add a button to call back in place of current session buttons
80 1 Adrian Georgescu
 1. Add a Session menu item to toggle the drawer content between active session and history sessions
81
 1. Show most recent sessions on top
82 132 Adrian Georgescu
83
= Contacts =
84
85 137 Adrian Georgescu
 1. When add contact without domain part always append curent domain
86 132 Adrian Georgescu
 1. Type a new group in add contact: (NameError: global name 'ContactsGroup' is not defined)
87
 1. '''Delete the contact''' when pressing delete
88
 1. After dialing a found contact, display back the buddy list
89 144 Adrian Georgescu
 1. Show search results from the system address book
90 132 Adrian Georgescu
 1. Edit Group names
91
 1. Add right click for contact:
92
  1. Start audio session
93
  1. Start chat session
94
  1. Transfer file
95
  1. Offer local desktop
96
  1. Request remote desktop
97
  1. Edit contact
98
  1. Delete contact
99 1 Adrian Georgescu
100 48 Adrian Georgescu
= Conferencing =
101 1 Adrian Georgescu
102
Only one conference is possible to make the interface easy to use.
103 144 Adrian Georgescu
104 84 Adrian Georgescu
To start a conference:
105 1 Adrian Georgescu
106
 1. Send a re-INVITE to a) take each call off hold and b) set the is-focus attribute of the Contact header
107 125 Adrian Georgescu
 1. Set the conference bridge to mix audio between all parties
108 59 Adrian Georgescu
 1. Disable the hold buttons, they do not operate while in conference
109
 1. Draw the selection rectangle around the sessions part of the conference
110 1 Adrian Georgescu
111 63 Adrian Georgescu
To stop a conference
112 6 Adrian Georgescu
113 111 Adrian Georgescu
 1. Send a re-INVITE to a) take each call an leave only one off hold and b) disable is-focus attribute of the Contact header
114
 1. Set the conference bridge to stop mixing audio
115 121 Adrian Georgescu
 1. Enable the hold buttons
116
 1. Draw the selection rectangle around the selected session
117
118
New sessions while in a conference
119
120
 1. New sessions are added bellow the conference
121 1 Adrian Georgescu
 1. A session can be dragged in and out of the conference
122 121 Adrian Georgescu
 1. When switching from a conference to another single session, do not use hold
123
124 41 Adrian Georgescu
= Preferences =
125 122 Adrian Georgescu
126 42 Adrian Georgescu
 1. Make all text input fields equal in size
127 160 Adrian Georgescu
 1. Delete hr above Advanced text
128 151 Adrian Georgescu
 1. Do not allow deselection of all codecs, at least one codec must be enabled
129 42 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
130
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
131
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
132
 1. '''general.sip.transports''' cannot be saved
133
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
134
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
135
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
136 41 Adrian Georgescu
 1. When '''disable account''' in preferences, it does not get removed from the main interface account lists
137
 1. Properly '''align''' horizontally the Advanced settings
138
 1. Display text to the '''left of the checkbox''' instead of the right
139
 1. '''Delete account Enabled checkbox''', leave only the checkbox in the account list
140
 1. '''De-register''' the account and remove it from the account list in main interface when disable the account
141 149 Adrian Georgescu
 1. When '''enable an account''', select it in the main interface account list
142 1 Adrian Georgescu
 1. ~~ Display the '''bonjour account''' always at the end of the list ~~
143 151 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property.  There is no SIP address or password associated with it
144 154 Adrian Georgescu
 1. Cannot '''delete Bonjour''' account: (TypeError: cannot delete BonjourAccount instance with default id). Do  not allow the user to attempt to delete it (hide the minus button). Bonjour can only be enabled/disabled but not deleted.
145 41 Adrian Georgescu
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
146
 1. '''general.message_received_sound''' does not fit in window
147 96 Adrian Georgescu
 1. Allow ordering of accounts in the account list
148 118 Adrian Georgescu
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
149
 1. Check if the wav file is in the right format before saving the settings related to ringtones
150 29 Adrian Georgescu
 1. Check if the TLS options set by the user are valid before saving them (by loading them outside the engine using gnutls library)
151
152 41 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
153 1 Adrian Georgescu
154 116 Adrian Georgescu
= Engine =
155 122 Adrian Georgescu
156 41 Adrian Georgescu
 1. If '''engine is dead''', the message  '''no sip account is active''' is displayed but is unclear what the real reason is. An engine stop must be logged to general debug window. Not clear how to restart the engine, maybe we should restart the application until a good solution is found
157 29 Adrian Georgescu
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
158
159
{{{
160
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
161
}}}
162
163
By setting the wrong TLS certificate files, the middleware does not start anymore:
164
165
{{{
166
[Session started at 2009-07-19 10:37:39 +0200.]
167
Traceback (most recent call last):
168
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
169
   in applicationDidFinishLaunching_
170
    self.backend.init(options)
171
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
172
    self._app.start(config_backend=config_be)
173
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
174
    trace_sip=settings.logging.trace_sip,
175 41 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
176 29 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
177
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
178
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
179
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
180
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
181 1 Adrian Georgescu
None
182 34 Adrian Georgescu
}}}
183 1 Adrian Georgescu
184 155 Adrian Georgescu
= Menu structure =
185
186
 1. File
187
 1. Edit
188
 1. View
189
 1. Audio
190
  1. Output device
191
  1. Input device
192
  1. Alert device
193
  1. Mute
194
 1. Presence
195
  1. Activity
196
   1. Available
197
   1. Phone call
198
   1. Meeting
199
   1. Lunch
200
   1. Dinner
201
   1. Do not disturb
202
   1. Travel
203
   1. Offline
204
   1. Holiday
205
 1. Contacts
206
  1. Add contact
207
  1. Delete contact
208
  1. Edit contact
209
  1. Add group
210
  1. Delete group
211
  1. Edit group
212
 1. Sessions
213
  1. New session ...
214
215 1 Adrian Georgescu
= Presence bar =
216
217
Make it as high as the contacts (two rows high).
218 142 Adrian Georgescu
219
 1. ~~ Show '''own photo''' to the left ~~
220 1 Adrian Georgescu
 1. Acquire photo from webcam and cache it
221
 1. Show '''Display name''' next to the photo on top row
222 142 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
223 1 Adrian Georgescu
 1. Show '''Presence activity''' next to name on top row. Activities:
224
   1. Available
225 142 Adrian Georgescu
   1. Phone call
226
   1. Meeting
227
   1. Lunch
228
   1. Dinner
229
   1. Do not disturb
230
   1. Travel
231
   1. Offline
232
   1. Holiday
233 148 Adrian Georgescu
234
Add a Presence menu item before Session.
235 7 Adrian Georgescu
236 1 Adrian Georgescu
= Debug window =
237 7 Adrian Georgescu
238 41 Adrian Georgescu
 1. Display all traces in a '''debug window''' with tabs for each debug type
239
 1. Add a '''General messages''' window to the Debug menu, first item
240 1 Adrian Georgescu
241
= GUI settings =
242
243
Remember the following settings between restarts:
244 79 Adrian Georgescu
245 41 Adrian Georgescu
 1. '''Debug window''' and the selected tab
246
 1. Status of '''contact groups''' - colapsed/expanded and their order
247
 1. SIP '''accounts order''' list
248 100 Adrian Georgescu
249 14 Adrian Georgescu
= Middleware =
250 47 Adrian Georgescu
251 102 Adrian Georgescu
 1. On startup, check if the audio device from the preferences '''is available''' in the detected devices list. If not, set the device to the system default device and display a warning to the user to set the devices in the preferences
252
 1. Check the validity of the '''TLS''' settings/files before starting the engine
253
 1. It seems that the '''stun servers''' are learned from the DNS and cannot be overwritten in settings, they show up automatically
254
 1. If I set the relay to abcd.com standard '''port 2855''' must be used, now is set to zero: relay = abcd.com:0;transport=tls
255 41 Adrian Georgescu
 1. Append '''dummy''' to the lists of available audio devices
256
 1. We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
257
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
258 1 Adrian Georgescu
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
259
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
260
 1. Delete '''general.audio.playback_dtmf''' setting
261
 1. Add '''general.audio.mute''' setting
262
 1. Delete '''account.audio''' section
263 66 Adrian Georgescu
 1. Add '''account.sip''' section
264
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
265
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
266
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
267
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
268
 1. Delete '''account.ice.use_stun''', it is always true
269 68 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
270 109 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
271
 1. Delete global.chat.accept_types
272 1 Adrian Georgescu
 1. Delete global.chat.accept_wrapped_types
273 159 Adrian Georgescu
274
= General =
275
276
Random crashes during functioning always end up in debugger at:
277
278
{{{
279
[Switching to process 59222 thread 0x9b73]
280
(gdb) bt
281
#0  0x937691c6 in mach_msg_trap ()
282
#1  0x937709bc in mach_msg ()
283
#2  0x9351104e in CFRunLoopRunSpecific ()
284
#3  0x93511c78 in CFRunLoopRunInMode ()
285
#4  0x9411128c in RunCurrentEventLoopInMode ()
286
#5  0x941110a5 in ReceiveNextEventCommon ()
287
#6  0x94110f19 in BlockUntilNextEventMatchingListInMode ()
288
#7  0x96863d0d in _DPSNextEvent ()
289
#8  0x968635c0 in -[NSApplication nextEventMatchingMask:untilDate:inMode:dequeue:] ()
290
#9  0x9685c5fb in -[NSApplication run] ()
291
#10 0x00233855 in ffi_call_SYSV ()
292
#11 0x00233d6c in ffi_call ()
293
#12 0x0024a825 in PyObjCFFI_Caller ()
294
#13 0x00261b63 in PyObjCSelector_GetMetadata ()
295
#14 0x00121505 in PyObject_Call ()
296
#15 0x0018f832 in PyEval_EvalFrameEx ()
297
#16 0x00191173 in PyEval_EvalCodeEx ()
298
#17 0x0018f79d in PyEval_EvalFrameEx ()
299
#18 0x00191173 in PyEval_EvalCodeEx ()
300
#19 0x00191260 in PyEval_EvalCode ()
301
#20 0x001a883c in PyErr_Display ()
302
#21 0x001a8e66 in PyRun_FileExFlags ()
303
#22 0x001aa7d2 in PyRun_SimpleFileExFlags ()
304
#23 0x00001d4e in main (argc=1, argv=0xbfffeef4) at /Users/adigeo/work/blink/main.m:33
305
kill
306
}}}