Gui progress

Version 35 (Adrian Georgescu, 07/19/2009 12:08 pm)

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2 1 Adrian Georgescu
3 1 Adrian Georgescu
= Critical issues =
4 1 Adrian Georgescu
5 5 Adrian Georgescu
Must be solved first.
6 1 Adrian Georgescu
7 35 Adrian Georgescu
 1. Sessions remain indefinitely in the drawer
8 35 Adrian Georgescu
 1. Voice calls do not update the status of the drawer
9 35 Adrian Georgescu
 1. Incoming sessions do no cancel
10 35 Adrian Georgescu
11 35 Adrian Georgescu
{{{
12 35 Adrian Georgescu
2009-07-19 12:07:27.968 Blink[43601:10b]   File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/ContactWindowController.py", line 462, in sip_session_incoming
13 35 Adrian Georgescu
2009-07-19 12:07:27.969 Blink[43601:10b]     session.reject(resp_code)
14 35 Adrian Georgescu
2009-07-19 12:07:27.969 Blink[43601:10b]   File "<string>", line 1, in reject
15 35 Adrian Georgescu
2009-07-19 12:07:27.969 Blink[43601:10b]   File "/Library/Python/2.5/site-packages/sipsimple/session.py", line 46, in wrapper
16 35 Adrian Georgescu
2009-07-19 12:07:27.971 Blink[43601:10b]     raise RuntimeError('cannot call %s in %s state' % (func.__name__, obj.state))
17 35 Adrian Georgescu
2009-07-19 12:07:27.971 Blink[43601:10b] RuntimeError: cannot call reject in terminated state
18 35 Adrian Georgescu
}}}
19 35 Adrian Georgescu
20 35 Adrian Georgescu
 1. Incoming sessions to not display audio session information 
21 31 Adrian Georgescu
 1. In chat window, after entering a message the scrollbar '''moves up by itself'''
22 31 Adrian Georgescu
 1. When text is pasted, as opposed to typed on the keyboard, the '''pasted content''' is sent but not displayed
23 11 Adrian Georgescu
 1. Display the '''negotiated codec''' next to audio and use colors from email snapshot
24 11 Adrian Georgescu
 1. '''session duration''' for both incoming and outgoing is missing
25 29 Adrian Georgescu
 1. When enable a new account, the main interface displays '''no account selected''' anymore
26 29 Adrian Georgescu
 1. On startup, '''select the default account''' in the account lists 
27 29 Adrian Georgescu
 1. When select a different account, mark it as '''default'''
28 11 Adrian Georgescu
 1. '''Expand the session frame horizontally''' to fill on the drawer to its full width and draw just one line between two voice calls
29 4 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
30 1 Adrian Georgescu
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
31 1 Adrian Georgescu
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
32 1 Adrian Georgescu
 1. '''general.sip.transports''' cannot be saved
33 10 Adrian Georgescu
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
34 18 Adrian Georgescu
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
35 23 Adrian Georgescu
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
36 25 Adrian Georgescu
 1. When '''disable account''' in preferences, it does not get removed from the main interface account lists
37 30 Adrian Georgescu
 1. Display '''active account in bold text'''
38 23 Adrian Georgescu
39 32 Adrian Georgescu
= Sessions =
40 30 Adrian Georgescu
41 32 Adrian Georgescu
 * Center the '''drawer title''' and make it look like a title bar
42 32 Adrian Georgescu
 * Show the '''drawer maximized''' horizontally
43 32 Adrian Georgescu
 * Center align '''Hangup All and Conference buttons'''
44 32 Adrian Georgescu
 * Only one audio session can be '''active at a time''', when answering a new audio session, all other existing audio sessions must be put on hold
45 33 Adrian Georgescu
 * When the active session is selected with the mouse, what is typed must be transmitted as DTMF tones
46 32 Adrian Georgescu
 * When an incoming request has '''chat only''' and the from header is in the contact list, automatically accept the session
47 32 Adrian Georgescu
 * Highlight the active session with a '''bold''' border
48 32 Adrian Georgescu
 * When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck 
49 32 Adrian Georgescu
 * If all sessions have ended, the '''drawer must be closed'''
