Gui progress

Version 130 (Adrian Georgescu, 07/21/2009 06:00 pm)

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2 1 Adrian Georgescu
3 74 Adrian Georgescu
= Audio sessions =
4 1 Adrian Georgescu
5 115 Adrian Georgescu
 1. ~~ Incoming sessions do not display '''session information''' and the control buttons are missing~~
6 113 Adrian Georgescu
  1. Not getting a SessionDidStart notification from middleware on incoming sessions
7 115 Adrian Georgescu
 1. ~~ When '''rejecting a session''' it creates an entry in the drawer~~
8 1 Adrian Georgescu
 1. '''Cancel''' is not handled for incoming sessions, the pop-up remains active 
9 115 Adrian Georgescu
 1. ~~'''Maximize drawer''' when it opens the first time, it seem to open only 80% now ~~
10 76 Adrian Georgescu
 1. Play '''ringtones'''
11 115 Adrian Georgescu
 1. ~~ A terminated session must '''disappear from the drawer''' automatically after 5 seconds ~~
12 115 Adrian Georgescu
 1. ~~ Remaining sessions must '''shuffle to the top''' when a session ends~~
13 115 Adrian Georgescu
 1. ~~ Toggle hold does not change hold '''button color''' ~~
14 115 Adrian Georgescu
 1. ~~ Update session audio information with '''Hold by remote''' when held by remote party ~~
15 115 Adrian Georgescu
 1. ~~ Only one audio session can be '''active at a time''', all other existing audio sessions must be put on hold~~
16 115 Adrian Georgescu
 1. ~~ Highlight the '''active session''' with a bold border, click on a session to select it as the active session~~
17 75 Adrian Georgescu
 1. When the active session is selected, what is typed on the keyboard must be transmitted as '''DTMF tones'''
18 115 Adrian Georgescu
 1. ~~ When a call is connected move keyboard focus to it ~~
19 115 Adrian Georgescu
 1. ~~ When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck  ~~
20 115 Adrian Georgescu
 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) ~~
21 117 Adrian Georgescu
 1. Remove the '''i''' icon, display a black triangle instead (black triangle?). Maybe is beter to just click on audio info to get a pop up with more information?
22 115 Adrian Georgescu
 1. ~~ '''Scroll bar''' appears as result of multiple sessions, but it does not disappear when the number of session decreases~~
23 115 Adrian Georgescu
 1. ~~ '''Hangup All''' is not implemented~~
24 119 Adrian Georgescu
 1. Display icon with lock when sRTP is active
25 123 Adrian Georgescu
 1. Disable Hangup All button if no session is active
26 123 Adrian Georgescu
 1. Disable Conference button if less than two sessions active
27 123 Adrian Georgescu
28 127 Adrian Georgescu
= History sessions =
29 32 Adrian Georgescu
30 128 Adrian Georgescu
 1. Use the same session drawer to display previous sessions
31 127 Adrian Georgescu
 1. Keep same layout as active session with the following changes:
32 127 Adrian Georgescu
   1. Instead of audio session information display the negotiated streams (Audio|Chat|Audio+Chat etc...)
33 127 Adrian Georgescu
   1. Instead of duration display '''YYYY-MM-DD HH:MM  Duration: HH:MM:SS''' 
34 127 Adrian Georgescu
   1. Add a button to call back in place of current session buttons
35 127 Adrian Georgescu
 1. Add a Session menu item to toggle the drawer content between active session and history sessions
36 127 Adrian Georgescu
 1. Show most recent sessions on top
37 127 Adrian Georgescu
38 127 Adrian Georgescu
 
39 120 Adrian Georgescu
= Conferencing =
40 120 Adrian Georgescu
41 124 Adrian Georgescu
Only one conference is possible to make the interface easy to use.
42 1 Adrian Georgescu
43 124 Adrian Georgescu
To start a conference: 
44 124 Adrian Georgescu
45 124 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
46 124 Adrian Georgescu
 1. Set the conference bridge to mix audio between all parties
47 124 Adrian Georgescu
 1. Disable the hold buttons, they do not operate while in conference
48 124 Adrian Georgescu
 1. Draw the selection rectangle around the sessions part of the conference
49 124 Adrian Georgescu
50 124 Adrian Georgescu
To stop a conference
51 124 Adrian Georgescu
52 124 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
53 124 Adrian Georgescu
 1. Set the conference bridge to stop mixing audio
54 124 Adrian Georgescu
 1. Enable the hold buttons
55 124 Adrian Georgescu
 1. Draw the selection rectangle around the selected session
56 124 Adrian Georgescu
57 124 Adrian Georgescu
New sessions while in a conference
58 124 Adrian Georgescu
59 120 Adrian Georgescu
 1. New sessions are added bellow the conference
60 120 Adrian Georgescu
 1. A session can be dragged in and out of the conference
