1 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
5 <title>gsignond API Reference Manual: GSignondExtension</title>
6 <meta name="generator" content="DocBook XSL Stylesheets V1.78.1">
7 <link rel="home" href="index.html" title="gsignond API Reference Manual">
8 <link rel="up" href="ch06.html" title="GSignond API for writing platform adaptation extensions">
9 <link rel="prev" href="ch06.html" title="GSignond API for writing platform adaptation extensions">
10 <link rel="next" href="GSignondAccessControlManager.html" title="GSignondAccessControlManager">
11 <meta name="generator" content="GTK-Doc V1.20 (XML mode)">
12 <link rel="stylesheet" href="style.css" type="text/css">
14 <body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
15 <table class="navigation" id="top" width="100%" summary="Navigation header" cellpadding="2" cellspacing="10"><tr valign="middle">
16 <td width="100%" align="left" class="shortcuts">
17 <a href="#" class="shortcut">Top</a><span id="nav_description"> <span class="dim">|</span>
18 <a href="#GSignondExtension.description" class="shortcut">Description</a></span><span id="nav_hierarchy"> <span class="dim">|</span>
19 <a href="#GSignondExtension.object-hierarchy" class="shortcut">Object Hierarchy</a></span>
21 <td><a accesskey="h" href="index.html"><img src="home.png" width="16" height="16" border="0" alt="Home"></a></td>
22 <td><a accesskey="u" href="ch06.html"><img src="up.png" width="16" height="16" border="0" alt="Up"></a></td>
23 <td><a accesskey="p" href="ch06.html"><img src="left.png" width="16" height="16" border="0" alt="Prev"></a></td>
24 <td><a accesskey="n" href="GSignondAccessControlManager.html"><img src="right.png" width="16" height="16" border="0" alt="Next"></a></td>
26 <div class="refentry">
27 <a name="GSignondExtension"></a><div class="titlepage"></div>
28 <div class="refnamediv"><table width="100%"><tr>
30 <h2><span class="refentrytitle"><a name="GSignondExtension.top_of_page"></a>GSignondExtension</span></h2>
31 <p>GSignondExtension — provides platform adaptation functionality</p>
33 <td class="gallery_image" valign="top" align="right"></td>
35 <div class="refsect1">
36 <a name="GSignondExtension.functions"></a><h2>Functions</h2>
37 <div class="informaltable"><table width="100%" border="0">
39 <col width="150px" class="functions_return">
40 <col class="functions_name">
44 <td class="function_type">const <a href="http://library.gnome.org/devel/glib/unstable/glib-Basic-Types.html#gchar"><span class="returnvalue">gchar</span></a> *
46 <td class="function_name">
47 <a class="link" href="GSignondExtension.html#gsignond-extension-get-name" title="gsignond_extension_get_name ()">gsignond_extension_get_name</a> <span class="c_punctuation">()</span>
51 <td class="function_type">
52 <span class="returnvalue">guint32</span>
54 <td class="function_name">
55 <a class="link" href="GSignondExtension.html#gsignond-extension-get-version" title="gsignond_extension_get_version ()">gsignond_extension_get_version</a> <span class="c_punctuation">()</span>
59 <td class="function_type">
60 <a class="link" href="GSignondStorageManager.html" title="GSignondStorageManager"><span class="returnvalue">GSignondStorageManager</span></a> *
62 <td class="function_name">
63 <a class="link" href="GSignondExtension.html#gsignond-extension-get-storage-manager" title="gsignond_extension_get_storage_manager ()">gsignond_extension_get_storage_manager</a> <span class="c_punctuation">()</span>
67 <td class="function_type">
68 <a class="link" href="GSignondSecretStorage.html" title="GSignondSecretStorage"><span class="returnvalue">GSignondSecretStorage</span></a> *
70 <td class="function_name">
71 <a class="link" href="GSignondExtension.html#gsignond-extension-get-secret-storage" title="gsignond_extension_get_secret_storage ()">gsignond_extension_get_secret_storage</a> <span class="c_punctuation">()</span>
75 <td class="function_type">
76 <a class="link" href="GSignondAccessControlManager.html" title="GSignondAccessControlManager"><span class="returnvalue">GSignondAccessControlManager</span></a> *
78 <td class="function_name">
79 <a class="link" href="GSignondExtension.html#gsignond-extension-get-access-control-manager" title="gsignond_extension_get_access_control_manager ()">gsignond_extension_get_access_control_manager</a> <span class="c_punctuation">()</span>
85 <div class="refsect1">
86 <a name="GSignondExtension.object-hierarchy"></a><h2>Object Hierarchy</h2>
87 <pre class="screen"> <a href="http://library.gnome.org/devel/gobject/unstable/gobject-The-Base-Object-Type.html#GObject">GObject</a>
88 <span class="lineart">╰──</span> GSignondExtension
91 <div class="refsect1">
92 <a name="GSignondExtension.includes"></a><h2>Includes</h2>
93 <pre class="synopsis">#include <gsignond/gsignond-plugin-interface.h>
96 <div class="refsect1">
97 <a name="GSignondExtension.description"></a><h2>Description</h2>
98 <p><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> provides access to platform adaptation functionality. It
99 contains getter methods for default implementations of <a class="link" href="GSignondAccessControlManager.html" title="GSignondAccessControlManager"><span class="type">GSignondAccessControlManager</span></a>,
100 <a class="link" href="GSignondSecretStorage.html" title="GSignondSecretStorage"><span class="type">GSignondSecretStorage</span></a> and <a class="link" href="GSignondStorageManager.html" title="GSignondStorageManager"><span class="type">GSignondStorageManager</span></a>.</p>
101 <p>gSSO can be adapted to a specific platform environment by implementing a
102 custom extension module. The following steps need to be taken:</p>
103 <p>a) subclass and re-implement some (or all) of the functionality of the above
105 <p>b) subclass <a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> and provide implementations of its getter methods for those
106 of the adaptation classes that have been changed.</p>
107 <p>d) provide a function <code class="function">GSignondExtension * extensionname_extension_init(void)</code>
108 that returns an instance of the <a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> subclass.</p>
109 <p>c) build and install these implementations as a gSSO extension module and
110 configure gSSO to use it.</p>
111 <p>Examples of custom extensions can be seen here:</p>
112 <a class="ulink" href="https://code.google.com/p/accounts-sso/source/browse/?repo=gsignond#git%2Fsrc%2Fextensions" target="_top">
113 https://code.google.com/p/accounts-sso/source/browse/?repo=gsignond#git%2Fsrc%2Fextensions</a><p>and gSSO configuration is described in <a class="link" href="GSignondConfig.html" title="GSignondConfig"><span class="type">GSignondConfig</span></a>.</p>
115 <div class="refsect1">
116 <a name="GSignondExtension.functions_details"></a><h2>Functions</h2>
117 <div class="refsect2">
118 <a name="gsignond-extension-get-name"></a><h3>gsignond_extension_get_name ()</h3>
119 <pre class="programlisting">const <a href="http://library.gnome.org/devel/glib/unstable/glib-Basic-Types.html#gchar"><span class="returnvalue">gchar</span></a> *
120 gsignond_extension_get_name (<em class="parameter"><code><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> *self</code></em>);</pre>
121 <p>Get a human readable name of the extension. Default implementation
122 returns "default".</p>
123 <div class="refsect3">
124 <a name="id-1.7.2.7.2.5"></a><h4>Parameters</h4>
125 <div class="informaltable"><table width="100%" border="0">
127 <col width="150px" class="parameters_name">
128 <col class="parameters_description">
129 <col width="200px" class="parameters_annotations">
132 <td class="parameter_name"><p>self</p></td>
133 <td class="parameter_description"><p>object instance.</p></td>
134 <td class="parameter_annotations"> </td>
138 <div class="refsect3">
139 <a name="id-1.7.2.7.2.6"></a><h4>Returns</h4>
140 <p> name of the extension. </p>
141 <p><span class="annotation">[<acronym title="Don't free data after the code is done."><span class="acronym">transfer none</span></acronym>]</span></p>
145 <div class="refsect2">
146 <a name="gsignond-extension-get-version"></a><h3>gsignond_extension_get_version ()</h3>
147 <pre class="programlisting"><span class="returnvalue">guint32</span>
148 gsignond_extension_get_version (<em class="parameter"><code><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> *self</code></em>);</pre>
149 <p>Get version of the extension, split into four bytes in order from MSB to LSB;
150 major, minor, patchlevel, build. Default implementation returns 0.</p>
151 <div class="refsect3">
152 <a name="id-1.7.2.7.3.5"></a><h4>Parameters</h4>
153 <div class="informaltable"><table width="100%" border="0">
155 <col width="150px" class="parameters_name">
156 <col class="parameters_description">
157 <col width="200px" class="parameters_annotations">
160 <td class="parameter_name"><p>self</p></td>
161 <td class="parameter_description"><p>object instance.</p></td>
162 <td class="parameter_annotations"> </td>
168 <div class="refsect2">
169 <a name="gsignond-extension-get-storage-manager"></a><h3>gsignond_extension_get_storage_manager ()</h3>
170 <pre class="programlisting"><a class="link" href="GSignondStorageManager.html" title="GSignondStorageManager"><span class="returnvalue">GSignondStorageManager</span></a> *
171 gsignond_extension_get_storage_manager
172 (<em class="parameter"><code><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> *self</code></em>,
173 <em class="parameter"><code><a class="link" href="GSignondConfig.html" title="GSignondConfig"><span class="type">GSignondConfig</span></a> *config</code></em>);</pre>
174 <p>Factory method to get a singleton storage manager object. See
175 <a class="link" href="GSignondStorageManager.html" title="GSignondStorageManager"><span class="type">GSignondStorageManager</span></a> for the description of the default implementation.</p>
176 <div class="refsect3">
177 <a name="id-1.7.2.7.4.5"></a><h4>Parameters</h4>
178 <div class="informaltable"><table width="100%" border="0">
180 <col width="150px" class="parameters_name">
181 <col class="parameters_description">
182 <col width="200px" class="parameters_annotations">
186 <td class="parameter_name"><p>self</p></td>
187 <td class="parameter_description"><p>object instance.</p></td>
188 <td class="parameter_annotations"> </td>
191 <td class="parameter_name"><p>config</p></td>
192 <td class="parameter_description"><p>configuration object instance.</p></td>
193 <td class="parameter_annotations"> </td>
198 <div class="refsect3">
199 <a name="id-1.7.2.7.4.6"></a><h4>Returns</h4>
200 <p> storage manager object instance. </p>
201 <p><span class="annotation">[<acronym title="Don't free data after the code is done."><span class="acronym">transfer none</span></acronym>]</span></p>
205 <div class="refsect2">
206 <a name="gsignond-extension-get-secret-storage"></a><h3>gsignond_extension_get_secret_storage ()</h3>
207 <pre class="programlisting"><a class="link" href="GSignondSecretStorage.html" title="GSignondSecretStorage"><span class="returnvalue">GSignondSecretStorage</span></a> *
208 gsignond_extension_get_secret_storage (<em class="parameter"><code><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> *self</code></em>,
209 <em class="parameter"><code><a class="link" href="GSignondConfig.html" title="GSignondConfig"><span class="type">GSignondConfig</span></a> *config</code></em>);</pre>
210 <p>Factory method to get a singleton secret storage object. See
211 <a class="link" href="GSignondSecretStorage.html" title="GSignondSecretStorage"><span class="type">GSignondSecretStorage</span></a> for the description of the default implementation.</p>
212 <div class="refsect3">
213 <a name="id-1.7.2.7.5.5"></a><h4>Parameters</h4>
214 <div class="informaltable"><table width="100%" border="0">
216 <col width="150px" class="parameters_name">
217 <col class="parameters_description">
218 <col width="200px" class="parameters_annotations">
222 <td class="parameter_name"><p>self</p></td>
223 <td class="parameter_description"><p>object instance.</p></td>
224 <td class="parameter_annotations"> </td>
227 <td class="parameter_name"><p>config</p></td>
228 <td class="parameter_description"><p>configuration object instance.</p></td>
229 <td class="parameter_annotations"> </td>
234 <div class="refsect3">
235 <a name="id-1.7.2.7.5.6"></a><h4>Returns</h4>
236 <p> secret storage object instance. </p>
237 <p><span class="annotation">[<acronym title="Don't free data after the code is done."><span class="acronym">transfer none</span></acronym>]</span></p>
241 <div class="refsect2">
242 <a name="gsignond-extension-get-access-control-manager"></a><h3>gsignond_extension_get_access_control_manager ()</h3>
243 <pre class="programlisting"><a class="link" href="GSignondAccessControlManager.html" title="GSignondAccessControlManager"><span class="returnvalue">GSignondAccessControlManager</span></a> *
244 gsignond_extension_get_access_control_manager
245 (<em class="parameter"><code><a class="link" href="GSignondExtension.html" title="GSignondExtension"><span class="type">GSignondExtension</span></a> *self</code></em>,
246 <em class="parameter"><code><a class="link" href="GSignondConfig.html" title="GSignondConfig"><span class="type">GSignondConfig</span></a> *config</code></em>);</pre>
247 <p>Factory method to get a singleton access control manager object. See
248 <a class="link" href="GSignondAccessControlManager.html" title="GSignondAccessControlManager"><span class="type">GSignondAccessControlManager</span></a> for the description of the default implementation.</p>
249 <div class="refsect3">
250 <a name="id-1.7.2.7.6.5"></a><h4>Parameters</h4>
251 <div class="informaltable"><table width="100%" border="0">
253 <col width="150px" class="parameters_name">
254 <col class="parameters_description">
255 <col width="200px" class="parameters_annotations">
259 <td class="parameter_name"><p>self</p></td>
260 <td class="parameter_description"><p>object instance.</p></td>
261 <td class="parameter_annotations"> </td>
264 <td class="parameter_name"><p>config</p></td>
265 <td class="parameter_description"><p>configuration object instance.</p></td>
266 <td class="parameter_annotations"> </td>
271 <div class="refsect3">
272 <a name="id-1.7.2.7.6.6"></a><h4>Returns</h4>
273 <p> access control manager object instance. </p>
274 <p><span class="annotation">[<acronym title="Don't free data after the code is done."><span class="acronym">transfer none</span></acronym>]</span></p>
278 <div class="refsect1">
279 <a name="GSignondExtension.other_details"></a><h2>Types and Values</h2>
284 Generated by GTK-Doc V1.20</div>