summaryrefslogtreecommitdiffstats
path: root/doc/voicecall-api.txt
blob: fb8f09925625fc9dba5a92dd8ae93cfcec1daa2c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
VoiceCall hierarchy
===================

Service		org.ofono
Interface	org.ofono.VoiceCall
Object path	[variable prefix]/{modem0,modem1,...}/{voicecall01,voicecall02,...}

Methods		dict GetProperties()

			Returns all properties for this object. See the
			properties section for available properties.

		void Deflect(string number)

			Deflects the incoming or waiting call to number given
			in the argument.  This method is only valid if the
			call is in "incoming" or "waiting" state and the
			Call Deflection supplementary service is subscribed to.

			This functionality is generally implemented by using
			the +CHLD=4 * NUMBER command.

			This method should not be confused with the Transfer()
			method.

			Possible Errors: [service].Error.InProgress
					 [service].Error.NotImplemented
					 [service].Error.InvalidArguments
					 [service].Error.InvalidFormat
					 [service].Error.Failed

		void Hangup()

			Hangs up the voice call.

			For an incoming call, the call is hung up using ATH or
			equivalent.  For a waiting call, the remote party is
			notified by using the User Determined User Busy (UDUB)
			condition.  This is generally implemented using CHLD=0.

			Please note that the GSM specification does not allow
			the release of a held call when a waiting call exists,
			or the release of a particular party in a held
			multiparty call.

			Note that releasing a held call or a particular party
			of a held multiparty call might not be possible on some
			implementations.

			NOTE: Releasing active calls does not produce
			side-effects.  That is the state of held or waiting
			calls is not affected.

			Possible Errors: [service].Error.InProgress
					 [service].Error.Failed
					 [service].Error.NotImplemented

		void Answer()

			Answers the incoming call.  Only valid if the state
			of the call is "incoming."

			This functionality is generally implemented by ATA
			AT command.

			Possible Errors: [service].Error.InProgress
					 [service].Error.Failed
					 [service].Error.NotImplemented
					 [service].Error.Failed

Signals		PropertyChanged(string property, variant value)

			Signal is emitted whenever a property has changed.
			The new value is passed as the signal argument.

		DisconnectReason(string reason)

			This signal is emitted when the modem manager can
			provide extra information about why this call was
			released. The possible reason values are:
				"local" - The call was release due to local
						user action
				"remote" - Remote party released the call
				"network" - Network released the call, most
						likely due to low signal or
						other network failure

			Not all implementations are able to provide this
			information, so applications should treat the emission
			of this signal as optional. This signal will be
			emitted before the PropertyChanged signal.

Properties	string LineIdentification [readonly]

			Contains the Line Identification information returned
			by the network, if present. For incoming calls this is
			effectively the CLIP. For outgoing calls this attribute
			will hold the dialed number, or the COLP if received by
			the underlying implementation.

			Please note that COLP may be different from the
			dialed number. A special "withheld" value means the
			remote party refused to provide caller ID and the
			"override category" option was not provisioned for
			the current subscriber.

		string IncomingLine [readonly, optional]

			Contains the Called Line Identification information
			returned by the network. This is only available for
			incoming calls and indicates the local subscriber
			number which was dialed by the remote party. This is
			useful for subscribers which have a multiple line
			service with their network provider and would like
			to know what line the call is coming in on.

		string Name [readonly]

			Contains the Name Identification information returned
			by the network, if present.

		boolean Multiparty [readonly]

			Contains the indication if the voice call is part
			of a multiparty call or not.

			Notifications if a call becomes part or leaves a
			multipart call are sent.

		string State [readonly]

			Contains the state of the current call.  The state
			can be one of:
				- "active" - The call is active
				- "held" - The call is on hold
				- "dialing" - The call is being dialed
				- "alerting" - The remote party is being alerted
				- "incoming" - Incoming call in progress
				- "waiting" - Call is waiting
				- "disconnected" - No further use of this object
					is allowed, it will be destroyed shortly

		string StartTime [readonly, optional]

			Contains the starting time of the call.  The time is
			stamped when the call enters the "active" state.
			Client applications can use this to infer somewhat
			reliable call duration information.

		string Information [readonly, optional]

			Contains information related to the call for the
			user.  Currently this property is set for calls
			initiated by SIM Toolkit applications.

		byte Icon [readonly, optional]

			Icon identifier to be used instead of or together
			with the text information.

		boolean Emergency [readonly]

			Contains the indication if the voice call is an
			emergency call or not.

		boolean RemoteHeld [experimental]

			Contains the indication whether the voice call is put
			on hold by the remote party or not.

		boolean RemoteMultiparty [experimental]

			Contains the indication whether the voice call is
			joined in a multiparty call by the remote party or not.