61 124 Adrian Georgescu
 1. When switching from a conference to another single session, do not use hold
62 124 Adrian Georgescu
63 120 Adrian Georgescu
64 1 Adrian Georgescu
= Chat sessions =
65 1 Adrian Georgescu
66 1 Adrian Georgescu
 1. '''Close chat''' button does not close the window
67 84 Adrian Georgescu
 1. '''No BYE''' is sent when session ends
68 56 Adrian Georgescu
 1. Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''
69 1 Adrian Georgescu
 1. For each message that appears in the history window:
70 1 Adrian Georgescu
  1. Display a rounded thin rectangle with the '''recipient''' on the left and '''full date''' on the right side of the text in history with either light blue or grey background depending on which party is typing it, display the full FROM headers
71 1 Adrian Georgescu
  1. Then display the content of the message without a rectangle
72 48 Adrian Georgescu
 1. Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings
73 1 Adrian Georgescu
 1. Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings
74 41 Adrian Georgescu
 1. '''Throttle playback''' of audible notifications to maximum one every 3 seconds 
75 84 Adrian Georgescu
 1. Display the number of '''un-read messages''' in non-visible tabs in a red circle over the tab name
76 84 Adrian Georgescu
 1. Display a status bar on the bottom of the window and '''show the connection information''' in it instead of the main window
77 1 Adrian Georgescu
 1. When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
78 1 Adrian Georgescu
 1. When an incoming request has '''chat only''' and the from header is in the contact list, automatically accept the session
79 125 Adrian Georgescu
 1. Make horizontal delimiter drag-able
80 126 Adrian Georgescu
 1. When start typing send '''is-composing'''. 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. 
81 130 Adrian Georgescu
 1. Add a + button (add contact) in the window toolbar if the buddy does not exit
82 80 Adrian Georgescu
83 1 Adrian Georgescu
= Main interface =
84 42 Adrian Georgescu
85 84 Adrian Georgescu
 1. When selecting a different account, mark it as '''default''' using the settings api
86 107 Adrian Georgescu
 1. '''Remove account''' from list when is disabled in preferences  
87 107 Adrian Georgescu
 1. On startup, '''select the default account''' in the account list
88 59 Adrian Georgescu
 1. The SIP accounts are '''not de-registered''' on quit
89 1 Adrian Georgescu
 1. Add a '''minimize button''' to collapse the buddy list
90 129 Adrian Georgescu
 1. Hide the Add button + sign when the interface is collapsed
91 107 Adrian Georgescu
 1. Mute button is not implemented 
92 112 Adrian Georgescu
 1. If red button is pressed the main window disappears and is no option to bring it back
93 112 Adrian Georgescu
 1. No dock icon available
94 59 Adrian Georgescu
95 59 Adrian Georgescu
= Contacts =
96 1 Adrian Georgescu
97 63 Adrian Georgescu
 1. When add contact without domain part always append curent domain
98 6 Adrian Georgescu
 1. '''Delete the contact''' when pressing delete
99 111 Adrian Georgescu
 1. After dialing a found contact, display back the buddy list
100 111 Adrian Georgescu
 1. Show search results from the system address book
101 121 Adrian Georgescu
 1. Add right click for contact:
102 121 Adrian Georgescu
  1. Start audio session
103 121 Adrian Georgescu
  1. Start chat session
104 121 Adrian Georgescu
  1. Transfer file
105 121 Adrian Georgescu
  1. Offer local desktop
106 121 Adrian Georgescu
  1. Request remote desktop
107 121 Adrian Georgescu
  1. Edit contact
108 121 Adrian Georgescu
  1. Delete contact
109 21 Adrian Georgescu
110 41 Adrian Georgescu
= Preferences =
111 41 Adrian Georgescu
112 122 Adrian Georgescu
 1. '''Change audio devices''' does not enter effect unless rebooting, call set_devices() to activate the new settings
113 42 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
114 42 Adrian Georgescu
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
115 42 Adrian Georgescu
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
116 42 Adrian Georgescu
 1. '''general.sip.transports''' cannot be saved
117 42 Adrian Georgescu
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
118 42 Adrian Georgescu
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
119 42 Adrian Georgescu
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
120 42 Adrian Georgescu
 1. When '''disable account''' in preferences, it does not get removed from the main interface account lists
121 41 Adrian Georgescu
 1. Properly '''align''' horizontally the Advanced settings
122 41 Adrian Georgescu
 1. Display text to the '''left of the checkbox''' instead of the right
123 41 Adrian Georgescu
 1. '''Delete account Enabled checkbox''', leave only the checkbox in the account list
124 41 Adrian Georgescu
 1. '''De-register''' the account and remove it from the account list in main interface when disable the account
125 41 Adrian Georgescu
 1. When '''enable an account''', select it in the main interface account list
