~noskcaj/ubuntu/vivid/gnome-keyring/3.15.90

« back to all changes in this revision

Viewing changes to gcr/gcr-certificate-renderer.c

  • Committer: Package Import Robot
  • Author(s): Jordi Mallach
  • Date: 2012-05-14 22:13:02 UTC
  • mfrom: (1.3.1)
  • mto: (80.2.8 experimental) (1.1.77)
  • mto: This revision was merged to the branch mainline in revision 148.
  • Revision ID: package-import@ubuntu.com-20120514221302-0l3gjmqpe6xopond
ImportĀ upstreamĀ versionĀ 3.4.1

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * Copyright (C) 2010 Stefan Walter
3
 
 *
4
 
 * This program is free software; you can redistribute it and/or modify
5
 
 * it under the terms of the GNU Lesser General Public License as
6
 
 * published by the Free Software Foundation; either version 2.1 of
7
 
 * the License, or (at your option) any later version.
8
 
 *
9
 
 * This program is distributed in the hope that it will be useful, but
10
 
 * WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12
 
 * Lesser General Public License for more details.
13
 
 *
14
 
 * You should have received a copy of the GNU Lesser General Public
15
 
 * License along with this program; if not, write to the Free Software
16
 
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
17
 
 * 02111-1307, USA.
18
 
 */
19
 
 
20
 
#include "config.h"
21
 
 
22
 
#include "gcr-certificate.h"
23
 
#include "gcr-certificate-renderer.h"
24
 
#include "gcr-display-view.h"
25
 
#include "gcr-icons.h"
26
 
#include "gcr-simple-certificate.h"
27
 
#include "gcr-renderer.h"
28
 
 
29
 
#include "egg/egg-asn1x.h"
30
 
#include "egg/egg-asn1-defs.h"
31
 
#include "egg/egg-dn.h"
32
 
#include "egg/egg-oid.h"
33
 
#include "egg/egg-hex.h"
34
 
 
35
 
#include "gck/gck.h"
36
 
 
37
 
#include <gdk/gdk.h>
38
 
#include <glib/gi18n-lib.h>
39
 
 
40
 
enum {
41
 
        PROP_0,
42
 
        PROP_CERTIFICATE,
43
 
        PROP_LABEL,
44
 
        PROP_ATTRIBUTES
45
 
};
46
 
 
47
 
struct _GcrCertificateRendererPrivate {
48
 
        GcrCertificate *certificate;
49
 
        GckAttributes *attributes;
50
 
        guint key_size;
51
 
        gchar *label;
52
 
};
53
 
 
54
 
static void gcr_renderer_iface_init (GcrRendererIface *iface);
55
 
 
56
 
G_DEFINE_TYPE_WITH_CODE (GcrCertificateRenderer, gcr_certificate_renderer, G_TYPE_OBJECT,
57
 
                         G_IMPLEMENT_INTERFACE (GCR_TYPE_RENDERER, gcr_renderer_iface_init));
58
 
 
59
 
/* -----------------------------------------------------------------------------
60
 
 * INTERNAL
61
 
 */
62
 
 
63
 
static gchar*
64
 
calculate_label (GcrCertificateRenderer *self, GNode *asn)
65
 
{
66
 
        gchar *label;
67
 
 
68
 
        if (self->pv->label)
69
 
                return g_strdup (self->pv->label);
70
 
 
71
 
        if (self->pv->attributes) {
72
 
                if (gck_attributes_find_string (self->pv->attributes, CKA_LABEL, &label))
73
 
                        return label;
74
 
        }
75
 
 
76
 
        if (asn != NULL) {
77
 
                label = egg_dn_read_part (egg_asn1x_node (asn, "tbsCertificate", "subject", "rdnSequence", NULL), "CN");
78
 
                if (label != NULL)
79
 
                        return label;
80
 
        }
81
 
 
82
 
        return g_strdup (_("Certificate"));
83
 
}
84
 
 
85
 
static gboolean
86
 
append_extension (GcrCertificateRenderer *self, GcrDisplayView *view,
87
 
                  GNode *asn, const guchar *data, gsize n_data, gint index)
88
 
