glibmm 2.80.0
|
TlsInteraction - Interaction with the user during TLS operations. More...
#include <giomm/tlsinteraction.h>
Static Public Member Functions | |
static GType | get_type () |
Get the GType for this class, for use with the underlying GObject type system. | |
Related Symbols | |
(Note that these are not member symbols.) | |
Glib::RefPtr< Gio::TlsInteraction > | wrap (GTlsInteraction *object, bool take_copy=false) |
A Glib::wrap() method for this object. | |
Related Symbols inherited from Glib::Object | |
Glib::RefPtr< Glib::Object > | wrap (GObject *object, bool take_copy=false) |
Additional Inherited Members | |
Public Types inherited from Glib::Object | |
using | DestroyNotify = void(*)(gpointer data) |
TlsInteraction - Interaction with the user during TLS operations.
TlsInteraction provides a mechanism for the TLS connection and database code to interact with the user. It can be used to ask the user for passwords.
To use a TlsInteraction with a TLS connection use Gio::TlsConnection::set_interaction().
Callers should instantiate a derived class that implements the various interaction methods to show the required dialogs.
Callers should use the 'invoke' functions like invoke_ask_password() to run interaction methods. These functions make sure that the interaction is invoked in the main loop and not in the current thread, if the current thread is not running the main loop.
Derived classes can choose to implement whichever interactions methods they'd like to support by overriding those virtual methods. Any interactions not implemented will return Gio::TLS_INTERACTION_UNHANDLED. If a derived class implements an async method, it must also implement the corresponding finish method.
|
noexcept |
|
overridenoexcept |
|
protected |
TlsInteractionResult Gio::TlsInteraction::ask_password | ( | const Glib::RefPtr< TlsPassword > & | password | ) |
A ask_password() convenience overload.
TlsInteractionResult Gio::TlsInteraction::ask_password | ( | const Glib::RefPtr< TlsPassword > & | password, |
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Run synchronous interaction to ask the user for a password.
In general, g_tls_interaction_invoke_ask_password() should be used instead of this function.
Derived subclasses usually implement a password prompt, although they may also choose to provide a password from elsewhere. The password value will be filled in and then callback will be called. Alternatively the user may abort this password request, which will usually abort the TLS connection.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code. Certain implementations may not support immediate cancellation.
password | A TlsPassword object. |
cancellable | An optional Cancellable cancellation object. |
Glib::Error |
void Gio::TlsInteraction::ask_password_async | ( | const Glib::RefPtr< TlsPassword > & | password | ) |
A ask_password_async() convenience overload.
void Gio::TlsInteraction::ask_password_async | ( | const Glib::RefPtr< TlsPassword > & | password, |
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
A ask_password_async() convenience overload.
void Gio::TlsInteraction::ask_password_async | ( | const Glib::RefPtr< TlsPassword > & | password, |
const SlotAsyncReady & | slot | ||
) |
A ask_password_async() convenience overload.
void Gio::TlsInteraction::ask_password_async | ( | const Glib::RefPtr< TlsPassword > & | password, |
const SlotAsyncReady & | slot, | ||
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Run asynchronous interaction to ask the user for a password.
In general, g_tls_interaction_invoke_ask_password() should be used instead of this function.
Derived subclasses usually implement a password prompt, although they may also choose to provide a password from elsewhere. The password value will be filled in and then slot will be called. Alternatively the user may abort this password request, which will usually abort the TLS connection.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code. Certain implementations may not support immediate cancellation.
Certain implementations may not support immediate cancellation.
password | A TlsPassword object. |
cancellable | An optional Cancellable cancellation object. |
slot | Will be called when the interaction completes. |
|
protectedvirtual |
TlsInteractionResult Gio::TlsInteraction::ask_password_finish | ( | const Glib::RefPtr< AsyncResult > & | result | ) |
Complete an ask password user interaction request.
This should be once the g_tls_interaction_ask_password_async() completion callback is called.
If Gio::TlsInteractionResult::HANDLED is returned, then the TlsPassword passed to g_tls_interaction_ask_password() will have its password filled in.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code.
result | The result passed to the callback. |
Glib::Error |
|
protectedvirtual |
Glib::Error. |
|
protectedvirtual |
Glib::Error. |
Get the GType for this class, for use with the underlying GObject type system.
|
inline |
Provides access to the underlying C GObject.
|
inline |
Provides access to the underlying C GObject.
GTlsInteraction * Gio::TlsInteraction::gobj_copy | ( | ) |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
TlsInteractionResult Gio::TlsInteraction::invoke_ask_password | ( | const Glib::RefPtr< TlsPassword > & | password | ) |
A invoke_ask_password() convenience overload.
TlsInteractionResult Gio::TlsInteraction::invoke_ask_password | ( | const Glib::RefPtr< TlsPassword > & | password, |
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Invoke the interaction to ask the user for a password.
It invokes this interaction in the main loop, specifically the MainContext returned by Glib::main_context_get_thread_default() when the interaction is created. This is called by called by TlsConnection or TlsDatabase to ask the user for a password.
Derived subclasses usually implement a password prompt, although they may also choose to provide a password from elsewhere. The password value will be filled in and then callback will be called. Alternatively the user may abort this password request, which will usually abort the TLS connection.
The implementation can either be a synchronous (eg: modal dialog) or an asynchronous one (eg: modeless dialog). This function will take care of calling which ever one correctly.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code. Certain implementations may not support immediate cancellation.
password | A TlsPassword object. |
cancellable | An optional Cancellable cancellation object. |
Glib::Error |
TlsInteractionResult Gio::TlsInteraction::invoke_request_certificate | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags | ||
) |
A invoke_request_certificate() convenience overload.
TlsInteractionResult Gio::TlsInteraction::invoke_request_certificate | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags, | ||
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Invoke the interaction to ask the user to choose a certificate to use with the connection.
It invokes this interaction in the main loop, specifically the MainContext returned by Glib::main_context_get_thread_default() when the interaction is created. This is called by called by TlsConnection when the peer requests a certificate during the handshake.
Derived subclasses usually implement a certificate selector, although they may also choose to provide a certificate from elsewhere. Alternatively the user may abort this certificate request, which may or may not abort the TLS connection.
The implementation can either be a synchronous (eg: modal dialog) or an asynchronous one (eg: modeless dialog). This function will take care of calling which ever one correctly.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code. Certain implementations may not support immediate cancellation.
connection | A TlsConnection object. |
flags | Flags providing more information about the request. |
cancellable | An optional Cancellable cancellation object. |
Glib::Error |
|
noexcept |
TlsInteractionResult Gio::TlsInteraction::request_certificate | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags | ||
) |
A request_certificate() convenience overload.
TlsInteractionResult Gio::TlsInteraction::request_certificate | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags, | ||
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Run synchronous interaction to ask the user to choose a certificate to use with the connection.
In general, g_tls_interaction_invoke_request_certificate() should be used instead of this function.
Derived subclasses usually implement a certificate selector, although they may also choose to provide a certificate from elsewhere. Alternatively the user may abort this certificate request, which will usually abort the TLS connection.
If Gio::TlsInteractionResult::HANDLED is returned, then the TlsConnection passed to g_tls_interaction_request_certificate() will have had its TlsConnection::property_certificate() filled in.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code. Certain implementations may not support immediate cancellation.
connection | A TlsConnection object. |
flags | Flags providing more information about the request. |
cancellable | An optional Cancellable cancellation object. |
Glib::Error |
void Gio::TlsInteraction::request_certificate_async | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags | ||
) |
A request_certificate_async() convenience overload.
void Gio::TlsInteraction::request_certificate_async | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags, | ||
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
A request_certificate_async() convenience overload.
void Gio::TlsInteraction::request_certificate_async | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags, | ||
const SlotAsyncReady & | slot | ||
) |
A request_certificate_async() convenience overload.
void Gio::TlsInteraction::request_certificate_async | ( | const Glib::RefPtr< TlsConnection > & | connection, |
TlsCertificateRequestFlags | flags, | ||
const SlotAsyncReady & | slot, | ||
const Glib::RefPtr< Cancellable > & | cancellable | ||
) |
Run asynchronous interaction to ask the user for a certificate to use with the connection.
In general, g_tls_interaction_invoke_request_certificate() should be used instead of this function.
Derived subclasses usually implement a certificate selector, although they may also choose to provide a certificate from elsewhere. slot will be called when the operation completes. Alternatively the user may abort this certificate request, which will usually abort the TLS connection.
connection | A TlsConnection object. |
flags | Flags providing more information about the request. |
cancellable | An optional Cancellable cancellation object. |
slot | Will be called when the interaction completes. |
TlsInteractionResult Gio::TlsInteraction::request_certificate_finish | ( | const Glib::RefPtr< AsyncResult > & | result | ) |
Complete a request certificate user interaction request.
This should be once the g_tls_interaction_request_certificate_async() completion callback is called.
If Gio::TlsInteractionResult::HANDLED is returned, then the TlsConnection passed to g_tls_interaction_request_certificate_async() will have had its TlsConnection::property_certificate() filled in.
If the interaction is cancelled by the cancellation object, or by the user then Gio::TlsInteractionResult::FAILED will be returned with an error that contains a Gio::Error::CANCELLED error code.
result | The result passed to the callback. |
Glib::Error |
|
related |
A Glib::wrap() method for this object.
object | The C instance. |
take_copy | False if the result should take ownership of the C instance. True if it should take a new copy or ref. |