50 32 Adrian Georgescu
 * Add an item to the '''Session menu''' to show the drawer, if it was closed
51 32 Adrian Georgescu
52 1 Adrian Georgescu
= Chat window =
53 1 Adrian Georgescu
54 1 Adrian Georgescu
 * Change title of the chat window to '''remote@domain'''
55 1 Adrian Georgescu
 * '''Hide the empty scroll bar''' of the text input box
56 1 Adrian Georgescu
 * Display a status bar on the bottom of the window and '''show the connection information''' in it instead of the main window
57 1 Adrian Georgescu
 * Display the Chat recipient in a '''tab at the bottom of the window'''
58 1 Adrian Georgescu
 * Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings
59 1 Adrian Georgescu
 * Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings
60 4 Adrian Georgescu
 * '''Throttle playback''' of audible notifications to maximum one every 3 seconds 
61 1 Adrian Georgescu
 * Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''
62 1 Adrian Georgescu
 * For each message that appears in the history window:
63 1 Adrian Georgescu
  * First 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
64 1 Adrian Georgescu
  * Then display the content of the message
65 1 Adrian Georgescu
 * When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
66 2 Adrian Georgescu
 * Display the number of '''un-read messages''' in non-visible tabs in a red circle over the tab name
67 1 Adrian Georgescu
68 6 Adrian Georgescu
= Contacts =
69 21 Adrian Georgescu
70 22 Adrian Georgescu
 * '''Hide display name''', show only the SIP address in the account selection
71 21 Adrian Georgescu
 * Remove the blue '''is-selected''' rectangle that appears around the active account
72 21 Adrian Georgescu
 * '''Replace''' 3333 with 3333@sip2sip.info and 4444 with 4444@sip2sip.info
73 1 Adrian Georgescu
 * When searching contacts, do not display '''Add button''' if the contact already exists
74 22 Adrian Georgescu
 * Show the '''Display name''' if set for the Contact, otherwise the SIP address
75 19 Adrian Georgescu
 * Add new '''contact window fields''': SIP address, Display name and Group
76 19 Adrian Georgescu
 * '''Delete the contact''' when pressing delete, show a confirm window
77 19 Adrian Georgescu
 * When '''searching a contact''' and starting a session to it: (NameError: global name 'row' is not defined)
78 19 Adrian Georgescu
79 19 Adrian Georgescu
= Preferences =
80 24 Adrian Georgescu
81 1 Adrian Georgescu
 * Properly '''align''' horizontally the Advanced settings
82 30 Adrian Georgescu
 * In advanced sections, display '''Enabled:''' on the left side of the checkbox instead of the right
83 30 Adrian Georgescu
 * Delete the '''little title bar on top of the account list'''
84 30 Adrian Georgescu
 * '''Delete account Enabled checkbox''', leave only the checkbox in the account list
85 1 Adrian Georgescu
 * Hide the vertical and horizontal '''scroll bars''' when no scrollbar is needed
86 1 Adrian Georgescu
 * '''De-register''' the account and remove it from the account list in main interface when disable the account
87 1 Adrian Georgescu
 * When '''enable an account''', select it in the main interface account list
88 1 Adrian Georgescu
 * Add a '''Reset option''' to reset advanced settings to default values
89 30 Adrian Georgescu
 * Display the '''bonjour account''' always at the end of the list
90 30 Adrian Georgescu
 * Cannot '''delete Bonjour''' account: (TypeError: cannot delete BonjourAccount instance with default id). Fo  not allow the user to attempt to delete it. Bonjour can only be enabled/disabled but not deleted.
91 1 Adrian Georgescu
 * For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
92 1 Adrian Georgescu
 * '''general.message_received_sound''' does not fit in window
93 1 Adrian Georgescu
 * Allow ordering of accounts in the account list
94 1 Adrian Georgescu
95 1 Adrian Georgescu
Hide the following settings, they should not be editable from GUI:
96 1 Adrian Georgescu
97 1 Adrian Georgescu
 * global.chat.accept_types
98 1 Adrian Georgescu
 * global.chat.accept_wrapped_types
99 1 Adrian Georgescu
 * global.sip.ignore_missing_ack
