Mercurial > crates > nonstick
annotate src/conv.rs @ 6:2ec97116d72c
Updates for rustc 1.0.0-beta
| author | Jesse Hallett <jesse@galois.com> |
|---|---|
| date | Fri, 03 Apr 2015 23:16:44 -0700 |
| parents | b195a14058bb |
| children | 9380392b9a60 |
| rev | line source |
|---|---|
| 1 | 1 use libc::{c_char, c_int}; |
| 2 use std::{ptr}; | |
| 3 use std::ffi::{CStr, CString}; | |
| 4 | |
| 5 use constants; | |
| 6 use constants::*; | |
| 7 use module::{PamItem, PamResult}; | |
| 8 | |
| 9 #[allow(missing_copy_implementations)] | |
| 10 pub enum AppDataPtr {} | |
| 11 | |
| 12 #[repr(C)] | |
| 13 struct PamMessage { | |
| 14 msg_style: PamMessageStyle, | |
| 15 msg: *const c_char, | |
| 16 } | |
| 17 | |
| 18 #[repr(C)] | |
| 19 struct PamResponse { | |
| 20 resp: *const c_char, | |
| 21 resp_retcode: AlwaysZero, | |
| 22 } | |
| 23 | |
| 24 /// `PamConv` acts as a channel for communicating with user. | |
| 25 /// | |
| 26 /// Communication is mediated by the pam client (the application that invoked | |
| 27 /// pam). Messages sent will be relayed to the user by the client, and response | |
| 28 /// will be relayed back. | |
| 29 #[repr(C)] | |
| 30 pub struct PamConv { | |
| 31 conv: extern fn(num_msg: c_int, | |
| 32 pam_message: &&PamMessage, | |
|
6
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
33 pam_response: &mut *const PamResponse, |
| 1 | 34 appdata_ptr: *const AppDataPtr |
| 35 ) -> PamResultCode, | |
| 36 appdata_ptr: *const AppDataPtr, | |
| 37 } | |
| 38 | |
| 39 impl PamConv { | |
| 40 /// Sends a message to the pam client. | |
| 41 /// | |
| 42 /// This will typically result in the user seeing a message or a prompt. | |
| 43 /// There are several message styles available: | |
| 44 /// | |
| 45 /// - PAM_PROMPT_ECHO_OFF | |
| 46 /// - PAM_PROMPT_ECHO_ON | |
| 47 /// - PAM_ERROR_MSG | |
| 48 /// - PAM_TEXT_INFO | |
| 49 /// - PAM_RADIO_TYPE | |
| 50 /// - PAM_BINARY_PROMPT | |
| 51 /// | |
| 52 /// Note that the user experience will depend on how the client implements | |
| 53 /// these message styles - and not all applications implement all message | |
| 54 /// styles. | |
| 55 pub fn send(&self, style: PamMessageStyle, msg: &str) -> PamResult<Option<String>> { | |
|
6
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
56 let mut resp_ptr: *const PamResponse = ptr::null(); |
| 1 | 57 let msg = PamMessage { |
| 58 msg_style: style, | |
| 59 msg: CString::new(msg).unwrap().as_ptr(), | |
| 60 }; | |
| 61 | |
|
6
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
62 let ret = (self.conv)(1, &&msg, &mut resp_ptr, self.appdata_ptr); |
| 1 | 63 |
| 64 if constants::PAM_SUCCESS == ret { | |
|
6
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
65 if resp_ptr.is_null() { |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
66 Ok(None) |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
67 } |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
68 else { |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
69 let bytes = unsafe { CStr::from_ptr((*resp_ptr).resp).to_bytes() }; |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
70 Ok(String::from_utf8(bytes.to_vec()).ok()) |
|
2ec97116d72c
Updates for rustc 1.0.0-beta
Jesse Hallett <jesse@galois.com>
parents:
1
diff
changeset
|
71 } |
| 1 | 72 } else { |
| 73 Err(ret) | |
| 74 } | |
| 75 } | |
| 76 } | |
| 77 | |
| 78 impl PamItem for PamConv { | |
| 79 fn item_type(_: Option<Self>) -> PamItemType { PAM_CONV } | |
| 80 } |
