Project

General

Profile

Gui progress » History » Version 229

Adrian Georgescu, 07/28/2009 04:46 PM

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