~ubuntu-branches/ubuntu/vivid/ekiga/vivid-proposed

« back to all changes in this revision

Viewing changes to lib/engine/protocol/call-protocol-manager.h

  • Committer: Bazaar Package Importer
  • Author(s): Kilian Krause
  • Date: 2011-07-17 00:24:50 UTC
  • mfrom: (5.1.5 upstream) (7.1.7 sid)
  • Revision ID: james.westby@ubuntu.com-20110717002450-ytg3wsrc1ptd3153
Tags: 3.3.1-1
* New upstream release.
 - Required libpt-dev 2.10 and libopal-dev 3.10
* Fix debian/watch to catch new version
* Remove libnotify0.7.patch - included upstream
* Add libboost-dev and libboost-signals-dev to Build-Depends
* debian/rules: Don't install *.la files for new internal shared libs
* Fix Vcs URIs to point to correct desktop/experimental/ekiga tree

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
 
 
2
/*
 
3
 * Ekiga -- A VoIP and Video-Conferencing application
 
4
 * Copyright (C) 2000-2009 Damien Sandras <dsandras@seconix.com>
 
5
 
 
6
 * This program is free software; you can  redistribute it and/or modify
 
7
 * it under the terms of the GNU General Public License as published by
 
8
 * the Free Software Foundation; either version 2 of the License, or (at
 
9
 * your option) any later version. This program is distributed in the hope
 
10
 * that it will be useful, but WITHOUT ANY WARRANTY; without even the
 
11
 * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 
12
 * See the GNU General Public License for more details.
 
13
 *
 
14
 * You should have received a copy of the GNU General Public License along
 
15
 * with this program; if not, write to the Free Software Foundation, Inc.,
 
16
 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
 
17
 *
 
18
 * Ekiga is licensed under the GPL license and as a special exception, you
 
19
 * have permission to link or otherwise combine this program with the
 
20
 * programs OPAL, OpenH323 and PWLIB, and distribute the combination, without
 
21
 * applying the requirements of the GNU GPL to the OPAL, OpenH323 and PWLIB
 
22
 * programs, as long as you do follow the requirements of the GNU GPL for all
 
23
 * the rest of the software thus combined.
 
24
 */
 
25
 
 
26
 
 
27
/*
 
28
 *                         call-protocol-manager.h  -  description
 
29
 *                         ------------------------------------------
 
30
 *   begin                : written in 2008 by Damien Sandras 
 
31
 *   copyright            : (c) 2008 by Damien Sandras
 
32
 *   description          : Declaration of the interface of a call protocol manager
 
33
 *                          implementation backend. A call manager handles calls
 
34
 *                          thanks to various call protocol managers.
 
35
 *
 
36
 */
 
37
 
 
38
 
 
39
#ifndef __CALL_PROTOCOL_MANAGER_H__
 
40
#define __CALL_PROTOCOL_MANAGER_H__
 
41
 
 
42
#include <string>
 
43
 
 
44
#include <boost/smart_ptr.hpp>
 
45
 
 
46
namespace Ekiga
 
47
{
 
48
 
 
49
/**
 
50
 * @addtogroup calls
 
51
 * @{:
 
52
 */
 
53
 
 
54
  class CallProtocolManager
 
55
  {
 
56
 
 
57
    public:
 
58
    class Interface
 
59
    {
 
60
        public:
 
61
        std::string voip_protocol;
 
62
        std::string protocol;
 
63
        std::string id;
 
64
        bool publish;
 
65
        unsigned port;
 
66
    };
 
67
 
 
68
 
 
69
    /* The constructor
 
70
     */
 
71
    CallProtocolManager () {};
 
72
 
 
73
    /* The destructor
 
74
     */
 
75
    virtual ~CallProtocolManager () {};
 
76
 
 
77
 
 
78
    /*                 
 
79
     * CALL MANAGEMENT 
 
80
     */               
 
81
 
 
82
    /** Create a call based on the remote uri given as parameter
 
83
     * @param: An uri
 
84
     * @return: true if a Ekiga::Call could be created
 
85
     */
 
86
    virtual bool dial (const std::string & uri) = 0; 
 
87
 
 
88
 
 
89
    /*
 
90
     * PROTOCOL INFORMATION
 
91
     */
 
92
 
 
93
    /** Return the protocol name
 
94
     * @return the protocol name
 
95
     */
 
96
    virtual const std::string & get_protocol_name () const = 0;
 
97
 
 
98
 
 
99
    /*
 
100
     * MISC
 
101
     */
 
102
 
 
103
    /** Return the listen interface
 
104
     * @return the interface on which we are accepting calls. Generally,
 
105
     * under the form protocol:IP:port.
 
106
     */
 
107
    virtual const Interface & get_listen_interface () const = 0;
 
108
 
 
109
    /** Set the DTMF mode to use to send DTMFs
 
110
     * @param mode is the desired DTMF mode
 
111
     */
 
112
    virtual void set_dtmf_mode (unsigned mode) = 0;
 
113
 
 
114
    /** Return the current DTMF mode
 
115
     * @return the desired DTMF mode
 
116
     */
 
117
    virtual unsigned get_dtmf_mode () const = 0;
 
118
 
 
119
    /** Set the port to listen to for incoming calls
 
120
     * @param port is the port on which we should bind
 
121
     */
 
122
    virtual bool set_listen_port (unsigned port) = 0;
 
123
  };
 
124
 
 
125
/**
 
126
 * @}
 
127
 */
 
128
 
 
129
};
 
130
 
 
131
#endif