{
89
 
        GcrRenderer *renderer = GCR_RENDERER (self);
90
 
        GNode *node;
91
 
        GQuark oid;
92
 
        gchar *display;
93
 
        gsize n_value;
94
 
        const guchar *value;
95
 
        const gchar *text;
96
 
        gboolean critical;
97
 
 
98
 
        /* Make sure it is present */
99
 
        node = egg_asn1x_node (asn, "tbsCertificate", "extensions", index, NULL);
100
 
        if (node == NULL)
101
 
                return FALSE;
102
 
 
103
 
        /* Dig out the OID */
104
 
        oid = egg_asn1x_get_oid_as_quark (egg_asn1x_node (node, "extnID", NULL));
105
 
        g_return_val_if_fail (oid, FALSE);
106
 
 
107
 
        _gcr_display_view_append_heading (view, renderer, _("Extension"));
108
 
 
109
 
 
110
 
        /* Extension type */
111
 
        text = egg_oid_get_description (oid);
112
 
        _gcr_display_view_append_value (view, renderer, _("Identifier"), text, FALSE);
113
 
 
114
 
 
115
 
        /* Extension value */
116
 
        value = egg_asn1x_get_raw_value (egg_asn1x_node (node, "extnValue", NULL), &n_value);
117
 
 
118
 
        /* TODO: Parsing of extensions that we understand */
119
 
        display = egg_hex_encode_full (value, n_value, TRUE, ' ', 1);
120
 
        _gcr_display_view_append_value (view, renderer, _("Value"), display, TRUE);
121
 
        g_free (display);
122
 
 
123
 
 
124
 
        /* Critical */
125
 
        if (egg_asn1x_get_boolean (egg_asn1x_node (node, "critical", NULL), &critical))
126
 
                _gcr_display_view_append_value (view, renderer, _("Critical"), critical ? _("Yes") : _("No"), FALSE);
127
 
 
128
 
        return TRUE;
129
 
}
130
 
 
131
 
typedef struct _on_parsed_dn_args {
132
 
        GcrCertificateRenderer *renderer;
133
 
        GcrDisplayView *view;
134
 
} on_parsed_dn_args;
135
 
 
136
 
static void
137
 
on_parsed_dn_part (guint index, GQuark oid, const guchar *value,
138
 
                   gsize n_value, gpointer user_data)
139
 
{
140
 
        GcrCertificateRenderer *self = ((on_parsed_dn_args*)user_data)->renderer;
141
 
        GcrDisplayView *view = ((on_parsed_dn_args*)user_data)->view;
142
 
        const gchar *attr;
143
 
        const gchar *desc;
144
 
        gchar *field;
145
 
        gchar *display;
146
 
 
147
 
        g_return_if_fail (GCR_IS_CERTIFICATE_RENDERER (self));
148
 
 
149
 
        attr = egg_oid_get_name (oid);
150
 
        desc = egg_oid_get_description (oid);
151
 
 
152
 
        /* Combine them into something sane */
153
 
        if (attr && desc) {
154
 
                if (strcmp (attr, desc) == 0)
155
 
                        field = g_strdup (attr);
156
 
                else
157
 
                        field = g_strdup_printf ("%s (%s)", attr, desc);
158
 
        } else if (!attr && !desc) {
159
 
                field = g_strdup ("");
160
 
        } else if (attr) {
161
 
                field = g_strdup (attr);
162
 
        } else if (desc) {
163
 
                field = g_strdup (desc);
164
 
        } else {
165
 
                g_assert_not_reached ();
166
 
        }
167
 
 
168
 
        display = egg_dn_print_value (oid, value, n_value);
169
 
        if (display == NULL)
170
 
                display = g_strdup ("");
171
 
 
172
 
        _gcr_display_view_append_value (view, GCR_RENDERER (self), field, display, FALSE);
173
 
        g_free (field);
174
 
        g_free (display);
175
 
}
176
 
 
177
 
/* -----------------------------------------------------------------------------
178
 
 * OBJECT
179
 
 */
180
 
 
181
 
static void
182
 
gcr_certificate_renderer_init (GcrCertificateRenderer *self)
183
 
{
184
 
        self->pv = (G_TYPE_INSTANCE_GET_PRIVATE (self, GCR_TYPE_CERTIFICATE_RENDERER, GcrCertificateRendererPrivate));
185
 
}
186
 
 
187
 
static void
188
 
gcr_certificate_renderer_dispose (GObject *obj)
189
 
{
190
 
        GcrCertificateRenderer *self = GCR_CERTIFICATE_RENDERER (obj);
191
 
 
192
 
        if (self->pv->certificate)
193
 
                g_object_unref (self->pv->certificate);
194
 
        self->pv->certificate = NULL;
195
 
 
196
 
        G_OBJECT_CLASS (gcr_certificate_renderer_parent_class)->dispose (obj);
197
 
}
198
 
 
199
 
