[gcr/main] gck-session: Use G_DECLARE_DERIVABLE_TYPE to declare the type
- From: Corentin Noël <corentinnoel src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gcr/main] gck-session: Use G_DECLARE_DERIVABLE_TYPE to declare the type
- Date: Mon, 7 Feb 2022 21:12:37 +0000 (UTC)
commit 4846793e9918e62e64dec4703f7639c16d766423
Author: Corentin Noël <corentin elementary io>
Date: Mon Feb 7 21:05:46 2022 +0100
gck-session: Use G_DECLARE_DERIVABLE_TYPE to declare the type
gck/gck-session.c | 165 +++++++++++++++++++++++++++++++-----------------------
gck/gck.h | 21 +------
2 files changed, 96 insertions(+), 90 deletions(-)
---
diff --git a/gck/gck-session.c b/gck/gck-session.c
index 5f5579e..29ef89e 100644
--- a/gck/gck-session.c
+++ b/gck/gck-session.c
@@ -74,7 +74,7 @@ enum {
PROP_APP_DATA
};
-struct _GckSessionPrivate {
+typedef struct {
/* Not modified after construct/init */
GckSlot *slot;
CK_SESSION_HANDLE handle;
@@ -83,10 +83,10 @@ struct _GckSessionPrivate {
gpointer app_data;
/* Changable data locked by mutex */
- GMutex *mutex;
+ GMutex mutex;
GTlsInteraction *interaction;
gboolean discarded;
-};
+} GckSessionPrivate;
static void gck_session_initable_iface (GInitableIface *iface);
@@ -132,9 +132,8 @@ gck_session_real_discard_handle (GckSession *self, CK_OBJECT_HANDLE handle)
static void
gck_session_init (GckSession *self)
{
- self->pv = gck_session_get_instance_private (self);
- self->pv->mutex = g_new0 (GMutex, 1);
- g_mutex_init (self->pv->mutex);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+ g_mutex_init (&priv->mutex);
}
static void
@@ -170,31 +169,32 @@ gck_session_set_property (GObject *obj, guint prop_id, const GValue *value,
GParamSpec *pspec)
{
GckSession *self = GCK_SESSION (obj);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
/* Only valid calls are from constructor */
switch (prop_id) {
case PROP_HANDLE:
- g_return_if_fail (!self->pv->handle);
- self->pv->handle = g_value_get_ulong (value);
+ g_return_if_fail (!priv->handle);
+ priv->handle = g_value_get_ulong (value);
break;
case PROP_INTERACTION:
gck_session_set_interaction (self, g_value_get_object (value));
break;
case PROP_SLOT:
- g_return_if_fail (!self->pv->slot);
- self->pv->slot = g_value_dup_object (value);
- g_return_if_fail (self->pv->slot);
+ g_return_if_fail (!priv->slot);
+ priv->slot = g_value_dup_object (value);
+ g_return_if_fail (priv->slot);
break;
case PROP_OPTIONS:
- g_return_if_fail (!self->pv->options);
- self->pv->options = g_value_get_flags (value);
+ g_return_if_fail (!priv->options);
+ priv->options = g_value_get_flags (value);
break;
case PROP_OPENING_FLAGS:
- self->pv->opening_flags = g_value_get_ulong (value);
+ priv->opening_flags = g_value_get_ulong (value);
break;
case PROP_APP_DATA:
- self->pv->app_data = g_value_get_pointer (value);
+ priv->app_data = g_value_get_pointer (value);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (obj, prop_id, pspec);
@@ -206,28 +206,30 @@ static void
gck_session_constructed (GObject *obj)
{
GckSession *self = GCK_SESSION (obj);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
G_OBJECT_CLASS (gck_session_parent_class)->constructed (obj);
- self->pv->opening_flags |= CKF_SERIAL_SESSION;
- if (self->pv->options & GCK_SESSION_READ_WRITE)
- self->pv->opening_flags |= CKF_RW_SESSION;
+ priv->opening_flags |= CKF_SERIAL_SESSION;
+ if (priv->options & GCK_SESSION_READ_WRITE)
+ priv->opening_flags |= CKF_RW_SESSION;
}
static void
gck_session_dispose (GObject *obj)
{
GckSession *self = GCK_SESSION (obj);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
gboolean discard = FALSE;
gboolean handled;
g_return_if_fail (GCK_IS_SESSION (self));
- if (self->pv->handle != 0) {
- g_mutex_lock (self->pv->mutex);
- discard = !self->pv->discarded;
- self->pv->discarded = TRUE;
- g_mutex_unlock (self->pv->mutex);
+ if (priv->handle != 0) {
+ g_mutex_lock (&priv->mutex);
+ discard = !priv->discarded;
+ priv->discarded = TRUE;
+ g_mutex_unlock (&priv->mutex);
}
if (discard) {
@@ -236,7 +238,7 @@ gck_session_dispose (GObject *obj)
* handle. This allows any necessary session reuse to work.
*/
- g_signal_emit_by_name (self, "discard-handle", self->pv->handle, &handled);
+ g_signal_emit_by_name (self, "discard-handle", priv->handle, &handled);
g_return_if_fail (handled);
}
@@ -247,14 +249,14 @@ static void
gck_session_finalize (GObject *obj)
{
GckSession *self = GCK_SESSION (obj);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
- g_assert (self->pv->handle == 0 || self->pv->discarded);
+ g_assert (priv->handle == 0 || priv->discarded);
- g_clear_object (&self->pv->interaction);
- g_clear_object (&self->pv->slot);
+ g_clear_object (&priv->interaction);
+ g_clear_object (&priv->slot);
- g_mutex_clear (self->pv->mutex);
- g_free (self->pv->mutex);
+ g_mutex_clear (&priv->mutex);
G_OBJECT_CLASS (gck_session_parent_class)->finalize (obj);
}
@@ -407,31 +409,32 @@ gck_session_initable_init (GInitable *initable,
GError **error)
{
GckSession *self = GCK_SESSION (initable);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
OpenSession args = { GCK_ARGUMENTS_INIT, 0, };
GckModule *module = NULL;
gboolean ret = FALSE;
gboolean want_login;
- want_login = (self->pv->options & GCK_SESSION_LOGIN_USER) == GCK_SESSION_LOGIN_USER;
+ want_login = (priv->options & GCK_SESSION_LOGIN_USER) == GCK_SESSION_LOGIN_USER;
/* Already have a session setup? */
- if (self->pv->handle && !want_login)
+ if (priv->handle && !want_login)
return TRUE;
g_object_ref (self);
module = gck_session_get_module (self);
/* Open a new session */
- args.slot = self->pv->slot;
- args.app_data = self->pv->app_data;
+ args.slot = priv->slot;
+ args.app_data = priv->app_data;
args.notify = NULL;
- args.session = self->pv->handle;
- args.flags = self->pv->opening_flags;
- args.interaction = self->pv->interaction ? g_object_ref (self->pv->interaction) : NULL;
+ args.session = priv->handle;
+ args.flags = priv->opening_flags;
+ args.interaction = priv->interaction ? g_object_ref (priv->interaction) : NULL;
args.auto_login = want_login;
- if (_gck_call_sync (self->pv->slot, perform_open_session, NULL, &args, cancellable, error)) {
- self->pv->handle = args.session;
+ if (_gck_call_sync (priv->slot, perform_open_session, NULL, &args, cancellable, error)) {
+ priv->handle = args.session;
ret = TRUE;
}
@@ -456,34 +459,35 @@ gck_session_initable_init_async (GAsyncInitable *initable,
gpointer user_data)
{
GckSession *self = GCK_SESSION (initable);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
OpenSession *args;
gboolean want_login;
GckCall *call;
g_object_ref (self);
- call = _gck_call_async_prep (self->pv->slot, perform_open_session, NULL,
+ call = _gck_call_async_prep (priv->slot, perform_open_session, NULL,
sizeof (*args), free_open_session);
args = _gck_call_get_arguments (call);
- want_login = (self->pv->options & GCK_SESSION_LOGIN_USER) == GCK_SESSION_LOGIN_USER;
- args->session = self->pv->handle;
+ want_login = (priv->options & GCK_SESSION_LOGIN_USER) == GCK_SESSION_LOGIN_USER;
+ args->session = priv->handle;
_gck_call_async_ready (call, self, cancellable, callback, user_data);
/* Already have a session setup? */
- if (self->pv->handle && !want_login) {
+ if (priv->handle && !want_login) {
_gck_call_async_short (call, CKR_OK);
g_object_unref (self);
return;
}
- args->app_data = self->pv->app_data;
+ args->app_data = priv->app_data;
args->notify = NULL;
- args->slot = g_object_ref (self->pv->slot);
- args->interaction = self->pv->interaction ? g_object_ref (self->pv->interaction) : NULL;
+ args->slot = g_object_ref (priv->slot);
+ args->interaction = priv->interaction ? g_object_ref (priv->interaction) : NULL;
args->auto_login = want_login;
- args->flags = self->pv->opening_flags;
+ args->flags = priv->opening_flags;
_gck_call_async_go (call);
g_object_unref (self);
@@ -495,6 +499,7 @@ gck_session_initable_init_finish (GAsyncInitable *initable,
GError **error)
{
GckSession *self = GCK_SESSION (initable);
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
gboolean ret = FALSE;
g_object_ref (self);
@@ -504,7 +509,7 @@ gck_session_initable_init_finish (GAsyncInitable *initable,
if (_gck_call_basic_finish (result, error)) {
args = _gck_call_async_result_arguments (result, OpenSession);
- self->pv->handle = args->session;
+ priv->handle = args->session;
ret = TRUE;
}
}
@@ -609,8 +614,11 @@ gck_session_from_handle (GckSlot *slot,
gulong
gck_session_get_handle (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_val_if_fail (GCK_IS_SESSION (self), (CK_SESSION_HANDLE)-1);
- return self->pv->handle;
+
+ return priv->handle;
}
/**
@@ -624,8 +632,11 @@ gck_session_get_handle (GckSession *self)
GckModule *
gck_session_get_module (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_val_if_fail (GCK_IS_SESSION (self), NULL);
- return gck_slot_get_module (self->pv->slot);
+
+ return gck_slot_get_module (priv->slot);
}
/**
@@ -639,9 +650,12 @@ gck_session_get_module (GckSession *self)
GckSlot *
gck_session_get_slot (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_val_if_fail (GCK_IS_SESSION (self), NULL);
- g_return_val_if_fail (GCK_IS_SLOT (self->pv->slot), NULL);
- return g_object_ref (self->pv->slot);
+ g_return_val_if_fail (GCK_IS_SLOT (priv->slot), NULL);
+
+ return g_object_ref (priv->slot);
}
/**
@@ -656,6 +670,7 @@ gck_session_get_slot (GckSession *self)
GckSessionInfo*
gck_session_get_info (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
GckSessionInfo *sessioninfo;
CK_FUNCTION_LIST_PTR funcs;
CK_SESSION_INFO info;
@@ -671,7 +686,7 @@ gck_session_get_info (GckSession *self)
g_return_val_if_fail (funcs, NULL);
memset (&info, 0, sizeof (info));
- rv = (funcs->C_GetSessionInfo) (self->pv->handle, &info);
+ rv = (funcs->C_GetSessionInfo) (priv->handle, &info);
g_object_unref (module);
@@ -700,6 +715,7 @@ gck_session_get_info (GckSession *self)
gulong
gck_session_get_state (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
CK_FUNCTION_LIST_PTR funcs;
CK_SESSION_INFO info;
GckModule *module;
@@ -714,7 +730,7 @@ gck_session_get_state (GckSession *self)
g_return_val_if_fail (funcs, 0);
memset (&info, 0, sizeof (info));
- rv = (funcs->C_GetSessionInfo) (self->pv->handle, &info);
+ rv = (funcs->C_GetSessionInfo) (priv->handle, &info);
g_object_unref (module);
@@ -737,8 +753,11 @@ gck_session_get_state (GckSession *self)
GckSessionOptions
gck_session_get_options (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_val_if_fail (GCK_IS_SESSION (self), 0);
- return self->pv->options;
+
+ return priv->options;
}
/**
@@ -753,10 +772,12 @@ gck_session_get_options (GckSession *self)
GTlsInteraction *
gck_session_get_interaction (GckSession *self)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_val_if_fail (GCK_IS_SESSION (self), NULL);
- if (self->pv->interaction)
- return g_object_ref (self->pv->interaction);
+ if (priv->interaction)
+ return g_object_ref (priv->interaction);
return NULL;
}
@@ -773,12 +794,14 @@ void
gck_session_set_interaction (GckSession *self,
GTlsInteraction *interaction)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
+
g_return_if_fail (GCK_IS_SESSION (self));
g_return_if_fail (interaction == NULL || G_IS_TLS_INTERACTION (interaction));
- g_mutex_lock (self->pv->mutex);
- g_set_object (&self->pv->interaction, interaction);
- g_mutex_unlock (self->pv->mutex);
+ g_mutex_lock (&priv->mutex);
+ g_set_object (&priv->interaction, interaction);
+ g_mutex_unlock (&priv->mutex);
}
/**
@@ -1205,6 +1228,7 @@ gck_session_login_interactive (GckSession *self,
GCancellable *cancellable,
GError **error)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
Interactive args = { GCK_ARGUMENTS_INIT, interaction, cancellable, NULL, };
g_return_val_if_fail (GCK_IS_SESSION (self), FALSE);
@@ -1215,7 +1239,7 @@ gck_session_login_interactive (GckSession *self,
/* TODO: For now this is all we support */
g_return_val_if_fail (user_type == CKU_USER, FALSE);
- args.token = self->pv->slot;
+ args.token = priv->slot;
return _gck_call_sync (self, perform_interactive, NULL, &args, cancellable, error);
}
@@ -1240,6 +1264,7 @@ gck_session_login_interactive_async (GckSession *self,
GAsyncReadyCallback callback,
gpointer user_data)
{
+ GckSessionPrivate *priv = gck_session_get_instance_private (self);
Interactive* args;
GckCall *call;
@@ -1255,7 +1280,7 @@ gck_session_login_interactive_async (GckSession *self,
args->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
args->interaction = interaction ? g_object_ref (interaction) : NULL;
- args->token = g_object_ref (self->pv->slot);
+ args->token = g_object_ref (priv->slot);
_gck_call_async_ready_go (call, self, cancellable, callback, user_data);
}
@@ -1793,8 +1818,8 @@ typedef struct _GenerateKeyPair {
static void
free_generate_key_pair (GenerateKeyPair *args)
{
- gck_attributes_unref (args->public_attrs);
- gck_attributes_unref (args->private_attrs);
+ g_clear_pointer (&args->public_attrs, gck_attributes_unref);
+ g_clear_pointer (&args->private_attrs, gck_attributes_unref);
g_free (args);
}
@@ -1991,7 +2016,7 @@ typedef struct _WrapKey {
static void
free_wrap_key (WrapKey *args)
{
- g_free (args->result);
+ g_clear_pointer (&args->result, g_free);
g_free (args);
}
@@ -2182,7 +2207,7 @@ typedef struct _UnwrapKey {
static void
free_unwrap_key (UnwrapKey *args)
{
- gck_attributes_unref (args->attrs);
+ g_clear_pointer (&args->attrs, gck_attributes_unref);
g_free (args);
}
@@ -2373,7 +2398,7 @@ typedef struct _DeriveKey {
static void
free_derive_key (DeriveKey *args)
{
- gck_attributes_unref (args->attrs);
+ g_clear_pointer (&args->attrs, gck_attributes_unref);
g_free (args);
}
@@ -2590,8 +2615,8 @@ free_crypt (Crypt *args)
g_clear_object (&args->interaction);
g_clear_object (&args->key_object);
- g_free (args->input);
- g_free (args->result);
+ g_clear_pointer (&args->input, g_free);
+ g_clear_pointer (&args->result, g_free);
g_free (args);
}
@@ -3094,8 +3119,8 @@ free_verify (Verify *args)
g_clear_object (&args->interaction);
g_clear_object (&args->key_object);
- g_free (args->input);
- g_free (args->signature);
+ g_clear_pointer (&args->input, g_free);
+ g_clear_pointer (&args->signature, g_free);
g_free (args);
}
diff --git a/gck/gck.h b/gck/gck.h
index ee66cd4..9d8c9c4 100644
--- a/gck/gck.h
+++ b/gck/gck.h
@@ -740,22 +740,7 @@ void gck_session_info_free (GckSessionInfo *sess
G_DEFINE_AUTOPTR_CLEANUP_FUNC (GckSessionInfo, gck_session_info_free);
#define GCK_TYPE_SESSION (gck_session_get_type())
-#define GCK_SESSION(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GCK_TYPE_SESSION, GckSession))
-#define GCK_SESSION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GCK_TYPE_SESSION, GckSession))
-#define GCK_IS_SESSION(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GCK_TYPE_SESSION))
-#define GCK_IS_SESSION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GCK_TYPE_SESSION))
-#define GCK_SESSION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), GCK_TYPE_SESSION, GckSessionClass))
-
-typedef struct _GckSessionClass GckSessionClass;
-typedef struct _GckSessionPrivate GckSessionPrivate;
-
-struct _GckSession {
- GObject parent;
-
- /*< private >*/
- GckSessionPrivate *pv;
- gpointer reserved[4];
-};
+G_DECLARE_DERIVABLE_TYPE (GckSession, gck_session, GCK, SESSION, GObject)
struct _GckSessionClass {
GObjectClass parent;
@@ -766,8 +751,6 @@ struct _GckSessionClass {
gpointer reserved[8];
};
-GType gck_session_get_type (void) G_GNUC_CONST;
-
GckSession * gck_session_from_handle (GckSlot *slot,
gulong session_handle,
GckSessionOptions options);
@@ -1192,8 +1175,6 @@ GckObject* gck_session_derive_key_finish (GckSession *self,
GAsyncResult *result,
GError **error);
-G_DEFINE_AUTOPTR_CLEANUP_FUNC (GckSession, g_object_unref);
-
/* ------------------------------------------------------------------------
* OBJECT
*/
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]