126 41 Adrian Georgescu
 1. Add a '''Reset option''' to reset advanced settings to default values
127 41 Adrian Georgescu
 1. Display the '''bonjour account''' always at the end of the list
128 94 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property.  There is not sip address or password
129 108 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. Bonjour can only be enabled/disabled but not deleted.
130 41 Adrian Georgescu
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
131 41 Adrian Georgescu
 1. '''general.message_received_sound''' does not fit in window
132 41 Adrian Georgescu
 1. Allow ordering of accounts in the account list
133 96 Adrian Georgescu
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
134 118 Adrian Georgescu
 1. Check if the wav file is in the right format before saving the settings related to ringtones
135 118 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)
136 55 Adrian Georgescu
137 29 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
138 29 Adrian Georgescu
139 41 Adrian Georgescu
= Engine =
140 1 Adrian Georgescu
141 116 Adrian Georgescu
 1. Set User Agent name to blink-version
142 122 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
143 41 Adrian Georgescu
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
144 29 Adrian Georgescu
145 29 Adrian Georgescu
{{{
146 29 Adrian Georgescu
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
147 29 Adrian Georgescu
}}}
148 29 Adrian Georgescu
149 29 Adrian Georgescu
By setting the wrong TLS certificate files, the middleware does not start anymore:
150 29 Adrian Georgescu
151 29 Adrian Georgescu
{{{
152 29 Adrian Georgescu
[Session started at 2009-07-19 10:37:39 +0200.]
153 29 Adrian Georgescu
Traceback (most recent call last):
154 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
155 29 Adrian Georgescu
   in applicationDidFinishLaunching_
156 29 Adrian Georgescu
    self.backend.init(options)
157 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
158 29 Adrian Georgescu
    self._app.start(config_backend=config_be)
159 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
160 29 Adrian Georgescu
    trace_sip=settings.logging.trace_sip,
161 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
162 41 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
163 29 Adrian Georgescu
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
164 29 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
165 29 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
166 29 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
167 29 Adrian Georgescu
None
168 1 Adrian Georgescu
}}}
169 34 Adrian Georgescu
170 1 Adrian Georgescu
= Presence bar =
171 1 Adrian Georgescu
172 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
173 1 Adrian Georgescu
174 129 Adrian Georgescu
 1. Show '''own photo''' to the left, align photo and size with buddy list photos
175 41 Adrian Georgescu
 1. Show '''Display name''' next to the photo on top row
176 129 Adrian Georgescu
 1. Show '''Presence activity''' next to name on top row
177 129 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
178 7 Adrian Georgescu
179 7 Adrian Georgescu
= Debug window =
180 1 Adrian Georgescu
181 7 Adrian Georgescu
 1. Display all traces in a '''debug window''' with tabs for each debug type
182 41 Adrian Georgescu
 1. Add a '''General messages''' window to the Debug menu, first item
183 41 Adrian Georgescu
184 1 Adrian Georgescu
= GUI settings =
185 1 Adrian Georgescu
186 1 Adrian Georgescu
Remember the following settings between restarts:
187 1 Adrian Georgescu
188 79 Adrian Georgescu
 1. '''Debug window''' and the selected tab
189 41 Adrian Georgescu
 1. Status of '''contact groups''' - colapsed/expanded and their order
190 41 Adrian Georgescu
 1. SIP '''accounts order''' list
191 41 Adrian Georgescu
192 100 Adrian Georgescu
= Middleware =
193 14 Adrian Georgescu
194 47 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
195 102 Adrian Georgescu
 1. Check the validity of the '''TLS''' settings/files before starting the engine
196 102 Adrian Georgescu
 1. It seems that the '''stun servers''' are learned from the DNS and cannot be overwritten in settings, they show up automatically
197 102 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
198 102 Adrian Georgescu
 1. Append '''dummy''' to the lists of available audio devices
199 41 Adrian Georgescu
 1. We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
200 41 Adrian Georgescu
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
201 41 Adrian Georgescu
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
202 1 Adrian Georgescu
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
203 1 Adrian Georgescu
 1. Delete '''general.audio.playback_dtmf''' setting
204 1 Adrian Georgescu
 1. Add '''general.audio.mute''' setting
205 1 Adrian Georgescu
 1. Delete '''account.audio''' section
206 1 Adrian Georgescu
 1. Add '''account.sip''' section
207 66 Adrian Georgescu
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
208 66 Adrian Georgescu
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
209 66 Adrian Georgescu
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
210 66 Adrian Georgescu
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
211 66 Adrian Georgescu
 1. Delete '''account.ice.use_stun''', it is always true
212 66 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
213 68 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
214 109 Adrian Georgescu
 1. Delete global.chat.accept_types
215 109 Adrian Georgescu
 1. Delete global.chat.accept_wrapped_types