Gui progress

Version 129 (Adrian Georgescu, 07/21/2009 05:46 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 80 Adrian Georgescu
82 1 Adrian Georgescu
= Main interface =
83 42 Adrian Georgescu
84 84 Adrian Georgescu
 1. When selecting a different account, mark it as '''default''' using the settings api
85 107 Adrian Georgescu
 1. '''Remove account''' from list when is disabled in preferences  
86 107 Adrian Georgescu
 1. On startup, '''select the default account''' in the account list
87 59 Adrian Georgescu
 1. The SIP accounts are '''not de-registered''' on quit
88 1 Adrian Georgescu
 1. Add a '''minimize button''' to collapse the buddy list
89 129 Adrian Georgescu
 1. Hide the Add button + sign when the interface is collapsed
90 107 Adrian Georgescu
 1. Mute button is not implemented 
91 112 Adrian Georgescu
 1. If red button is pressed the main window disappears and is no option to bring it back
92 112 Adrian Georgescu
 1. No dock icon available
93 59 Adrian Georgescu
94 59 Adrian Georgescu
= Contacts =
95 1 Adrian Georgescu
96 63 Adrian Georgescu
 1. When add contact without domain part always append curent domain
97 6 Adrian Georgescu
 1. '''Delete the contact''' when pressing delete
98 111 Adrian Georgescu
 1. After dialing a found contact, display back the buddy list
99 111 Adrian Georgescu
 1. Show search results from the system address book
100 121 Adrian Georgescu
 1. Add right click for contact:
101 121 Adrian Georgescu
  1. Start audio session
102 121 Adrian Georgescu
  1. Start chat session
103 121 Adrian Georgescu
  1. Transfer file
104 121 Adrian Georgescu
  1. Offer local desktop
105 121 Adrian Georgescu
  1. Request remote desktop
106 121 Adrian Georgescu
  1. Edit contact
107 121 Adrian Georgescu
  1. Delete contact
108 21 Adrian Georgescu
109 41 Adrian Georgescu
= Preferences =
110 41 Adrian Georgescu
111 122 Adrian Georgescu
 1. '''Change audio devices''' does not enter effect unless rebooting, call set_devices() to activate the new settings
112 42 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
113 42 Adrian Georgescu
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
114 42 Adrian Georgescu
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
115 42 Adrian Georgescu
 1. '''general.sip.transports''' cannot be saved
116 42 Adrian Georgescu
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
117 42 Adrian Georgescu
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
118 42 Adrian Georgescu
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
119 42 Adrian Georgescu
 1. When '''disable account''' in preferences, it does not get removed from the main interface account lists
120 41 Adrian Georgescu
 1. Properly '''align''' horizontally the Advanced settings
121 41 Adrian Georgescu
 1. Display text to the '''left of the checkbox''' instead of the right
122 41 Adrian Georgescu
 1. '''Delete account Enabled checkbox''', leave only the checkbox in the account list
123 41 Adrian Georgescu
 1. '''De-register''' the account and remove it from the account list in main interface when disable the account
124 41 Adrian Georgescu
 1. When '''enable an account''', select it in the main interface account list
125 41 Adrian Georgescu
 1. Add a '''Reset option''' to reset advanced settings to default values
126 41 Adrian Georgescu
 1. Display the '''bonjour account''' always at the end of the list
127 94 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property.  There is not sip address or password
128 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.
129 41 Adrian Georgescu
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
130 41 Adrian Georgescu
 1. '''general.message_received_sound''' does not fit in window
131 41 Adrian Georgescu
 1. Allow ordering of accounts in the account list
132 96 Adrian Georgescu
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
133 118 Adrian Georgescu
 1. Check if the wav file is in the right format before saving the settings related to ringtones
134 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)
135 55 Adrian Georgescu
136 29 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
137 29 Adrian Georgescu
138 41 Adrian Georgescu
= Engine =
139 1 Adrian Georgescu
140 116 Adrian Georgescu
 1. Set User Agent name to blink-version
141 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
142 41 Adrian Georgescu
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
143 29 Adrian Georgescu
144 29 Adrian Georgescu
{{{
145 29 Adrian Georgescu
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
146 29 Adrian Georgescu
}}}
147 29 Adrian Georgescu
148 29 Adrian Georgescu
By setting the wrong TLS certificate files, the middleware does not start anymore:
149 29 Adrian Georgescu
150 29 Adrian Georgescu
{{{
151 29 Adrian Georgescu
[Session started at 2009-07-19 10:37:39 +0200.]
152 29 Adrian Georgescu
Traceback (most recent call last):
153 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
154 29 Adrian Georgescu
   in applicationDidFinishLaunching_
155 29 Adrian Georgescu
    self.backend.init(options)
156 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
157 29 Adrian Georgescu
    self._app.start(config_backend=config_be)
158 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
159 29 Adrian Georgescu
    trace_sip=settings.logging.trace_sip,
160 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
161 41 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
162 29 Adrian Georgescu
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
163 29 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
164 29 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
165 29 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
166 29 Adrian Georgescu
None
167 1 Adrian Georgescu
}}}
168 34 Adrian Georgescu
169 1 Adrian Georgescu
= Presence bar =
170 1 Adrian Georgescu
171 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
172 1 Adrian Georgescu
173 129 Adrian Georgescu
 1. Show '''own photo''' to the left, align photo and size with buddy list photos
174 41 Adrian Georgescu
 1. Show '''Display name''' next to the photo on top row
175 129 Adrian Georgescu
 1. Show '''Presence activity''' next to name on top row
176 129 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
177 7 Adrian Georgescu
178 7 Adrian Georgescu
= Debug window =
179 1 Adrian Georgescu
180 7 Adrian Georgescu
 1. Display all traces in a '''debug window''' with tabs for each debug type
181 41 Adrian Georgescu
 1. Add a '''General messages''' window to the Debug menu, first item
182 41 Adrian Georgescu
183 1 Adrian Georgescu
= GUI settings =
184 1 Adrian Georgescu
185 1 Adrian Georgescu
Remember the following settings between restarts:
186 1 Adrian Georgescu
187 79 Adrian Georgescu
 1. '''Debug window''' and the selected tab
188 41 Adrian Georgescu
 1. Status of '''contact groups''' - colapsed/expanded and their order
189 41 Adrian Georgescu
 1. SIP '''accounts order''' list
190 41 Adrian Georgescu
191 100 Adrian Georgescu
= Middleware =
192 14 Adrian Georgescu
193 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
194 102 Adrian Georgescu
 1. Check the validity of the '''TLS''' settings/files before starting the engine
195 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
196 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
197 102 Adrian Georgescu
 1. Append '''dummy''' to the lists of available audio devices
198 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.
199 41 Adrian Georgescu
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
200 41 Adrian Georgescu
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
201 1 Adrian Georgescu
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
202 1 Adrian Georgescu
 1. Delete '''general.audio.playback_dtmf''' setting
203 1 Adrian Georgescu
 1. Add '''general.audio.mute''' setting
204 1 Adrian Georgescu
 1. Delete '''account.audio''' section
205 1 Adrian Georgescu
 1. Add '''account.sip''' section
206 66 Adrian Georgescu
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
207 66 Adrian Georgescu
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
208 66 Adrian Georgescu
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
209 66 Adrian Georgescu
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
210 66 Adrian Georgescu
 1. Delete '''account.ice.use_stun''', it is always true
211 66 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
212 68 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
213 109 Adrian Georgescu
 1. Delete global.chat.accept_types
214 109 Adrian Georgescu
 1. Delete global.chat.accept_wrapped_types