static void
200
 
gcr_certificate_renderer_finalize (GObject *obj)
201
 
{
202
 
        GcrCertificateRenderer *self = GCR_CERTIFICATE_RENDERER (obj);
203
 
 
204
 
        g_assert (!self->pv->certificate);
205
 
 
206
 
        if (self->pv->attributes)
207
 
                gck_attributes_unref (self->pv->attributes);
208
 
        self->pv->attributes = NULL;
209
 
 
210
 
        g_free (self->pv->label);
211
 
        self->pv->label = NULL;
212
 
 
213
 
        G_OBJECT_CLASS (gcr_certificate_renderer_parent_class)->finalize (obj);
214
 
}
215
 
 
216
 
static void
217
 
gcr_certificate_renderer_set_property (GObject *obj, guint prop_id, const GValue *value,
218
 
                                     GParamSpec *pspec)
219
 
{
220
 
        GcrCertificateRenderer *self = GCR_CERTIFICATE_RENDERER (obj);
221
 
 
222
 
        switch (prop_id) {
223
 
        case PROP_CERTIFICATE:
224
 
                gcr_certificate_renderer_set_certificate (self, g_value_get_object (value));
225
 
                break;
226
 
        case PROP_LABEL:
227
 
                g_free (self->pv->label);
228
 
                self->pv->label = g_value_dup_string (value);
229
 
                g_object_notify (obj, "label");
230
 
                gcr_renderer_emit_data_changed (GCR_RENDERER (self));
231
 
                break;
232
 
        case PROP_ATTRIBUTES:
233
 
                gcr_certificate_renderer_set_attributes (self, g_value_get_boxed (value));
234
 
                break;
235
 
        default:
236
 
                G_OBJECT_WARN_INVALID_PROPERTY_ID (obj, prop_id, pspec);
237
 
                break;
238
 
        }
239
 
}
240
 
 
241
 
static void
242
 
gcr_certificate_renderer_get_property (GObject *obj, guint prop_id, GValue *value,
243
 
                                     GParamSpec *pspec)
244
 
{
245
 
        GcrCertificateRenderer *self = GCR_CERTIFICATE_RENDERER (obj);
246
 
 
247
 
        switch (prop_id) {
248
 
        case PROP_CERTIFICATE:
249
 
                g_value_set_object (value, self->pv->certificate);
250
 
                break;
251
 
        case PROP_LABEL:
252
 
                g_value_take_string (value, calculate_label (self, NULL));
253
 
                break;
254
 
        case PROP_ATTRIBUTES:
255
 
                g_value_set_boxed (value, self->pv->attributes);
256
 
                break;
257
 
        default:
258
 
                G_OBJECT_WARN_INVALID_PROPERTY_ID (obj, prop_id, pspec);
259
 
                break;
260
 
        }
261
 
}
262
 
 
263
 
static void
264
 
gcr_certificate_renderer_class_init (GcrCertificateRendererClass *klass)
265
 
{
266
 
        GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
267
 
        GckAttributes *registered;
268
 
 
269
 
        gcr_certificate_renderer_parent_class = g_type_class_peek_parent (klass);
270
 
        g_type_class_add_private (klass, sizeof (GcrCertificateRendererPrivate));
271
 
 
272
 
        gobject_class->dispose = gcr_certificate_renderer_dispose;
273
 
        gobject_class->finalize = gcr_certificate_renderer_finalize;
274
 
        gobject_class->set_property = gcr_certificate_renderer_set_property;
275
 
        gobject_class->get_property = gcr_certificate_renderer_get_property;
276
 
 
277
 
        g_object_class_install_property (gobject_class, PROP_CERTIFICATE,
278
 
                   g_param_spec_object("certificate", "Certificate", "Certificate to display.",
279
 
                                       GCR_TYPE_CERTIFICATE, G_PARAM_READWRITE));
280
 
 
281
 
        g_object_class_override_property (gobject_class, PROP_LABEL, "label");
282
 
        g_object_class_override_property (gobject_class, PROP_ATTRIBUTES, "attributes");
283
 
 
284
 
        _gcr_icons_register ();
285
 
 
286
 
        /* Register this as a renderer which can be loaded */
287
 
        registered = gck_attributes_new ();
288
 
        gck_attributes_add_ulong (registered, CKA_CLASS, CKO_CERTIFICATE);
289
 
        gcr_renderer_register (GCR_TYPE_CERTIFICATE_RENDERER, registered);
290
 
        gck_attributes_unref (registered);
291
 
}
292
 
 
293
 
