Project

General

Profile

Gui progress » History » Version 265

Adrian Georgescu, 07/30/2009 06:22 PM

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