Project

General

Profile

Gui progress » History » Version 257

Adrian Georgescu, 07/30/2009 11:24 AM

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2
3 74 Adrian Georgescu
= Audio sessions =
4 1 Adrian Georgescu
5 257 Adrian Georgescu
 1. Set SIP User Agent name on start to '''blink-<version>'''
6 195 Adrian Georgescu
 1. '''Mute''' microphone when pressing mute button
7 230 Adrian Georgescu
 1. Add  a '''record button''' left to Hold button. When pressed toggle recording the audio session
8 235 Adrian Georgescu
 1. Display RTP '''packet loss''' with red above the session buttons when > 0.5 %, sample every 10 seconds
9 222 Adrian Georgescu
 1. Display '''Ringing...''' when get ringing indication from remote party
10 231 Adrian Georgescu
 1. Closing many active sessions cause many tones to be played back. Throttle tones playback
11 195 Adrian Georgescu
 1. Call '''set_audio_devices()''' when changing the audio device or tail_length in global Preferences
12 236 Adrian Georgescu
 1. Calls made with bonjour account that do not resolve in DNS do not end, try dial abcd
13 256 Adrian Georgescu
 1. Add a '''triangle button''' to expand vertically the audio session frame with extra lines with more audio session information:
14
    * Local RTP: 130.129.86.171:64369
15
    * Remote RTP: 81.23.228.129:58228
16
    * Remote UA: Asterisk PBX 
17
    * Packet loss=0.0% (must be updated every 5 seconds) 
18
    * Jitter RX/TX=0/21 ms (must be updated every 5 seconds)
19 193 Adrian Georgescu
 1. ~~Play '''ringtones'''~~ 
20 248 Adrian Georgescu
 1. ~~'''Cancel''' is not handled for incoming sessions, the pop-up remains active~~
21
  1. ~~With every new incoming session the window shrinks in size~~
22
  1. ~~After the second call is canceled the window does not auto close anymore and one previous canceled call remains on top~~
23 179 Adrian Georgescu
 1. ~~ Incoming sessions do not display '''session information''' and the control buttons are missing~~
24
 1. ~~ When '''rejecting a session''' it creates an entry in the drawer~~
25 178 Adrian Georgescu
 1. ~~'''Maximize drawer''' when it opens the first time, it seem to open only 80% now ~~
26 146 Adrian Georgescu
 1. ~~Playback DTMF tones~~
27 115 Adrian Georgescu
 1. ~~ A terminated session must '''disappear from the drawer''' automatically after 5 seconds ~~
28
 1. ~~ Remaining sessions must '''shuffle to the top''' when a session ends~~
29
 1. ~~ Toggle hold does not change hold '''button color''' ~~
30
 1. ~~ Update session audio information with '''Hold by remote''' when held by remote party ~~
31
 1. ~~ Only one audio session can be '''active at a time''', all other existing audio sessions must be put on hold~~
32 1 Adrian Georgescu
 1. ~~ Highlight the '''active session''' with a bold border, click on a session to select it as the active session~~
33 140 Adrian Georgescu
 1. ~~ When the active session is selected, what is typed on the keyboard must be transmitted as '''DTMF tones'''~~
34 115 Adrian Georgescu
 1. ~~ When a call is connected move keyboard focus to it ~~
35
 1. ~~ When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck  ~~
36
 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) ~~
37 147 Adrian Georgescu
 1. ~~ '''Scroll bar''' appears as result of multiple sessions, but it does not disappear when the number of session decreases~~
38
 1. ~~ '''Hangup All''' is not implemented~~
39 156 Adrian Georgescu
 1. ~~Display icon with lock when sRTP is active~~
40 161 Adrian Georgescu
 1. ~~ Disable Hangup All button if no session is active~~
41 150 Adrian Georgescu
 1. ~~ Disable Conference button if less than two sessions active~~
42 160 Adrian Georgescu
 1. ~~Allow the session end button for incoming sessions, which have not yet been established  (waiting for the ACK message) ~~
43 1 Adrian Georgescu
44
= Chat sessions =
45 224 Adrian Georgescu
46 252 Adrian Georgescu
 1. When using a relay during stream initialization print system message: '''MSRP session reserved at relay host:port'''