static void
294
 
gcr_certificate_renderer_real_render (GcrRenderer *renderer, GcrViewer *viewer)
295
 
{
296
 
        GcrCertificateRenderer *self;
297
 
        gconstpointer data, value;
298
 
        gsize n_data, n_value, n_raw;
299
 
        GcrDisplayView *view;
300
 
        on_parsed_dn_args args;
301
 
        const gchar *text;
302
 
        gpointer raw;
303
 
        gulong version;
304
 
        guint bits, index;
305
 
        gchar *display;
306
 
        GNode *asn;
307
 
        GQuark oid;
308
 
        GDate date;
309
 
 
310
 
        self = GCR_CERTIFICATE_RENDERER (renderer);
311
 
 
312
 
        if (GCR_IS_DISPLAY_VIEW (viewer)) {
313
 
                view = GCR_DISPLAY_VIEW (viewer);
314
 
 
315
 
        } else {
316
 
                g_warning ("GcrCertificateRenderer only works with internal specific "
317
 
                           "GcrViewer returned by gcr_viewer_new().");
318
 
                return;
319
 
        }
320
 
 
321
 
        _gcr_display_view_clear (view, renderer);
322
 
 
323
 
        if (!self->pv->certificate)
324
 
                return;
325
 
 
326
 
        _gcr_display_view_set_stock_image (view, GCR_RENDERER (self), GCR_ICON_CERTIFICATE);
327
 
 
328
 
        data = gcr_certificate_get_der_data (self->pv->certificate, &n_data);
329
 
        g_return_if_fail (data);
330
 
 
331
 
        asn = egg_asn1x_create_and_decode (pkix_asn1_tab, "Certificate", data, n_data);
332
 
        g_return_if_fail (asn);
333
 
 
334
 
        display = calculate_label (self, asn);
335
 
        _gcr_display_view_append_title (view, renderer, display);
336
 
        g_free (display);
337
 
 
338
 
        display = egg_dn_read_part (egg_asn1x_node (asn, "tbsCertificate", "subject", "rdnSequence", NULL), "CN");
339
 
        _gcr_display_view_append_content (view, renderer, _("Identity"), display);
340
 
        g_free (display);
341
 
 
342
 
        display = egg_dn_read_part (egg_asn1x_node (asn, "tbsCertificate", "issuer", "rdnSequence", NULL), "CN");
343
 
        _gcr_display_view_append_content (view, renderer, _("Verified by"), display);
344
 
        g_free (display);
345
 
 
346
 
        if (egg_asn1x_get_time_as_date (egg_asn1x_node (asn, "tbsCertificate", "validity", "notAfter", NULL), &date)) {
347
 
                display = g_malloc0 (128);
348
 
                if (!g_date_strftime (display, 128, "%x", &date))
349
 
                        g_return_if_reached ();
350
 
                _gcr_display_view_append_content (view, renderer, _("Expires"), display);
351
 
                g_free (display);
352
 
        }
353
 
 
354
 
        _gcr_display_view_start_details (view, renderer);
355
 
 
356
 
        args.renderer = self;
357
 
        args.view = view;
358
 
 
359
 
        /* The subject */
360
 
        _gcr_display_view_append_heading (view, renderer, _("Subject Name"));
361
 
        egg_dn_parse (egg_asn1x_node (asn, "tbsCertificate", "subject", "rdnSequence", NULL), on_parsed_dn_part, &args);
362
 
 
363
 
        /* The Issuer */
364
 
        _gcr_display_view_append_heading (view, renderer, _("Issuer Name"));
365
 
        egg_dn_parse (egg_asn1x_node (asn, "tbsCertificate", "issuer", "rdnSequence", NULL), on_parsed_dn_part, &args);
366
 
 
367
 
        /* The Issued Parameters */
368
 
        _gcr_display_view_append_heading (view, renderer, _("Issued Certificate"));
369
 
 
370
 
        if (!egg_asn1x_get_integer_as_ulong (egg_asn1x_node (asn, "tbsCertificate", "version", NULL), &version))
371
 
                g_return_if_reached ();
372
 
        display = g_strdup_printf ("%lu", version + 1);
373
 
        _gcr_display_view_append_value (view, renderer, _("Version"), display, FALSE);
374
 
        g_free (display);
375
 
 
376
 
        raw = egg_asn1x_get_integer_as_raw (egg_asn1x_node (asn, "tbsCertificate", "serialNumber", NULL), NULL, &n_raw);
377
 
        g_return_if_fail (raw);
378
 
        display = egg_hex_encode_full (raw, n_raw, TRUE, ' ', 1);
379
 
        _gcr_display_view_append_value (view, renderer, _("Serial Number"), display, TRUE);
380
 
        g_free (display);
381
 
        g_free (raw);
382
 
 
383
 
        display = g_malloc0 (128);
384
 
        if (egg_asn1x_get_time_as_date (egg_asn1x_node (asn, "tbsCertificate", "validity", "notBefore", NULL), &date)) {
385
 
                if (!g_date_strftime (display, 128, "%Y-%m-%d", &date))
386
 
                        g_return_if_reached ();
387
 
                _gcr_display_view_append_value (view, renderer, _("Not Valid Before"), display, FALSE);
388
 
        }
389
 
        if (egg_asn1x_get_time_as_date (egg_asn1x_node (asn, "tbsCertificate", "validity", "notAfter", NULL), &date)) {
390
 
                if (!g_date_strftime (display, 128, "%Y-%m-%d", &date))
391
 
                        g_return_if_reached ();
392
 
                _gcr_display_view_append_value (view, renderer, _("Not Valid After"), display, FALSE);
393
 
        }
394
 
        g_free (display);
395
 
 
396
 
        /* Signature */
397
 
        _gcr_display_view_append_heading (view, renderer, ("Signature"));
398
 
 
399
 
        oid = egg_asn1x_get_oid_as_quark (egg_asn1x_node (asn, "signatureAlgorithm", "algorithm", NULL));
400
 
        text = egg_oid_get_description (oid);
401
 
        _gcr_display_view_append_value (view, renderer, _("Signature Algorithm"), text, FALSE);
402
 
 
403
 
        value = egg_asn1x_get_raw_element (egg_asn1x_node (asn, "signatureAlgorithm", "parameters", NULL), &n_value);
404
 
        if (value && n_value) {
405
 
                display = egg_hex_encode_full (value, n_value, TRUE, ' ', 1);
406
 
                _gcr_display_view_append_value (view, renderer, _("Signature Parameters"), display, TRUE);
407
 
                g_free (display);
408
 
        }
409
 
 
410
 
        raw = egg_asn1x_get_bits_as_raw (egg_asn1x_node (asn, "signature", NULL), NULL, &bits);
411
 
        g_return_if_fail (raw);
412
 
        display = egg_hex_encode_full (raw, bits / 8, TRUE, ' ', 1);
413
 
        _gcr_display_view_append_value (view, renderer, _("Signature"), display, TRUE);
414
 
        g_free (display);
415
 
        g_free (raw);
416
 
 
417
 
        /* Public Key Info */
418
 
        _gcr_display_view_append_heading (view, renderer, _("Public Key Info"));
419
 
 
420
 
        oid = egg_asn1x_get_oid_as_quark (egg_asn1x_node (asn, "tbsCertificate", "subjectPublicKeyInfo",
421
 
                                                          "algorithm", "algorithm", NULL));
422
 
        text = egg_oid_get_description (oid);
423
 
        _gcr_display_view_append_value (view, renderer, _("Key Algorithm"), text, FALSE);
424
 
 
425
 
        value = egg_asn1x_get_raw_element (egg_asn1x_node (asn, "tbsCertificate", "subjectPublicKeyInfo",
426
 
                                                           "algorithm", "parameters", NULL), &n_value);
427
 
        if (value && n_value) {
428
 
                display = egg_hex_encode_full (value, n_value, TRUE, ' ', 1);
429
 
                _gcr_display_view_append_value (view, renderer, _("Key Parameters"), display, TRUE);
430
 
                g_free (display);
431
 
        }
432
 
 
433
 
        bits = gcr_certificate_get_key_size (self->pv->certificate);
434
 
        if (bits > 0) {
435
 
                display = g_strdup_printf ("%u", bits);
436
 
                _gcr_display_view_append_value (view, renderer, _("Key Size"), display, FALSE);
437
 
                g_free (display);
438
 
        }
439
 
 
440
 
        raw = egg_asn1x_get_bits_as_raw (egg_asn1x_node (asn, "tbsCertificate", "subjectPublicKeyInfo",
441
 
                                                         "subjectPublicKey", NULL), NULL, &bits);
442
 
        g_return_if_fail (raw);
443
 
        display = egg_hex_encode_full (raw, bits / 8, TRUE, ' ', 1);
444
 
        _gcr_display_view_append_value (view, renderer, _("Public Key"), display, TRUE);
445
 
        g_free (display);
446
 
        g_free (raw);
447
 
 
448
 
        /* Fingerprints */
449
 
        _gcr_display_view_append_heading (view, renderer, _("Fingerprints"));
450
 
 
451
 
        _gcr_display_view_append_fingerprint (view, renderer, data, n_data, "SHA1", G_CHECKSUM_SHA1);
452
 
        _gcr_display_view_append_fingerprint (view, renderer, data, n_data, "MD5", G_CHECKSUM_MD5);
453
 
 
454
 
        /* Extensions */
455
 
        for (index = 1; TRUE; ++index) {
456
 
                if (!append_extension (self, view, asn, data, n_data, index))
457
 
                        break;
458
 
        }
459
 
 
460
 
        egg_asn1x_destroy (asn);
461
 
}
462
 
 
463
 
