~ubuntu-branches/ubuntu/karmic/ekiga/karmic

« back to all changes in this revision

Viewing changes to lib/engine/components/opal/opal-account.h

  • Committer: Bazaar Package Importer
  • Author(s): Ken VanDine
  • Date: 2009-03-17 15:14:12 UTC
  • mfrom: (1.1.9 upstream)
  • Revision ID: james.westby@ubuntu.com-20090317151412-no6uq0wl8zz2hsw3
Tags: 3.2.0-0ubuntu1
* New upstream release (LP: #341367)
  - Better NAT support in case of Cone NAT
  - Uniformise detection of libnotify; fix compilation with mingw
  - Fix "URL completion combobox shows identical completions"
  - Fix "Assistant loosing values when going backward"
  - Fix GmConf settings when compiled with another package name
  - Fix unregistration of accounts
  - Fix build with --enable-kde
  - Fixed possible crash when retrieving presence information
  - New translations: crh, or
  - Updated translations: as, bg, bn_IN, da, de, el, eu, gl, gu, hi, hu,
    ja, kn, ko, ku, lt, ml, mr, or, pt, ro, ru, ta, te, tr
  - New help translation: en_GB
  - Updated help translation: fr
  - Better NAT support in case of Cone NAT
  - There is now only one H.263 plugin implementing both H.263 and H.263+
  - Allow several ALSA devices to have the same name
  - Added support for the G.722 audio codec: G.722 is a 16 kHz wideband
    audio codec advertised as HD Voice by the famous Polycom. It is a
    great boost in quality and interoperability
  - Added support for the CELT ultral-low delay audio codec: CELT delivers
    high quality audio at 32 kHz or 48 kHz, allowing to transmit music in
    high quality, with low delay and low bitrate
  - Added support for SIP dialog-info notifications: they allow displaying
    notifications of incoming calls in the roster. With software like
    kamailio or Asterisk, it allows being informed of incoming calls
    reaching your colleagues
  - Largely improved LDAP support: the OpenLDAP guys contributed several
    patches to provide state-of-the-art LDAP support in the Ekiga address
    book. The new code even supports authentication
  - Killed the gconf_test_age test, Ekiga can now finally work with
    badly installed GConf schemas
  - Better handling of multiple network interfaces with dynamic addition
    and removal
  - Added settings migration from Ekiga 2.0.x.
  - Other various fixes, cleanups, removal of deprecated symbols etc.
  - New translations: crh, or
  - New help translation: en_GB, eu
  - Updated many translations and help
  - Experimental features:
    * Significant improvements in IPv6 support
    * Gstreamer audio and video capture support near to be finished...
* debian/patches/migrate_2.0_settings.patch:
  - Removed, migration is now upstream
* debian/patches/00_news.patch
  - Removed
* debian/patches/ubuntu_lpi.patch:
  - Modified to work with 3.2

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
 
 
2
/* Ekiga -- A VoIP and Video-Conferencing application
 
3
 * Copyright (C) 2000-2009 Damien Sandras <dsandras@seconix.com>
 
4
 *
 
5
 * This program is free software; you can redistribute it and/or modify
 
6
 * it under the terms of the GNU General Public License as published by
 
7
 * the Free Software Foundation; either version 2 of the License, or
 
8
 * (at your option) any later version.
 
9
 *
 
10
 * This program is distributed in the hope that it will be useful,
 
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
 * GNU General Public License for more details.
 
14
 *
 
15
 * You should have received a copy of the GNU General Public License
 
16
 * along with this program; if not, write to the Free Software Foundation,
 
17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
18
 *
 
19
 *
 
20
 * Ekiga is licensed under the GPL license and as a special exception,
 
21
 * you have permission to link or otherwise combine this program with the
 
22
 * programs OPAL, OpenH323 and PWLIB, and distribute the combination,
 
23
 * without applying the requirements of the GNU GPL to the OPAL, OpenH323
 
24
 * and PWLIB programs, as long as you do follow the requirements of the
 
25
 * GNU GPL for all the rest of the software thus combined.
 
26
 */
 
27
 
 
28
 
 
29
/*
 
30
 *                         opal-account.h  -  description
 
31
 *                         ------------------------------------------
 
32
 *   begin                : written in 2008 by Damien Sandras
 
33
 *   copyright            : (c) 2008 by Damien Sandras
 
34
 *   description          : declaration of an OPAL account
 
35
 *
 
36
 */
 
37
 
 
38
#ifndef __OPAL_ACCOUNT_H__
 
39
#define __OPAL_ACCOUNT_H__
 
40
 
 
41
#include "services.h"
 
42
#include "account-core.h"
 
43
#include "account.h"
 
44
#include "form.h"
 
45
#include "bank-impl.h"
 
46
 
 
47
namespace Opal
 
48
{
 
49
  /**
 
50
   * @addtogroup accounts
 
51
   * @internal
 
52
   * @{
 
53
   */
 
54
  class Account: public Ekiga::Account
 
55
  {
 
56
public:
 
57
 
 
58
    typedef enum { SIP, Ekiga, DiamondCard, H323 } Type;
 
59
 
 
60
    Account (Ekiga::ServiceCore & core, 
 
61
             const std::string & account);
 
62
 
 
63
    Account (Ekiga::ServiceCore & core,
 
64
             Type t,
 
65
             std::string name, 
 
66
             std::string host,
 
67
             std::string user,
 
68
             std::string auth_user,
 
69
             std::string password,
 
70
             bool enabled,
 
71
             unsigned timeout);
 
72
 
 
73
    virtual ~Account ();
 
74
 
 
75
    const std::string get_name () const;
 
76
 
 
77
    const std::string get_aor () const;
 
78
 
 
79
    /** Returns the protocol name of the Opal::Account.
 
80
     * This function is purely virtual and should be implemented by the
 
81
     * Ekiga::Account descendant.
 
82
     * @return The protocol name of the Ekiga::Contact.
 
83
     */
 
84
    const std::string get_protocol_name () const;
 
85
 
 
86
    const std::string get_host () const;
 
87
 
 
88
    /** Returns the user name for the Opal::Account.
 
89
     * This function is purely virtual and should be implemented by the
 
90
     * Ekiga::Account descendant.
 
91
     * @return The user name of the Ekiga::Account.
 
92
     */
 
93
    const std::string get_username () const;
 
94
 
 
95
    /** Returns the authentication user name for the Opal::Account.
 
96
     * This function is purely virtual and should be implemented by the
 
97
     * Ekiga::Account descendant.
 
98
     * @return The authentication user name of the Ekiga::Account.
 
99
     */
 
100
    const std::string get_authentication_username () const;
 
101
 
 
102
    /** Returns the password for the Opal::Account.
 
103
     * This function is purely virtual and should be implemented by the
 
104
     * Ekiga::Account descendant.
 
105
     * @return The password of the Ekiga::Account.
 
106
     */
 
107
    const std::string get_password () const;
 
108
 
 
109
    void set_authentication_settings (const std::string & username,
 
110
                                      const std::string & password);
 
111
 
 
112
    /** Returns the registration timeout for the Opal::Account.
 
113
     * This function is purely virtual and should be implemented by the
 
114
     * Ekiga::Account descendant.
 
115
     * @return The timeout of the Ekiga::Account.
 
116
     */
 
117
    unsigned get_timeout () const;
 
118
 
 
119
    void enable ();
 
120
 
 
121
    void disable ();
 
122
 
 
123
    bool is_enabled () const;
 
124
 
 
125
    bool is_active () const;
 
126
 
 
127
    void remove ();
 
128
 
 
129
    void edit ();
 
130
 
 
131
    bool populate_menu (Ekiga::MenuBuilder &builder);
 
132
 
 
133
    const std::string as_string () const;
 
134
 
 
135
    sigc::signal0<void> trigger_saving;
 
136
 
 
137
private:
 
138
    void on_edit_form_submitted (bool submitted,
 
139
                                 Ekiga::Form &result);
 
140
    void on_consult (const std::string url);
 
141
    
 
142
    // Triggered for our own event
 
143
    void on_registration_event (Ekiga::AccountCore::RegistrationState state, std::string info);
 
144
 
 
145
    bool dead;
 
146
    bool active;
 
147
    bool enabled;
 
148
    unsigned timeout;
 
149
    std::string aid;
 
150
    std::string name;
 
151
    std::string protocol_name;
 
152
    std::string host;
 
153
    std::string username;
 
154
    std::string auth_username;
 
155
    std::string password;
 
156
    Type type;
 
157
 
 
158
    Ekiga::ServiceCore & core;
 
159
  };
 
160
 
 
161
  /**
 
162
   * @}
 
163
   */
 
164
};
 
165
 
 
166
#endif