diff options
| author | Robin Krahl <robin.krahl@ireas.org> | 2018-06-07 03:03:29 +0200 | 
|---|---|---|
| committer | Robin Krahl <robin.krahl@ireas.org> | 2018-06-07 03:03:29 +0200 | 
| commit | f035857d9a9dc14c85e6bdf22cbe72528235657d (patch) | |
| tree | b6ec10e06a025a8b226e882c4ee39cc802c67665 | |
| parent | bbe6740d0a0b3f4dd8c1593272a747cfbbb3006b (diff) | |
| download | nitrokey-rs-f035857d9a9dc14c85e6bdf22cbe72528235657d.tar.gz nitrokey-rs-f035857d9a9dc14c85e6bdf22cbe72528235657d.tar.bz2 | |
Use Result<(), CommandError> instead of CommandStatus
The Result enum is more idiomatic and easier to use than our custom
CommandStatus enum with the same structure.  This is especially true for
the try operator ?.
| -rw-r--r-- | src/auth.rs | 44 | ||||
| -rw-r--r-- | src/device.rs | 72 | ||||
| -rw-r--r-- | src/lib.rs | 8 | ||||
| -rw-r--r-- | src/otp.rs | 38 | ||||
| -rw-r--r-- | src/pws.rs | 33 | ||||
| -rw-r--r-- | src/tests/device.rs | 89 | ||||
| -rw-r--r-- | src/tests/otp.rs | 55 | ||||
| -rw-r--r-- | src/tests/pws.rs | 69 | ||||
| -rw-r--r-- | src/util.rs | 37 | 
9 files changed, 195 insertions, 250 deletions
| diff --git a/src/auth.rs b/src/auth.rs index 6a0a71f..62b851f 100644 --- a/src/auth.rs +++ b/src/auth.rs @@ -5,7 +5,7 @@ use otp::{ConfigureOtp, GenerateOtp, OtpMode, OtpSlotData, RawOtpSlotData};  use std::ffi::CString;  use std::ops::Deref;  use std::os::raw::c_int; -use util::{generate_password, result_from_string, CommandError, CommandStatus}; +use util::{generate_password, get_command_result, result_from_string, CommandError};  static TEMPORARY_PASSWORD_LENGTH: usize = 25; @@ -287,41 +287,33 @@ impl<T: Device> Admin<T> {      /// ```      ///      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot -    pub fn write_config(&self, config: Config) -> CommandStatus { -        let raw_config = match RawConfig::try_from(config) { -            Ok(raw_config) => raw_config, -            Err(err) => return CommandStatus::Error(err), -        }; +    pub fn write_config(&self, config: Config) -> Result<(), CommandError> { +        let raw_config = RawConfig::try_from(config)?;          unsafe { -            let rv = nitrokey_sys::NK_write_config( +            get_command_result(nitrokey_sys::NK_write_config(                  raw_config.numlock,                  raw_config.capslock,                  raw_config.scrollock,                  raw_config.user_password,                  false,                  self.temp_password.as_ptr() as *const i8, -            ); -            return CommandStatus::from(rv); +            ))          }      } -    fn write_otp_slot<C>(&self, data: OtpSlotData, callback: C) -> CommandStatus +    fn write_otp_slot<C>(&self, data: OtpSlotData, callback: C) -> Result<(), CommandError>      where          C: Fn(RawOtpSlotData, *const i8) -> c_int,      { -        let raw_data = match RawOtpSlotData::new(data) { -            Ok(raw_data) => raw_data, -            Err(err) => return CommandStatus::Error(err), -        }; +        let raw_data = RawOtpSlotData::new(data)?;          let temp_password_ptr = self.temp_password.as_ptr() as *const i8; -        let rv = callback(raw_data, temp_password_ptr); -        return CommandStatus::from(rv); +        get_command_result(callback(raw_data, temp_password_ptr))      }  }  impl<T: Device> ConfigureOtp for Admin<T> { -    fn write_hotp_slot(&self, data: OtpSlotData, counter: u64) -> CommandStatus { -        return self.write_otp_slot(data, |raw_data: RawOtpSlotData, temp_password_ptr| unsafe { +    fn write_hotp_slot(&self, data: OtpSlotData, counter: u64) -> Result<(), CommandError> { +        self.write_otp_slot(data, |raw_data: RawOtpSlotData, temp_password_ptr| unsafe {              nitrokey_sys::NK_write_hotp_slot(                  raw_data.number,                  raw_data.name.as_ptr(), @@ -333,11 +325,11 @@ impl<T: Device> ConfigureOtp for Admin<T> {                  raw_data.token_id.as_ptr(),                  temp_password_ptr,              ) -        }); +        })      } -    fn write_totp_slot(&self, data: OtpSlotData, time_window: u16) -> CommandStatus { -        return self.write_otp_slot(data, |raw_data: RawOtpSlotData, temp_password_ptr| unsafe { +    fn write_totp_slot(&self, data: OtpSlotData, time_window: u16) -> Result<(), CommandError> { +        self.write_otp_slot(data, |raw_data: RawOtpSlotData, temp_password_ptr| unsafe {              nitrokey_sys::NK_write_totp_slot(                  raw_data.number,                  raw_data.name.as_ptr(), @@ -349,17 +341,17 @@ impl<T: Device> ConfigureOtp for Admin<T> {                  raw_data.token_id.as_ptr(),                  temp_password_ptr,              ) -        }); +        })      } -    fn erase_hotp_slot(&self, slot: u8) -> CommandStatus { +    fn erase_hotp_slot(&self, slot: u8) -> Result<(), CommandError> {          let temp_password_ptr = self.temp_password.as_ptr() as *const i8; -        unsafe { CommandStatus::from(nitrokey_sys::NK_erase_hotp_slot(slot, temp_password_ptr)) } +        unsafe { get_command_result(nitrokey_sys::NK_erase_hotp_slot(slot, temp_password_ptr)) }      } -    fn erase_totp_slot(&self, slot: u8) -> CommandStatus { +    fn erase_totp_slot(&self, slot: u8) -> Result<(), CommandError> {          let temp_password_ptr = self.temp_password.as_ptr() as *const i8; -        unsafe { CommandStatus::from(nitrokey_sys::NK_erase_totp_slot(slot, temp_password_ptr)) } +        unsafe { get_command_result(nitrokey_sys::NK_erase_totp_slot(slot, temp_password_ptr)) }      }  } diff --git a/src/device.rs b/src/device.rs index f901306..c4e83a9 100644 --- a/src/device.rs +++ b/src/device.rs @@ -5,7 +5,7 @@ use nitrokey_sys;  use otp::GenerateOtp;  use pws::GetPasswordSafe;  use std::ffi::CString; -use util::{get_last_error, result_from_string, CommandError, CommandStatus}; +use util::{get_command_result, get_last_error, result_from_string, CommandError};  /// Available Nitrokey models.  #[derive(Debug, PartialEq)] @@ -296,14 +296,14 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus, Device}; +    /// use nitrokey::Device;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?;      /// match device.change_admin_pin("12345678", "12345679") { -    ///     CommandStatus::Success => println!("Updated admin PIN."), -    ///     CommandStatus::Error(err) => println!("Failed to update admin PIN: {:?}", err), +    ///     Ok(()) => println!("Updated admin PIN."), +    ///     Err(err) => println!("Failed to update admin PIN: {:?}", err),      /// };      /// #     Ok(())      /// # } @@ -311,16 +311,16 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      ///      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`WrongPassword`]: enum.CommandError.html#variant.WrongPassword -    fn change_admin_pin(&self, current: &str, new: &str) -> CommandStatus { +    fn change_admin_pin(&self, current: &str, new: &str) -> Result<(), CommandError> {          let current_string = CString::new(current);          let new_string = CString::new(new);          if current_string.is_err() || new_string.is_err() { -            return CommandStatus::Error(CommandError::InvalidString); +            return Err(CommandError::InvalidString);          }          let current_string = current_string.unwrap();          let new_string = new_string.unwrap();          unsafe { -            CommandStatus::from(nitrokey_sys::NK_change_admin_PIN( +            get_command_result(nitrokey_sys::NK_change_admin_PIN(                  current_string.as_ptr(),                  new_string.as_ptr(),              )) @@ -337,14 +337,14 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus, Device}; +    /// use nitrokey::Device;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?;      /// match device.change_user_pin("123456", "123457") { -    ///     CommandStatus::Success => println!("Updated admin PIN."), -    ///     CommandStatus::Error(err) => println!("Failed to update admin PIN: {:?}", err), +    ///     Ok(()) => println!("Updated admin PIN."), +    ///     Err(err) => println!("Failed to update admin PIN: {:?}", err),      /// };      /// #     Ok(())      /// # } @@ -352,16 +352,16 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      ///      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`WrongPassword`]: enum.CommandError.html#variant.WrongPassword -    fn change_user_pin(&self, current: &str, new: &str) -> CommandStatus { +    fn change_user_pin(&self, current: &str, new: &str) -> Result<(), CommandError> {          let current_string = CString::new(current);          let new_string = CString::new(new);          if current_string.is_err() || new_string.is_err() { -            return CommandStatus::Error(CommandError::InvalidString); +            return Err(CommandError::InvalidString);          }          let current_string = current_string.unwrap();          let new_string = new_string.unwrap();          unsafe { -            CommandStatus::from(nitrokey_sys::NK_change_user_PIN( +            get_command_result(nitrokey_sys::NK_change_user_PIN(                  current_string.as_ptr(),                  new_string.as_ptr(),              )) @@ -378,14 +378,14 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus, Device}; +    /// use nitrokey::Device;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?;      /// match device.unlock_user_pin("12345678", "123456") { -    ///     CommandStatus::Success => println!("Unlocked user PIN."), -    ///     CommandStatus::Error(err) => println!("Failed to unlock user PIN: {:?}", err), +    ///     Ok(()) => println!("Unlocked user PIN."), +    ///     Err(err) => println!("Failed to unlock user PIN: {:?}", err),      /// };      /// #     Ok(())      /// # } @@ -393,16 +393,16 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      ///      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`WrongPassword`]: enum.CommandError.html#variant.WrongPassword -    fn unlock_user_pin(&self, admin_pin: &str, user_pin: &str) -> CommandStatus { +    fn unlock_user_pin(&self, admin_pin: &str, user_pin: &str) -> Result<(), CommandError> {          let admin_pin_string = CString::new(admin_pin);          let user_pin_string = CString::new(user_pin);          if admin_pin_string.is_err() || user_pin_string.is_err() { -            return CommandStatus::Error(CommandError::InvalidString); +            return Err(CommandError::InvalidString);          }          let admin_pin_string = admin_pin_string.unwrap();          let user_pin_string = user_pin_string.unwrap();          unsafe { -            CommandStatus::from(nitrokey_sys::NK_unlock_user_password( +            get_command_result(nitrokey_sys::NK_unlock_user_password(                  admin_pin_string.as_ptr(),                  user_pin_string.as_ptr(),              )) @@ -417,20 +417,20 @@ pub trait Device: Authenticate + GetPasswordSafe + GenerateOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus, Device}; +    /// use nitrokey::Device;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?;      /// match device.lock() { -    ///     CommandStatus::Success => println!("Locked the Nitrokey device."), -    ///     CommandStatus::Error(err) => println!("Could not lock the Nitrokey device: {:?}", err), +    ///     Ok(()) => println!("Locked the Nitrokey device."), +    ///     Err(err) => println!("Could not lock the Nitrokey device: {:?}", err),      /// };      /// #     Ok(())      /// # }      /// ``` -    fn lock(&self) -> CommandStatus { -        unsafe { CommandStatus::from(nitrokey_sys::NK_lock_device()) } +    fn lock(&self) -> Result<(), CommandError> { +        unsafe { get_command_result(nitrokey_sys::NK_lock_device()) }      }  } @@ -547,14 +547,13 @@ impl Storage {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus};      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::Storage::connect()?;      /// match device.enable_encrypted_volume("123456") { -    ///     CommandStatus::Success => println!("Enabled the encrypted volume."), -    ///     CommandStatus::Error(err) => println!("Could not enable the encrypted volume: {:?}", err), +    ///     Ok(()) => println!("Enabled the encrypted volume."), +    ///     Err(err) => println!("Could not enable the encrypted volume: {:?}", err),      /// };      /// #     Ok(())      /// # } @@ -562,13 +561,13 @@ impl Storage {      ///      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`WrongPassword`]: enum.CommandError.html#variant.WrongPassword -    pub fn enable_encrypted_volume(&self, user_pin: &str) -> CommandStatus { +    pub fn enable_encrypted_volume(&self, user_pin: &str) -> Result<(), CommandError> {          let user_pin = CString::new(user_pin);          if user_pin.is_err() { -            return CommandStatus::Error(CommandError::InvalidString); +            return Err(CommandError::InvalidString);          }          let user_pin = user_pin.unwrap(); -        unsafe { CommandStatus::from(nitrokey_sys::NK_unlock_encrypted_volume(user_pin.as_ptr())) } +        unsafe { get_command_result(nitrokey_sys::NK_unlock_encrypted_volume(user_pin.as_ptr())) }      }      /// Disables the encrypted storage volume. @@ -579,7 +578,6 @@ impl Storage {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus};      /// # use nitrokey::CommandError;      ///      /// fn use_volume() {} @@ -587,17 +585,17 @@ impl Storage {      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::Storage::connect()?;      /// match device.enable_encrypted_volume("123456") { -    ///     CommandStatus::Success => { +    ///     Ok(()) => {      ///         println!("Enabled the encrypted volume.");      ///         use_volume();      ///         match device.disable_encrypted_volume() { -    ///             CommandStatus::Success => println!("Disabled the encrypted volume."), -    ///             CommandStatus::Err(err) => { +    ///             Ok(()) => println!("Disabled the encrypted volume."), +    ///             Err(err) => {      ///                 println!("Could not disable the encrypted volume: {:?}", err);      ///             },      ///         };      ///     }, -    ///     CommandStatus::Error(err) => println!("Could not enable the encrypted volume: {:?}", err), +    ///     Err(err) => println!("Could not enable the encrypted volume: {:?}", err),      /// };      /// #     Ok(())      /// # } @@ -605,8 +603,8 @@ impl Storage {      ///      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`WrongPassword`]: enum.CommandError.html#variant.WrongPassword -    pub fn disable_encrypted_volume(&self) -> CommandStatus { -        unsafe { CommandStatus::from(nitrokey_sys::NK_lock_encrypted_volume()) } +    pub fn disable_encrypted_volume(&self) -> Result<(), CommandError> { +        unsafe { get_command_result(nitrokey_sys::NK_lock_encrypted_volume()) }      }  } @@ -37,7 +37,7 @@  //! Configure an HOTP slot:  //!  //! ```no_run -//! use nitrokey::{Authenticate, CommandStatus, ConfigureOtp, OtpMode, OtpSlotData}; +//! use nitrokey::{Authenticate, ConfigureOtp, OtpMode, OtpSlotData};  //! # use nitrokey::CommandError;  //!  //! # fn try_main() -> Result<(), (CommandError)> { @@ -46,8 +46,8 @@  //! match device.authenticate_admin("12345678") {  //!     Ok(admin) => {  //!         match admin.write_hotp_slot(slot_data, 0) { -//!             CommandStatus::Success => println!("Successfully wrote slot."), -//!             CommandStatus::Error(err) => println!("Could not write slot: {:?}", err), +//!             Ok(()) => println!("Successfully wrote slot."), +//!             Err(err) => println!("Could not write slot: {:?}", err),  //!         }  //!     },  //!     Err((_, err)) => println!("Could not authenticate as admin: {:?}", err), @@ -102,7 +102,7 @@ pub use config::Config;  pub use device::{connect, Device, DeviceWrapper, Pro, Storage};  pub use otp::{ConfigureOtp, GenerateOtp, OtpMode, OtpSlotData};  pub use pws::{GetPasswordSafe, PasswordSafe, SLOT_COUNT}; -pub use util::{CommandError, CommandStatus, LogLevel}; +pub use util::{CommandError, LogLevel};  /// Enables or disables debug output.  Calling this method with `true` is equivalent to setting the  /// log level to `Debug`; calling it with `false` is equivalent to the log level `Error` (see @@ -1,6 +1,6 @@  use nitrokey_sys;  use std::ffi::CString; -use util::{result_from_string, CommandError, CommandStatus}; +use util::{get_command_result, result_from_string, CommandError};  /// Modes for one-time password generation.  #[derive(Debug, PartialEq)] @@ -25,7 +25,7 @@ pub trait ConfigureOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{Authenticate, CommandStatus, ConfigureOtp, OtpMode, OtpSlotData}; +    /// use nitrokey::{Authenticate, ConfigureOtp, OtpMode, OtpSlotData};      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), (CommandError)> { @@ -34,8 +34,8 @@ pub trait ConfigureOtp {      /// match device.authenticate_admin("12345678") {      ///     Ok(admin) => {      ///         match admin.write_hotp_slot(slot_data, 0) { -    ///             CommandStatus::Success => println!("Successfully wrote slot."), -    ///             CommandStatus::Error(err) => println!("Could not write slot: {:?}", err), +    ///             Ok(()) => println!("Successfully wrote slot."), +    ///             Err(err) => println!("Could not write slot: {:?}", err),      ///         }      ///     },      ///     Err((_, err)) => println!("Could not authenticate as admin: {:?}", err), @@ -47,7 +47,7 @@ pub trait ConfigureOtp {      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`NoName`]: enum.CommandError.html#variant.NoName -    fn write_hotp_slot(&self, data: OtpSlotData, counter: u64) -> CommandStatus; +    fn write_hotp_slot(&self, data: OtpSlotData, counter: u64) -> Result<(), CommandError>;      /// Configure a TOTP slot with the given data and set the TOTP time window to the given value      /// (default 30). @@ -61,7 +61,7 @@ pub trait ConfigureOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{Authenticate, CommandStatus, ConfigureOtp, OtpMode, OtpSlotData}; +    /// use nitrokey::{Authenticate, ConfigureOtp, OtpMode, OtpSlotData};      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), (CommandError)> { @@ -70,8 +70,8 @@ pub trait ConfigureOtp {      /// match device.authenticate_admin("12345678") {      ///     Ok(admin) => {      ///         match admin.write_totp_slot(slot_data, 30) { -    ///             CommandStatus::Success => println!("Successfully wrote slot."), -    ///             CommandStatus::Error(err) => println!("Could not write slot: {:?}", err), +    ///             Ok(()) => println!("Successfully wrote slot."), +    ///             Err(err) => println!("Could not write slot: {:?}", err),      ///         }      ///     },      ///     Err((_, err)) => println!("Could not authenticate as admin: {:?}", err), @@ -83,7 +83,7 @@ pub trait ConfigureOtp {      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString      /// [`NoName`]: enum.CommandError.html#variant.NoName -    fn write_totp_slot(&self, data: OtpSlotData, time_window: u16) -> CommandStatus; +    fn write_totp_slot(&self, data: OtpSlotData, time_window: u16) -> Result<(), CommandError>;      /// Erases an HOTP slot.      /// @@ -94,7 +94,7 @@ pub trait ConfigureOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{Authenticate, CommandStatus, ConfigureOtp}; +    /// use nitrokey::{Authenticate, ConfigureOtp};      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), (CommandError)> { @@ -102,8 +102,8 @@ pub trait ConfigureOtp {      /// match device.authenticate_admin("12345678") {      ///     Ok(admin) => {      ///         match admin.erase_hotp_slot(1) { -    ///             CommandStatus::Success => println!("Successfully erased slot."), -    ///             CommandStatus::Error(err) => println!("Could not erase slot: {:?}", err), +    ///             Ok(()) => println!("Successfully erased slot."), +    ///             Err(err) => println!("Could not erase slot: {:?}", err),      ///         }      ///     },      ///     Err((_, err)) => println!("Could not authenticate as admin: {:?}", err), @@ -113,7 +113,7 @@ pub trait ConfigureOtp {      /// ```      ///      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot -    fn erase_hotp_slot(&self, slot: u8) -> CommandStatus; +    fn erase_hotp_slot(&self, slot: u8) -> Result<(), CommandError>;      /// Erases a TOTP slot.      /// @@ -124,7 +124,7 @@ pub trait ConfigureOtp {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{Authenticate, CommandStatus, ConfigureOtp}; +    /// use nitrokey::{Authenticate, ConfigureOtp};      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), (CommandError)> { @@ -132,8 +132,8 @@ pub trait ConfigureOtp {      /// match device.authenticate_admin("12345678") {      ///     Ok(admin) => {      ///         match admin.erase_totp_slot(1) { -    ///             CommandStatus::Success => println!("Successfully erased slot."), -    ///             CommandStatus::Error(err) => println!("Could not erase slot: {:?}", err), +    ///             Ok(()) => println!("Successfully erased slot."), +    ///             Err(err) => println!("Could not erase slot: {:?}", err),      ///         }      ///     },      ///     Err((_, err)) => println!("Could not authenticate as admin: {:?}", err), @@ -143,7 +143,7 @@ pub trait ConfigureOtp {      /// ```      ///      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot -    fn erase_totp_slot(&self, slot: u8) -> CommandStatus; +    fn erase_totp_slot(&self, slot: u8) -> Result<(), CommandError>;  }  /// Provides methods to generate OTP codes and to query OTP slots on a Nitrokey @@ -181,8 +181,8 @@ pub trait GenerateOtp {      ///      /// [`get_totp_code`]: #method.get_totp_code      /// [`Timestamp`]: enum.CommandError.html#variant.Timestamp -    fn set_time(&self, time: u64) -> CommandStatus { -        unsafe { CommandStatus::from(nitrokey_sys::NK_totp_set_time(time)) } +    fn set_time(&self, time: u64) -> Result<(), CommandError> { +        unsafe { get_command_result(nitrokey_sys::NK_totp_set_time(time)) }      }      /// Returns the name of the given HOTP slot. @@ -2,7 +2,7 @@ use device::{Device, DeviceWrapper, Pro, Storage};  use libc;  use nitrokey_sys;  use std::ffi::CString; -use util::{get_last_error, result_from_string, CommandError, CommandStatus}; +use util::{get_command_result, get_last_error, result_from_string, CommandError};  /// The number of slots in a [`PasswordSafe`][].  /// @@ -111,15 +111,12 @@ fn get_password_safe<'a>(          return Err(CommandError::InvalidString);      }      let user_pin_string = user_pin_string.unwrap(); -    let status = unsafe { -        CommandStatus::from(nitrokey_sys::NK_enable_password_safe( +    let result = unsafe { +        get_command_result(nitrokey_sys::NK_enable_password_safe(              user_pin_string.as_ptr(),          ))      }; -    match status { -        CommandStatus::Success => Ok(PasswordSafe { _device: device }), -        CommandStatus::Error(err) => Err(err), -    } +    result.map(|()| PasswordSafe { _device: device })  }  impl<'a> PasswordSafe<'a> { @@ -283,19 +280,25 @@ impl<'a> PasswordSafe<'a> {      ///      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot      /// [`InvalidString`]: enum.CommandError.html#variant.InvalidString -    pub fn write_slot(&self, slot: u8, name: &str, login: &str, password: &str) -> CommandStatus { +    pub fn write_slot( +        &self, +        slot: u8, +        name: &str, +        login: &str, +        password: &str, +    ) -> Result<(), CommandError> {          let name_string = CString::new(name);          let login_string = CString::new(login);          let password_string = CString::new(password);          if name_string.is_err() || login_string.is_err() || password_string.is_err() { -            return CommandStatus::Error(CommandError::InvalidString); +            return Err(CommandError::InvalidString);          }          let name_string = name_string.unwrap();          let login_string = login_string.unwrap();          let password_string = password_string.unwrap();          unsafe { -            CommandStatus::from(nitrokey_sys::NK_write_password_safe_slot( +            get_command_result(nitrokey_sys::NK_write_password_safe_slot(                  slot,                  name_string.as_ptr(),                  login_string.as_ptr(), @@ -314,23 +317,23 @@ impl<'a> PasswordSafe<'a> {      /// # Example      ///      /// ```no_run -    /// use nitrokey::{CommandStatus, GetPasswordSafe}; +    /// use nitrokey::GetPasswordSafe;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?;      /// let pws = device.get_password_safe("123456")?;      /// match pws.erase_slot(0) { -    ///     CommandStatus::Success => println!("Erased slot 0."), -    ///     CommandStatus::Error(err) => println!("Could not erase slot 0: {:?}", err), +    ///     Ok(()) => println!("Erased slot 0."), +    ///     Err(err) => println!("Could not erase slot 0: {:?}", err),      /// };      /// #     Ok(())      /// # }      /// ```      ///      /// [`InvalidSlot`]: enum.CommandError.html#variant.InvalidSlot -    pub fn erase_slot(&self, slot: u8) -> CommandStatus { -        unsafe { CommandStatus::from(nitrokey_sys::NK_erase_password_safe_slot(slot)) } +    pub fn erase_slot(&self, slot: u8) -> Result<(), CommandError> { +        unsafe { get_command_result(nitrokey_sys::NK_erase_password_safe_slot(slot)) }      }  } diff --git a/src/tests/device.rs b/src/tests/device.rs index 22423fa..60ca33a 100644 --- a/src/tests/device.rs +++ b/src/tests/device.rs @@ -2,7 +2,7 @@ use std::ffi::CStr;  use std::process::Command;  use std::{thread, time};  use tests::util::{Target, ADMIN_PASSWORD, USER_PASSWORD}; -use {Authenticate, CommandError, CommandStatus, Config, Device}; +use {Authenticate, CommandError, Config, Device, Storage};  static ADMIN_NEW_PASSWORD: &str = "1234567890";  static USER_NEW_PASSWORD: &str = "abcdefghij"; @@ -130,23 +130,20 @@ fn config() {      let device = Target::connect().unwrap();      let admin = device.authenticate_admin(ADMIN_PASSWORD).unwrap();      let config = Config::new(None, None, None, true); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      let get_config = admin.get_config().unwrap();      assert_eq!(config, get_config);      let config = Config::new(None, Some(9), None, true); -    assert_eq!( -        CommandStatus::Error(CommandError::InvalidSlot), -        admin.write_config(config) -    ); +    assert_eq!(Err(CommandError::InvalidSlot), admin.write_config(config));      let config = Config::new(Some(1), None, Some(0), false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      let get_config = admin.get_config().unwrap();      assert_eq!(config, get_config);      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      let get_config = admin.get_config().unwrap();      assert_eq!(config, get_config);  } @@ -158,8 +155,11 @@ fn change_user_pin() {      let device = device.authenticate_user(USER_PASSWORD).unwrap().device();      let device = device.authenticate_user(USER_NEW_PASSWORD).unwrap_err().0; -    let result = device.change_user_pin(USER_PASSWORD, USER_NEW_PASSWORD); -    assert_eq!(CommandStatus::Success, result); +    assert!( +        device +            .change_user_pin(USER_PASSWORD, USER_NEW_PASSWORD) +            .is_ok() +    );      let device = device.authenticate_user(USER_PASSWORD).unwrap_err().0;      let device = device @@ -168,13 +168,16 @@ fn change_user_pin() {          .device();      let result = device.change_user_pin(USER_PASSWORD, USER_PASSWORD); -    assert_eq!(CommandStatus::Error(CommandError::WrongPassword), result); +    assert_eq!(Err(CommandError::WrongPassword), result); -    let result = device.change_user_pin(USER_NEW_PASSWORD, USER_PASSWORD); -    assert_eq!(CommandStatus::Success, result); +    assert!( +        device +            .change_user_pin(USER_NEW_PASSWORD, USER_PASSWORD) +            .is_ok() +    );      let device = device.authenticate_user(USER_PASSWORD).unwrap().device(); -    device.authenticate_user(USER_NEW_PASSWORD).unwrap_err(); +    assert!(device.authenticate_user(USER_NEW_PASSWORD).is_err());  }  #[test] @@ -184,8 +187,11 @@ fn change_admin_pin() {      let device = device.authenticate_admin(ADMIN_PASSWORD).unwrap().device();      let device = device.authenticate_admin(ADMIN_NEW_PASSWORD).unwrap_err().0; -    let result = device.change_admin_pin(ADMIN_PASSWORD, ADMIN_NEW_PASSWORD); -    assert_eq!(CommandStatus::Success, result); +    assert!( +        device +            .change_admin_pin(ADMIN_PASSWORD, ADMIN_NEW_PASSWORD) +            .is_ok() +    );      let device = device.authenticate_admin(ADMIN_PASSWORD).unwrap_err().0;      let device = device @@ -193,11 +199,16 @@ fn change_admin_pin() {          .unwrap()          .device(); -    let result = device.change_admin_pin(ADMIN_PASSWORD, ADMIN_PASSWORD); -    assert_eq!(CommandStatus::Error(CommandError::WrongPassword), result); +    assert_eq!( +        Err(CommandError::WrongPassword), +        device.change_admin_pin(ADMIN_PASSWORD, ADMIN_PASSWORD) +    ); -    let result = device.change_admin_pin(ADMIN_NEW_PASSWORD, ADMIN_PASSWORD); -    assert_eq!(CommandStatus::Success, result); +    assert!( +        device +            .change_admin_pin(ADMIN_NEW_PASSWORD, ADMIN_PASSWORD) +            .is_ok() +    );      let device = device.authenticate_admin(ADMIN_PASSWORD).unwrap().device();      device.authenticate_admin(ADMIN_NEW_PASSWORD).unwrap_err(); @@ -216,12 +227,13 @@ fn require_failed_user_login(device: Target, password: &str, error: CommandError  fn unlock_user_pin() {      let device = Target::connect().unwrap();      let device = device.authenticate_user(USER_PASSWORD).unwrap().device(); -    assert_eq!( -        CommandStatus::Success, -        device.unlock_user_pin(ADMIN_PASSWORD, USER_PASSWORD) +    assert!( +        device +            .unlock_user_pin(ADMIN_PASSWORD, USER_PASSWORD) +            .is_ok()      );      assert_eq!( -        CommandStatus::Error(CommandError::WrongPassword), +        Err(CommandError::WrongPassword),          device.unlock_user_pin(USER_PASSWORD, USER_PASSWORD)      ); @@ -232,12 +244,13 @@ fn unlock_user_pin() {      let device = require_failed_user_login(device, USER_PASSWORD, CommandError::WrongPassword);      assert_eq!( -        CommandStatus::Error(CommandError::WrongPassword), +        Err(CommandError::WrongPassword),          device.unlock_user_pin(USER_PASSWORD, USER_PASSWORD)      ); -    assert_eq!( -        CommandStatus::Success, -        device.unlock_user_pin(ADMIN_PASSWORD, USER_PASSWORD) +    assert!( +        device +            .unlock_user_pin(ADMIN_PASSWORD, USER_PASSWORD) +            .is_ok()      );      device.authenticate_user(USER_PASSWORD).unwrap();  } @@ -246,22 +259,19 @@ fn unlock_user_pin() {  #[cfg_attr(not(feature = "test-storage"), ignore)]  fn encrypted_volume() {      let device = Storage::connect().unwrap(); -    assert_eq!(CommandStatus::Success, device.lock()); +    assert!(device.lock().is_ok());      assert_eq!(1, count_nitrokey_block_devices()); -    assert_eq!(CommandStatus::Success, device.disable_encrypted_volume()); +    assert!(device.disable_encrypted_volume().is_ok());      assert_eq!(1, count_nitrokey_block_devices());      assert_eq!( -        CommandStatus::Error(CommandError::WrongPassword), +        Err(CommandError::WrongPassword),          device.enable_encrypted_volume("123")      );      assert_eq!(1, count_nitrokey_block_devices()); -    assert_eq!( -        CommandStatus::Success, -        device.enable_encrypted_volume(USER_PASSWORD) -    ); +    assert!(device.enable_encrypted_volume(USER_PASSWORD).is_ok());      assert_eq!(2, count_nitrokey_block_devices()); -    assert_eq!(CommandStatus::Success, device.disable_encrypted_volume()); +    assert!(device.disable_encrypted_volume().is_ok());      assert_eq!(1, count_nitrokey_block_devices());  } @@ -270,10 +280,7 @@ fn encrypted_volume() {  fn lock() {      let device = Storage::connect().unwrap(); -    assert_eq!( -        CommandStatus::Success, -        device.enable_encrypted_volume(USER_PASSWORD) -    ); -    assert_eq!(CommandStatus::Success, device.lock()); +    assert!(device.enable_encrypted_volume(USER_PASSWORD).is_ok()); +    assert!(device.lock().is_ok());      assert_eq!(1, count_nitrokey_block_devices());  } diff --git a/src/tests/otp.rs b/src/tests/otp.rs index 91f9f1b..cf71d9d 100644 --- a/src/tests/otp.rs +++ b/src/tests/otp.rs @@ -1,7 +1,6 @@  use std::ops::Deref;  use tests::util::{Target, ADMIN_PASSWORD, USER_PASSWORD}; -use {Admin, Authenticate, CommandError, CommandStatus, Config, ConfigureOtp, GenerateOtp, OtpMode, -     OtpSlotData}; +use {Admin, Authenticate, CommandError, Config, ConfigureOtp, GenerateOtp, OtpMode, OtpSlotData};  // test suite according to RFC 4226, Appendix D  static HOTP_SECRET: &str = "3132333435363738393031323334353637383930"; @@ -36,10 +35,7 @@ fn get_admin_test_device() -> Admin<Target> {  fn configure_hotp(admin: &ConfigureOtp, counter: u8) {      let slot_data = OtpSlotData::new(1, "test-hotp", HOTP_SECRET, OtpMode::SixDigits); -    assert_eq!( -        CommandStatus::Success, -        admin.write_hotp_slot(slot_data, counter.into()) -    ); +    assert!(admin.write_hotp_slot(slot_data, counter.into()).is_ok());  }  fn check_hotp_codes(device: &GenerateOtp, offset: u8) { @@ -56,7 +52,7 @@ fn check_hotp_codes(device: &GenerateOtp, offset: u8) {  fn hotp_no_pin() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_hotp(&admin, 0);      check_hotp_codes(admin.deref(), 0); @@ -73,7 +69,7 @@ fn hotp_no_pin() {  fn hotp_pin() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, true); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_hotp(&admin, 0);      let user = admin.device().authenticate_user(USER_PASSWORD).unwrap(); @@ -87,7 +83,7 @@ fn hotp_pin() {  fn hotp_slot_name() {      let admin = get_admin_test_device();      let slot_data = OtpSlotData::new(1, "test-hotp", HOTP_SECRET, OtpMode::SixDigits); -    assert_eq!(CommandStatus::Success, admin.write_hotp_slot(slot_data, 0)); +    assert!(admin.write_hotp_slot(slot_data, 0).is_ok());      let device = admin.device();      let result = device.get_hotp_slot_name(1); @@ -102,12 +98,12 @@ fn hotp_error() {      let admin = get_admin_test_device();      let slot_data = OtpSlotData::new(1, "", HOTP_SECRET, OtpMode::SixDigits);      assert_eq!( -        CommandStatus::Error(CommandError::NoName), +        Err(CommandError::NoName),          admin.write_hotp_slot(slot_data, 0)      );      let slot_data = OtpSlotData::new(4, "test", HOTP_SECRET, OtpMode::SixDigits);      assert_eq!( -        CommandStatus::Error(CommandError::InvalidSlot), +        Err(CommandError::InvalidSlot),          admin.write_hotp_slot(slot_data, 0)      );      let code = admin.get_hotp_code(4); @@ -119,13 +115,13 @@ fn hotp_error() {  fn hotp_erase() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      let slot_data = OtpSlotData::new(1, "test1", HOTP_SECRET, OtpMode::SixDigits); -    assert_eq!(CommandStatus::Success, admin.write_hotp_slot(slot_data, 0)); +    assert!(admin.write_hotp_slot(slot_data, 0).is_ok());      let slot_data = OtpSlotData::new(2, "test2", HOTP_SECRET, OtpMode::SixDigits); -    assert_eq!(CommandStatus::Success, admin.write_hotp_slot(slot_data, 0)); +    assert!(admin.write_hotp_slot(slot_data, 0).is_ok()); -    assert_eq!(CommandStatus::Success, admin.erase_hotp_slot(1)); +    assert!(admin.erase_hotp_slot(1).is_ok());      let device = admin.device();      let result = device.get_hotp_slot_name(1); @@ -139,10 +135,7 @@ fn hotp_erase() {  fn configure_totp(admin: &ConfigureOtp, factor: u64) {      let slot_data = OtpSlotData::new(1, "test-totp", TOTP_SECRET, OtpMode::EightDigits);      let time_window = 30u64.checked_mul(factor).unwrap(); -    assert_eq!( -        CommandStatus::Success, -        admin.write_totp_slot(slot_data, time_window as u16) -    ); +    assert!(admin.write_totp_slot(slot_data, time_window as u16).is_ok());  }  fn check_totp_codes(device: &GenerateOtp, factor: u64, timestamp_size: TotpTimestampSize) { @@ -153,7 +146,7 @@ fn check_totp_codes(device: &GenerateOtp, factor: u64, timestamp_size: TotpTimes              continue;          } -        assert_eq!(CommandStatus::Success, device.set_time(time)); +        assert!(device.set_time(time).is_ok());          let result = device.get_totp_code(1);          assert!(result.is_ok());          let result_code = result.unwrap(); @@ -171,7 +164,7 @@ fn totp_no_pin() {      // TODO: this test may fail due to bad timing --> find solution      let admin = get_admin_test_device();      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_totp(&admin, 1);      check_totp_codes(admin.deref(), 1, TotpTimestampSize::U32); @@ -191,7 +184,7 @@ fn totp_no_pin() {  fn totp_no_pin_64() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_totp(&admin, 1);      check_totp_codes(admin.deref(), 1, TotpTimestampSize::U64); @@ -209,7 +202,7 @@ fn totp_pin() {      // TODO: this test may fail due to bad timing --> find solution      let admin = get_admin_test_device();      let config = Config::new(None, None, None, true); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_totp(&admin, 1);      let user = admin.device().authenticate_user(USER_PASSWORD).unwrap(); @@ -225,7 +218,7 @@ fn totp_pin() {  fn totp_pin_64() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, true); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      configure_totp(&admin, 1);      let user = admin.device().authenticate_user(USER_PASSWORD).unwrap(); @@ -239,7 +232,7 @@ fn totp_pin_64() {  fn totp_slot_name() {      let admin = get_admin_test_device();      let slot_data = OtpSlotData::new(1, "test-totp", TOTP_SECRET, OtpMode::EightDigits); -    assert_eq!(CommandStatus::Success, admin.write_totp_slot(slot_data, 0)); +    assert!(admin.write_totp_slot(slot_data, 0).is_ok());      let device = admin.device();      let result = device.get_totp_slot_name(1); @@ -255,12 +248,12 @@ fn totp_error() {      let admin = get_admin_test_device();      let slot_data = OtpSlotData::new(1, "", HOTP_SECRET, OtpMode::SixDigits);      assert_eq!( -        CommandStatus::Error(CommandError::NoName), +        Err(CommandError::NoName),          admin.write_hotp_slot(slot_data, 0)      );      let slot_data = OtpSlotData::new(4, "test", HOTP_SECRET, OtpMode::SixDigits);      assert_eq!( -        CommandStatus::Error(CommandError::InvalidSlot), +        Err(CommandError::InvalidSlot),          admin.write_hotp_slot(slot_data, 0)      );      let code = admin.get_hotp_code(4); @@ -272,13 +265,13 @@ fn totp_error() {  fn totp_erase() {      let admin = get_admin_test_device();      let config = Config::new(None, None, None, false); -    assert_eq!(CommandStatus::Success, admin.write_config(config)); +    assert!(admin.write_config(config).is_ok());      let slot_data = OtpSlotData::new(1, "test1", TOTP_SECRET, OtpMode::SixDigits); -    assert_eq!(CommandStatus::Success, admin.write_totp_slot(slot_data, 0)); +    assert!(admin.write_totp_slot(slot_data, 0).is_ok());      let slot_data = OtpSlotData::new(2, "test2", TOTP_SECRET, OtpMode::SixDigits); -    assert_eq!(CommandStatus::Success, admin.write_totp_slot(slot_data, 0)); +    assert!(admin.write_totp_slot(slot_data, 0).is_ok()); -    assert_eq!(CommandStatus::Success, admin.erase_totp_slot(1)); +    assert!(admin.erase_totp_slot(1).is_ok());      let device = admin.device();      let result = device.get_totp_slot_name(1); diff --git a/src/tests/pws.rs b/src/tests/pws.rs index 02e33cd..f581515 100644 --- a/src/tests/pws.rs +++ b/src/tests/pws.rs @@ -2,7 +2,7 @@ use device::Device;  use nitrokey_sys;  use pws::{GetPasswordSafe, PasswordSafe, SLOT_COUNT};  use tests::util::{Target, ADMIN_PASSWORD, USER_PASSWORD}; -use util::{result_from_string, CommandError, CommandStatus}; +use util::{result_from_string, CommandError};  fn get_pws(device: &Target) -> PasswordSafe {      device.get_password_safe(USER_PASSWORD).unwrap() @@ -28,17 +28,14 @@ fn drop() {      let device = Target::connect().unwrap();      {          let pws = get_pws(&device); -        assert_eq!( -            CommandStatus::Success, -            pws.write_slot(1, "name", "login", "password") -        ); +        assert!(pws.write_slot(1, "name", "login", "password").is_ok());          assert_eq!("name", pws.get_slot_name(1).unwrap());          let result = result_from_string(unsafe { nitrokey_sys::NK_get_password_safe_slot_name(1) });          assert_eq!(Ok(String::from("name")), result);      }      let result = result_from_string(unsafe { nitrokey_sys::NK_get_password_safe_slot_name(1) });      assert_eq!(Ok(String::from("name")), result); -    device.lock(); +    assert!(device.lock().is_ok());      let result = result_from_string(unsafe { nitrokey_sys::NK_get_password_safe_slot_name(1) });      assert_eq!(Err(CommandError::NotAuthorized), result);  } @@ -49,30 +46,19 @@ fn get_status() {      let device = Target::connect().unwrap();      let pws = get_pws(&device);      for i in 0..SLOT_COUNT { -        assert_eq!( -            CommandStatus::Success, -            pws.erase_slot(i), -            "Could not erase slot {}", -            i -        ); +        assert!(pws.erase_slot(i).is_ok(), "Could not erase slot {}", i);      }      let status = pws.get_slot_status().unwrap();      assert_eq!(status, [false; SLOT_COUNT as usize]); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(1, "name", "login", "password") -    ); +    assert!(pws.write_slot(1, "name", "login", "password").is_ok());      let status = pws.get_slot_status().unwrap();      for i in 0..SLOT_COUNT {          assert_eq!(i == 1, status[i as usize]);      }      for i in 0..SLOT_COUNT { -        assert_eq!( -            CommandStatus::Success, -            pws.write_slot(i, "name", "login", "password") -        ); +        assert!(pws.write_slot(i, "name", "login", "password").is_ok());      }      let status = pws.get_slot_status().unwrap();      assert_eq!(status, [true; SLOT_COUNT as usize]); @@ -83,15 +69,12 @@ fn get_status() {  fn get_data() {      let device = Target::connect().unwrap();      let pws = get_pws(&device); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(1, "name", "login", "password") -    ); +    assert!(pws.write_slot(1, "name", "login", "password").is_ok());      assert_eq!("name", pws.get_slot_name(1).unwrap());      assert_eq!("login", pws.get_slot_login(1).unwrap());      assert_eq!("password", pws.get_slot_password(1).unwrap()); -    assert_eq!(CommandStatus::Success, pws.erase_slot(1)); +    assert!(pws.erase_slot(1).is_ok());      // TODO: check error codes      assert_eq!(Err(CommandError::Unknown), pws.get_slot_name(1));      assert_eq!(Err(CommandError::Unknown), pws.get_slot_login(1)); @@ -100,10 +83,7 @@ fn get_data() {      let name = "with å";      let login = "pär@test.com";      let password = "'i3lJc[09?I:,[u7dWz9"; -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(1, name, login, password) -    ); +    assert!(pws.write_slot(1, name, login, password).is_ok());      assert_eq!(name, pws.get_slot_name(1).unwrap());      assert_eq!(login, pws.get_slot_login(1).unwrap());      assert_eq!(password, pws.get_slot_password(1).unwrap()); @@ -129,30 +109,21 @@ fn write() {      let pws = get_pws(&device);      assert_eq!( -        CommandStatus::Error(CommandError::InvalidSlot), +        Err(CommandError::InvalidSlot),          pws.write_slot(SLOT_COUNT, "name", "login", "password")      ); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(0, "", "login", "password") -    ); +    assert!(pws.write_slot(0, "", "login", "password").is_ok());      assert_eq!(Err(CommandError::Unknown), pws.get_slot_name(0));      assert_eq!(Ok(String::from("login")), pws.get_slot_login(0));      assert_eq!(Ok(String::from("password")), pws.get_slot_password(0)); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(0, "name", "", "password") -    ); +    assert!(pws.write_slot(0, "name", "", "password").is_ok());      assert_eq!(Ok(String::from("name")), pws.get_slot_name(0));      assert_eq!(Err(CommandError::Unknown), pws.get_slot_login(0));      assert_eq!(Ok(String::from("password")), pws.get_slot_password(0)); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(0, "name", "login", "") -    ); +    assert!(pws.write_slot(0, "name", "login", "").is_ok());      assert_eq!(Ok(String::from("name")), pws.get_slot_name(0));      assert_eq!(Ok(String::from("login")), pws.get_slot_login(0));      assert_eq!(Err(CommandError::Unknown), pws.get_slot_password(0)); @@ -163,16 +134,10 @@ fn write() {  fn erase() {      let device = Target::connect().unwrap();      let pws = get_pws(&device); -    assert_eq!( -        CommandStatus::Error(CommandError::InvalidSlot), -        pws.erase_slot(SLOT_COUNT) -    ); +    assert_eq!(Err(CommandError::InvalidSlot), pws.erase_slot(SLOT_COUNT)); -    assert_eq!( -        CommandStatus::Success, -        pws.write_slot(0, "name", "login", "password") -    ); -    assert_eq!(CommandStatus::Success, pws.erase_slot(0)); -    assert_eq!(CommandStatus::Success, pws.erase_slot(0)); +    assert!(pws.write_slot(0, "name", "login", "password").is_ok()); +    assert!(pws.erase_slot(0).is_ok()); +    assert!(pws.erase_slot(0).is_ok());      assert_eq!(Err(CommandError::Unknown), pws.get_slot_name(0));  } diff --git a/src/util.rs b/src/util.rs index 364b0de..1608952 100644 --- a/src/util.rs +++ b/src/util.rs @@ -39,15 +39,6 @@ pub enum CommandError {      RngError,  } -/// Command execution status. -#[derive(Debug, PartialEq)] -pub enum CommandStatus { -    /// The command was successful. -    Success, -    /// An error occured during command execution. -    Error(CommandError), -} -  /// Log level for libnitrokey.  ///  /// Setting the log level to a lower level enables all output from higher levels too.  Currently, @@ -90,17 +81,22 @@ pub fn result_from_string(ptr: *const c_char) -> Result<String, CommandError> {      }  } -pub fn get_last_status() -> CommandStatus { -    unsafe { -        let status = nitrokey_sys::NK_get_last_command_status(); -        return CommandStatus::from(status as c_int); +pub fn get_command_result(value: c_int) -> Result<(), CommandError> { +    match value { +        0 => Ok(()), +        other => Err(CommandError::from(other)),      }  } +pub fn get_last_result() -> Result<(), CommandError> { +    let value = unsafe { nitrokey_sys::NK_get_last_command_status() } as c_int; +    get_command_result(value) +} +  pub fn get_last_error() -> CommandError { -    return match get_last_status() { -        CommandStatus::Success => CommandError::Unknown, -        CommandStatus::Error(err) => err, +    return match get_last_result() { +        Ok(()) => CommandError::Unknown, +        Err(err) => err,      };  } @@ -133,15 +129,6 @@ impl From<c_int> for CommandError {      }  } -impl From<c_int> for CommandStatus { -    fn from(value: c_int) -> Self { -        match value { -            0 => CommandStatus::Success, -            other => CommandStatus::Error(CommandError::from(other)), -        } -    } -} -  impl Into<i32> for LogLevel {      fn into(self) -> i32 {          match self { | 