static void
464
 
gcr_renderer_iface_init (GcrRendererIface *iface)
465
 
{
466
 
        iface->render = gcr_certificate_renderer_real_render;
467
 
}
468
 
 
469
 
/* -----------------------------------------------------------------------------
470
 
 * PUBLIC
471
 
 */
472
 
 
473
 
GcrCertificateRenderer*
474
 
gcr_certificate_renderer_new (GcrCertificate *certificate)
475
 
{
476
 
        return g_object_new (GCR_TYPE_CERTIFICATE_RENDERER, "certificate", certificate, NULL);
477
 
}
478
 
 
479
 
GcrCertificate*
480
 
gcr_certificate_renderer_get_certificate (GcrCertificateRenderer *self)
481
 
{
482
 
        g_return_val_if_fail (GCR_IS_CERTIFICATE_RENDERER (self), NULL);
483
 
        return self->pv->certificate;
484
 
}
485
 
 
486
 
void
487
 
gcr_certificate_renderer_set_certificate (GcrCertificateRenderer *self, GcrCertificate *cert)
488
 
{
489
 
        g_return_if_fail (GCR_IS_CERTIFICATE_RENDERER (self));
490
 
 
491
 
        if (self->pv->certificate)
492
 
                g_object_unref (self->pv->certificate);
493
 
        self->pv->certificate = cert;
494
 
        if (self->pv->certificate)
495
 
                g_object_ref (self->pv->certificate);
496
 
 
497
 
        gcr_renderer_emit_data_changed (GCR_RENDERER (self));
498
 
        g_object_notify (G_OBJECT (self), "certificate");
499
 
}
500
 
 
501
 