100 1 Adrian Georgescu
 * account.presence.publish_interval
101 19 Adrian Georgescu
 * account.presence.subscribe_interval
102 19 Adrian Georgescu
 * account.presence.subscribe_rls_services
103 19 Adrian Georgescu
 * account.presence.subscribe_xcap_diff
104 19 Adrian Georgescu
105 19 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
106 29 Adrian Georgescu
107 29 Adrian Georgescu
= Engine =
108 29 Adrian Georgescu
109 29 Adrian Georgescu
 * 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
110 29 Adrian Georgescu
 * 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
111 29 Adrian Georgescu
112 29 Adrian Georgescu
 * If the engine has stopped (because of some crash) the preferences do not show anymore:
113 29 Adrian Georgescu
114 29 Adrian Georgescu
{{{
115 29 Adrian Georgescu
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
116 29 Adrian Georgescu
}}}
117 29 Adrian Georgescu
118 29 Adrian Georgescu
By setting the wrong TLS certificate files, the middleware does not start anymore:
119 29 Adrian Georgescu
120 29 Adrian Georgescu
{{{
121 29 Adrian Georgescu
[Session started at 2009-07-19 10:37:39 +0200.]
122 29 Adrian Georgescu
Traceback (most recent call last):
123 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
124 29 Adrian Georgescu
   in applicationDidFinishLaunching_
125 29 Adrian Georgescu
    self.backend.init(options)
126 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
127 29 Adrian Georgescu
    self._app.start(config_backend=config_be)
128 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
129 29 Adrian Georgescu
    trace_sip=settings.logging.trace_sip,
130 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
131 29 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, **init_options)
132 29 Adrian Georgescu
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
133 29 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
134 29 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
135 29 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
136 29 Adrian Georgescu
None
137 29 Adrian Georgescu
}}}
138 1 Adrian Georgescu
139 34 Adrian Georgescu
140 1 Adrian Georgescu
= Presence bar =
141 1 Adrian Georgescu
142 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
143 1 Adrian Georgescu
144 2 Adrian Georgescu
 * Show '''own photo''' to the left
145 2 Adrian Georgescu
 * Show '''Display name''' next to the photo on top row
146 1 Adrian Georgescu
 * Show '''presence activity''' next to name on top row
147 1 Adrian Georgescu
 * Show '''activity note''' on second row
148 7 Adrian Georgescu
149 7 Adrian Georgescu
= Debug window =
150 7 Adrian Georgescu
151 7 Adrian Georgescu
 * Display all traces in a '''debug window''' with tabs for each debug type
152 7 Adrian Georgescu
 * Add a '''General messages''' window to the Debug menu, first item
153 1 Adrian Georgescu
154 1 Adrian Georgescu
= GUI settings =
155 1 Adrian Georgescu
156 1 Adrian Georgescu
Remember the following settings between restarts:
157 1 Adrian Georgescu
158 28 Adrian Georgescu
 * '''Main window''' size and screen position (done)
159 2 Adrian Georgescu
 * '''Debug window''' and the selected tabe
160 1 Adrian Georgescu
 * Status of '''contact groups''' - colapsed/expanded and their order
161 17 Adrian Georgescu
 * SIP '''accounts order''' list
162 14 Adrian Georgescu
163 14 Adrian Georgescu
= Middleware changes =
164 14 Adrian Georgescu
165 34 Adrian Georgescu
 * Check the validity of the TLS certificate before starting the engine
166 14 Adrian Georgescu
 * Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
167 14 Adrian Georgescu
 * It seems that the stun servers are learned from the DNS and cannot be overwritten in settings, they show up automatically
168 14 Adrian Georgescu
 * if I set the relay to abcd.com you must use the default standard port of 2855, now is set to zero: relay = abcd.com:0;transport=tls
169 14 Adrian Georgescu
 * Append dummy to the lists of available audio devices
170 14 Adrian Georgescu
 * We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
171 14 Adrian Georgescu
 * Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
172 14 Adrian Georgescu
 * Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
173 14 Adrian Georgescu
 * Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
174 14 Adrian Georgescu
 * Delete '''account.audio''' section