47
 1. Use the '''same look and feel''' for the toolbar buttons as the main interface (greyish buttons) 
48 255 Adrian Georgescu
 1. When click on the Audio button, use add_stream to append audio to existing session
49
 1. If an audio stream exists part of the session add the audio control buttons '''Record|Hold|Terminate'''
50 1 Adrian Georgescu
 1. Display the number of '''un-read messages''' in non-active tabs within a red circle over the tab name
51 253 Adrian Georgescu
 1. To close a tab add a '''small x button''' to it
52 252 Adrian Georgescu
 1. When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
53 255 Adrian Georgescu
 1. Display '''is-composing''' payload. Implement the is-composing payload parser in middleware, see http://sipsimpleclient.com/ticket/40
54 252 Adrian Georgescu
 1. Display is-composing information received from the other end
55
 1. '''Auto-accept''' chat only sessions when caller is in the contacts list  (tricky because of aliases). Use the SIP URI user@domain from the From header of the INVITE to match the contact
56 245 Adrian Georgescu
 1. ~~Rename '''Close chat''' button to '''Close'''~~
57 244 Adrian Georgescu
 1. ~~Rename Call button text with '''Audio'''~~
58 246 Adrian Georgescu
 1. ~~If not connected, change Close button to '''Connect'''~~ better keep Connect and Close separate
59 247 Adrian Georgescu
 1. ~~When connecting, grey the action button and display '''Connecting''' until the session is in either connected or terminated state~~
60
 1. ~~ Add timestamp for system messages~~
61
 1. ~~When connected print system message: '''MSRP chat session established to MSRP_URI'''~~
62
 1. ~~When disconnected print system message: '''MSRP chat session terminated (reason)'''~~
63 224 Adrian Georgescu
 1. ~~When pressing the IM button in the main interface just '''open the chat window''' and display the last conversation from history, do not start a session automatically~~
64 1 Adrian Georgescu
 1. ~~Start session when user '''starts typing''' or by pressing the Connect button~~
65 253 Adrian Georgescu
 1. ~~Do not close the chat tab/window after the session ends~~
66 228 Adrian Georgescu
 1. ~~Read history directory from '''global.chat.history_directory''' setting~~
67 1 Adrian Georgescu
 1. ~~Remove confirmation window with: "There is an active chat session, would you like to terminate and close it?"~~ ''(left confirmation for more than 1 sessions)''
68
 1. ~~Do not play an '''audible tone when terminating''' a chat session, the stop tone is for audio session only~~
69 243 Adrian Georgescu
 1. ~~Display session information inline with a different border color~~
70
 1. ~~CPIM parser cannot pase Display names equal to one space~~
71 164 Adrian Georgescu
 1. ~~Add a '''+''' button (to add contact) in the toolbar~~
72 174 Adrian Georgescu
 1. ~~Display the full From and To headers~~
73 135 Adrian Georgescu
 1. ~~Use secondary ring tone on output_device  when incoming session with chat media only~~
74 164 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~~
75
 1. ~~When click on close, close the tab or the whole window if no tab left~~
76 1 Adrian Georgescu
 1. ~~'''Throttle playback''' of audible notifications to maximum one every 3 seconds ~~
77 180 Adrian Georgescu
 1. ~~ Display timestamp in HH:MM:ss format to the right side of the window, same lin as From/To header ~~ 
78
 1. ~~Bug: Cannot get rid of existing tabs, they keep growing~~
79
 1. ~~Bug: opening and closing chat windows bring up different number of former chat tabs back~~
80 1 Adrian Georgescu
 1. ~~Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''~~
81 131 Adrian Georgescu
 1. ~~Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings~~
82 157 Adrian Georgescu
 1. ~~Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings~~
83 174 Adrian Georgescu
 1. ~~Add '''File transfer''' button on toolbar~~
84 218 Adrian Georgescu
 1. ~~Add '''History''' button on toolbar~~
85 217 Adrian Georgescu
 
86
= Multi-party chat =
87
88
 1.  How to display participants in a multy-party  (drawer?)
89
 1. Starting a chat to a multiparty server must prompt the user for the Nickname to use for the session. Add a a new dialog window for such sessions:
90
  1. Room: use last used room
91 131 Adrian Georgescu
  1. Server: default to '''account.chat.server'''
92 1 Adrian Georgescu
  1. Nickname
93 167 Adrian Georgescu
94 216 Adrian Georgescu
= Main interface =
95
96 254 Adrian Georgescu
 1. Highlight mute button content with red when pressed
97 249 Adrian Georgescu
 1. ~~Use '''green + title button''' to collapse/expand the buddy list~~
98
 1. ~~Hide + (add contact) button when the interface is collapsed~~
99
 1. ~~Add a status bar on the bottom of the window ~~
100 237 Adrian Georgescu
 1. ~~Display the NAT type on the status bar~~
101 249 Adrian Georgescu
 1. ~~'''Bonjour account''' does not appear when deactivate/activate in preferences~~
102
 1. ~~An account marked  as active appears immediately in the account list. If registration for the account is active, display text with grey if not registered yet and black if registered~~ 
103 167 Adrian Georgescu
 1. ~~At least one account must be active, use the bonjour acocunt if no accounts are defined ~~
104 1 Adrian Georgescu
 1. ~~ The list of account is built based the active attribute of each account alone, registration status has no role~~
105 167 Adrian Georgescu
 1. ~~When selecting a different account, mark it as '''default''' using the settings api~~
106 1 Adrian Georgescu
 1. ~~Bonjour account does not show up in account list~~
107
 1. ~~'''Remove account''' from list when is disabled in preferences  ~~
108
 1. ~~On startup, '''select the default account''' in the account list~~
109 132 Adrian Georgescu
 1. ~~If red Close button is pressed, the main window disappears and is no option to bring it back~~
110 1 Adrian Georgescu
 1. ~~No dock icon available~~
111 195 Adrian Georgescu
112 232 Adrian Georgescu
= Log drawer =
113 236 Adrian Georgescu
114 254 Adrian Georgescu
 1. Lower the font size and use red font in case of errors
115
 1. Display more useful messages (e.g. DNS lookups, session status)
116 232 Adrian Georgescu
117 195 Adrian Georgescu
= Contacts =
118 132 Adrian Georgescu
119 195 Adrian Georgescu
 1. When add a contact without domain part, always append the '''curent domain'''
120
 1. Type a '''new group''' in add contact: (NameError: global name 'ContactsGroup' is not defined)
121
 1. '''Delete the contact''' when pressing delete
122
 1. Rename '''Add as a contact''' to Add Contact
123
 1. Hide '''Add contact''' if contact exists
124 1 Adrian Georgescu
 1. After dialing a found contact, '''display back''' the buddy list
125 199 Adrian Georgescu
 1. '''Cannot press''' start session buttons for input in search bar if no match found
126
 1. Show search results from system '''address book'''
127
128
129 202 Adrian Georgescu
= Preferences =
130 200 Adrian Georgescu
131
 1. Properly '''align''' horizontally the Advanced settings
132
 1. Audio device must also list 'Default system input ' and 'Default system output'
133
 1. ~~Make all text input fields equal in size~~
134 201 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property
135 199 Adrian Georgescu
 1. Hide the minus button for Bonjour, it cannot be deleted
136
 1. When password field is changed, re-Register the account 
137 242 Adrian Georgescu
 1. When Register flag is toggled for account, (de)Register the account accordingly
138 199 Adrian Georgescu
 1. Codec lists must be an ordered list with at least one active codec
139
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
140
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
141
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
142
 1. '''general.sip.transports''' cannot be saved
143
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
144
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
145
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
146
 1. Display text to the '''left of the checkbox''' instead of the right
147
 1. ~~'''Delete account Enabled checkbox''', leave only the checkbox in the account list~~
148
 1. When '''enable an account''', select it in the main interface account list
149
 1. ~~ Display the '''bonjour account''' always at the end of the list ~~
150
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
151
 1. '''general.message_received_sound''' does not fit in window
152
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
153
 1. Check if the wav file is in the right format before saving the settings related to ringtones
154
 1. Check if the TLS options set by the user are valid before saving them (by loading them outside the engine using gnutls library)
