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
// Take a look at the license at the top of the repository in the LICENSE file.

use glib::translate::*;

use crate::{ffi, Credentials, CredentialsType};

impl Credentials {
    /// Gets a pointer to native credentials of type @native_type from
    /// @self.
    ///
    /// It is a programming error (which will cause a warning to be
    /// logged) to use this method if there is no #GCredentials support for
    /// the OS or if @native_type isn't supported by the OS.
    /// ## `native_type`
    /// The type of native credentials to get.
    ///
    /// # Returns
    ///
    /// The pointer to native credentials or
    ///     [`None`] if there is no #GCredentials support for the OS or if @native_type
    ///     isn't supported by the OS. Do not free the returned data, it is owned
    ///     by @self.
    #[doc(alias = "g_credentials_get_native")]
    #[doc(alias = "get_native")]
    pub fn native(&self, native_type: CredentialsType) -> glib::ffi::gpointer {
        unsafe { ffi::g_credentials_get_native(self.to_glib_none().0, native_type.into_glib()) }
    }

    /// Tries to get the UNIX process identifier from @self. This
    /// method is only available on UNIX platforms.
    ///
    /// This operation can fail if #GCredentials is not supported on the
    /// OS or if the native credentials type does not contain information
    /// about the UNIX process ID.
    ///
    /// # Returns
    ///
    /// The UNIX process ID, or `-1` if @error is set.
    #[cfg(unix)]
    #[cfg_attr(docsrs, doc(cfg(unix)))]
    #[doc(alias = "g_credentials_get_unix_pid")]
    #[doc(alias = "get_unix_pid")]
    pub fn unix_pid(&self) -> Result<libc::pid_t, glib::Error> {
        unsafe {
            let mut error = std::ptr::null_mut();
            let ret = ffi::g_credentials_get_unix_pid(self.to_glib_none().0, &mut error);
            if error.is_null() {
                Ok(ret)
            } else {
                Err(from_glib_full(error))
            }
        }
    }

    /// Tries to get the UNIX user identifier from @self. This
    /// method is only available on UNIX platforms.
    ///
    /// This operation can fail if #GCredentials is not supported on the
    /// OS or if the native credentials type does not contain information
    /// about the UNIX user.
    ///
    /// # Returns
    ///
    /// The UNIX user identifier or `-1` if @error is set.
    #[cfg(unix)]
    #[cfg_attr(docsrs, doc(cfg(unix)))]
    #[doc(alias = "g_credentials_get_unix_user")]
    #[doc(alias = "get_unix_user")]
    pub fn unix_user(&self) -> Result<libc::uid_t, glib::Error> {
        unsafe {
            let mut error = std::ptr::null_mut();
            let ret = ffi::g_credentials_get_unix_user(self.to_glib_none().0, &mut error);
            if error.is_null() {
                Ok(ret)
            } else {
                Err(from_glib_full(error))
            }
        }
    }

    /// Copies the native credentials of type @native_type from @native
    /// into @self.
    ///
    /// It is a programming error (which will cause a warning to be
    /// logged) to use this method if there is no #GCredentials support for
    /// the OS or if @native_type isn't supported by the OS.
    /// ## `native_type`
    /// The type of native credentials to set.
    /// ## `native`
    /// A pointer to native credentials.
    #[doc(alias = "g_credentials_set_native")]
    pub unsafe fn set_native(&self, native_type: CredentialsType, native: glib::ffi::gpointer) {
        unsafe {
            ffi::g_credentials_set_native(self.to_glib_none().0, native_type.into_glib(), native)
        }
    }

    /// Tries to set the UNIX user identifier on @self. This method
    /// is only available on UNIX platforms.
    ///
    /// This operation can fail if #GCredentials is not supported on the
    /// OS or if the native credentials type does not contain information
    /// about the UNIX user. It can also fail if the OS does not allow the
    /// use of "spoofed" credentials.
    /// ## `uid`
    /// The UNIX user identifier to set.
    ///
    /// # Returns
    ///
    /// [`true`] if @uid was set, [`false`] if error is set.
    #[cfg(unix)]
    #[cfg_attr(docsrs, doc(cfg(unix)))]
    #[doc(alias = "g_credentials_set_unix_user")]
    pub fn set_unix_user(&self, uid: libc::uid_t) -> Result<(), glib::Error> {
        unsafe {
            let mut error = std::ptr::null_mut();
            let is_ok = ffi::g_credentials_set_unix_user(self.to_glib_none().0, uid, &mut error);
            debug_assert_eq!(is_ok == glib::ffi::GFALSE, !error.is_null());
            if error.is_null() {
                Ok(())
            } else {
                Err(from_glib_full(error))
            }
        }
    }
}