GckAttributes*
502
 
gcr_certificate_renderer_get_attributes (GcrCertificateRenderer *self)
503
 
{
504
 
        g_return_val_if_fail (GCR_IS_CERTIFICATE_RENDERER (self), NULL);
505
 
        return self->pv->attributes;
506
 
}
507
 
 
508
 
void
509
 
gcr_certificate_renderer_set_attributes (GcrCertificateRenderer *self, GckAttributes *attrs)
510
 
{
511
 
        GcrCertificate *cert;
512
 
        GckAttribute *attr;
513
 
        gboolean emit = TRUE;
514
 
 
515
 
        g_return_if_fail (GCR_IS_CERTIFICATE_RENDERER (self));
516
 
 
517
 
        gck_attributes_unref (self->pv->attributes);
518
 
        self->pv->attributes = attrs;\
519
 
 
520
 
        if (self->pv->attributes) {
521
 
                gck_attributes_ref (self->pv->attributes);
522
 
                attr = gck_attributes_find (self->pv->attributes, CKA_VALUE);
523
 
                if (attr) {
524
 
                        /* Create a new certificate object refferring to same memory */
525
 
                        cert = gcr_simple_certificate_new_static (attr->value, attr->length);
526
 
                        g_object_set_data_full (G_OBJECT (cert), "attributes",
527
 
                                                gck_attributes_ref (self->pv->attributes),
528
 
                                                (GDestroyNotify)gck_attributes_unref);
529
 
                        gcr_certificate_renderer_set_certificate (self, cert);
530
 
                        g_object_unref (cert);
531
 
                        emit = FALSE;
532
 
                } else {
533
 
                        gcr_certificate_renderer_set_certificate (self, NULL);
534
 
                }
535
 
        }
536
 
 
537
 
        if (emit)
538
 
                gcr_renderer_emit_data_changed (GCR_RENDERER (self));
539
 
 
540
 
}