155
156 48 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
157 1 Adrian Georgescu
158 194 Adrian Georgescu
= Conferencing =
159
160
Only one conference is possible to make the interface easy to use.
161 1 Adrian Georgescu
162 240 Adrian Georgescu
Start conference as a mixer
163 1 Adrian Georgescu
164 185 Adrian Georgescu
 1. Set the conference bridge to mix audio between all parties
165 240 Adrian Georgescu
 1. Send a re-INVITE to take each call off hold and set the is-focus attribute of the Contact header
166
 1. Disable the hold buttons of the conferenced sessions
167
 1. Draw the active session selection rectangle around the sessions part of the conference
168 151 Adrian Georgescu
169 240 Adrian Georgescu
Stop  conference as a mixer
170 42 Adrian Georgescu
171
 1. Set the conference bridge to stop mixing audio
172 240 Adrian Georgescu
 1. Send a re-INVITE to disable is-focus attribute of the Contact header
173 41 Adrian Georgescu
 1. Enable the hold buttons
174 1 Adrian Georgescu
 1. Draw the selection rectangle around the selected session
175
176 240 Adrian Georgescu
New sessions as a mixer
177 1 Adrian Georgescu
178
 1. New sessions are added bellow the conference
179
 1. A session can be dragged in and out of the conference
180
 1. When switching from a conference to another single session, do not use hold
181 240 Adrian Georgescu
182
Conference participant
183
184
 1. SUBSCRIBE to the conference event package when receiving a re-INVITE with isfocus true
185
 1. Expand vertically the session frame to display the names of the participants received in subsequent NOTIFY that contain the list of the participants in the conference
186
187 41 Adrian Georgescu
188
= Audio history =
189 96 Adrian Georgescu
190 118 Adrian Georgescu
 1. Use the same session drawer to display previous sessions
191
 1. Keep same layout as active sessions with the following changes:
192 29 Adrian Georgescu
   1. Missed calls (incoming un-answered sessions must display the SIP address in red) 
193
   1. Duration line must display also the Start time: HH:MM:SS (YYYY-MM-DD HH:MM )
194 41 Adrian Georgescu
   1. Instead of audio session information display: Incoming|Outgoing
195 1 Adrian Georgescu
   1. Replace the current session buttons with a callback button
196 116 Adrian Georgescu
 1. Add a Session menu item to toggle the drawer content between active session and history sessions
197 122 Adrian Georgescu
 1. Show most recent sessions on top
198 41 Adrian Georgescu
199 29 Adrian Georgescu
= Engine =
200
201
 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
202
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
203
204
{{{
205
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
206
}}}
207
208
By setting the wrong TLS certificate files, the middleware does not start anymore:
209
210
{{{
211
[Session started at 2009-07-19 10:37:39 +0200.]
212
Traceback (most recent call last):
213
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
214
   in applicationDidFinishLaunching_
215
    self.backend.init(options)
216
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
217 41 Adrian Georgescu
    self._app.start(config_backend=config_be)
218 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
219
    trace_sip=settings.logging.trace_sip,
220
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
221
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
222
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
223 1 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
224 34 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
225 1 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
226 155 Adrian Georgescu
None
227
}}}
228
229
= Menu structure =
230
231 198 Adrian Georgescu
 1. File
232
 1. Edit
233
 1. View
234 155 Adrian Georgescu
  1. Audio sessions drawer 
235 213 Adrian Georgescu
  1. Previous audio sessions
236
  1. Previous chat sessions
237
 1. Audio
238
  1. Output device selection
239
  1. Input device selection
240 155 Adrian Georgescu
  1. Alert device selection
241
  1. Mute (mute mic input)
242
  1. Silent (mute output)
243
 1. Presence
244 1 Adrian Georgescu
  1. Activity
245 155 Adrian Georgescu
   1. Available
246
   1. Phone call
247 198 Adrian Georgescu
   1. Meeting
248 155 Adrian Georgescu
   1. Lunch
249
   1. Dinner
250
   1. Do not disturb (when enabled reject automatically all audio calls)
251
   1. Travel
252
   1. Offline
253
   1. Holiday
254
 1. Contacts
255
  1. Add contact
256
  1. Delete contact
257
  1. Edit contact
258
  1. Add group
259 173 Adrian Georgescu
  1. Delete group
260 166 Adrian Georgescu
  1. Edit group
261
 1. Sessions
262
  1. New audio session ...
263
  1. New chat session ...
264 155 Adrian Georgescu
  1. New multi party chat session ...
265 1 Adrian Georgescu
  1. Close all audio sessions
266
  1. Conference audio sessions
267
268 142 Adrian Georgescu
= Presence bar =
269
270 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
271
272 142 Adrian Georgescu
 1. ~~ Show '''own photo''' to the left ~~
273 1 Adrian Georgescu
 1. Acquire photo from webcam and cache it
274
 1. Show '''Display name''' next to the photo on top row
275 142 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
276
 1. Show '''Presence activity''' next to name on top row. Activities:
277
   1. Available
278
   1. Phone call
279
   1. Meeting
280
   1. Lunch
281
   1. Dinner
282
   1. Do not disturb
283 148 Adrian Georgescu
   1. Travel
284
   1. Offline
285 7 Adrian Georgescu
   1. Holiday
286 1 Adrian Georgescu
287 7 Adrian Georgescu
Add a Presence menu item before Session.
288 41 Adrian Georgescu
289
= Debug window =
290 1 Adrian Georgescu
291
 1. Display all traces in a '''debug window''' with tabs for each debug type
292
 1. Add a '''General messages''' window to the Debug menu, first item
293
294 79 Adrian Georgescu
= GUI settings =
295 41 Adrian Georgescu
296
Remember the following settings between restarts:
297 100 Adrian Georgescu
298 14 Adrian Georgescu
 1. '''Debug window''' and the selected tab
299 47 Adrian Georgescu
 1. Status of '''contact groups''' - colapsed/expanded and their order
300 102 Adrian Georgescu
301 214 Adrian Georgescu
= Middleware =
302 102 Adrian Georgescu
303
 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
304
 1. Enable logging of notifications to file
305 41 Adrian Georgescu
 1. Check the validity of the '''TLS''' settings/files before starting the engine
306
 1. It seems that the '''stun servers''' are learned from the DNS and cannot be overwritten in settings, they show up automatically
307 1 Adrian Georgescu
 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
308
 1. We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
309
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
310
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
311
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
312 66 Adrian Georgescu
 1. Delete '''general.audio.playback_dtmf''' setting
313
 1. Add '''general.audio.mute''' setting
314
 1. Delete '''account.audio''' section
315
 1. Add '''account.sip''' section
316
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
317
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
318 68 Adrian Georgescu
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
319 109 Adrian Georgescu
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
320
 1. Delete '''account.ice.use_stun''', it is always true
321 1 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
322 172 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
323 159 Adrian Georgescu
 1. Delete global.chat.accept_types
324
 1. Delete global.chat.accept_wrapped_types
325
 1.  Add a new setting '''account.chat.server''' default = chatserver.domain
326 189 Adrian Georgescu
327
= General =
328 225 Adrian Georgescu
329 171 Adrian Georgescu
 1. ~~Enable logging based on log settings~~
330 170 Adrian Georgescu
 1. ~~'''Set global.user_data_directory''' to ~/Library/Application\ Support/Blink/~~
331 159 Adrian Georgescu
 1. Scratchy noises when playing tone generator tones
332
 1. Crash when more than 32 tones in the tone generator queue
333 234 Adrian Georgescu
334
= IP connectivity checks =
335
336
If the Internet connectivity goes up and down the client must adjust to this
337
by taling appropiate actions. It is not enough to detect only what kind of
338
NAT we are behind but also what kind of IP connectivity we have.
339
340
== No IP network ==
341
342
Posible checks:
343
344
 * No real IP
345
 * DNS is down
346
 * No default route
347
348
== LAN without Internet ==
349
350
(e.g. wifi hotspot before login)
351
352
Posible checks:
353
354
 * Ethernet is up
355
 * DNS is up
356
357
== Internet access ==
358
359
Posible checks:
360
361
 * Ethernet is up
362
 * DNS is up
363
 * STUN is up
364
 * NAT type