diff options
| author | Robin Krahl <robin.krahl@ireas.org> | 2019-01-01 23:38:14 +0000 | 
|---|---|---|
| committer | Robin Krahl <robin.krahl@ireas.org> | 2019-01-02 00:43:32 +0100 | 
| commit | 52afed9c6a17ec9c120a5a91b445afa74be87f0e (patch) | |
| tree | f2c177d068c61aea4ed85b134110bac25f027332 /src | |
| parent | bf1e181a1bbbc8e42d1313e80676c1955499b87c (diff) | |
| download | nitrokey-rs-52afed9c6a17ec9c120a5a91b445afa74be87f0e.tar.gz nitrokey-rs-52afed9c6a17ec9c120a5a91b445afa74be87f0e.tar.bz2 | |
Add force argument to ConfigureOtp::set_time
This patch adds the force argument to the set_time method in the
ConfigureOtp trait that allows the user to choose whether jumps to the
past are allowed when updating the time.  It is implemented by using the
NK_totp_set_time_soft function.  Previously, jumps where unconditionally
allowed.
Diffstat (limited to 'src')
| -rw-r--r-- | src/otp.rs | 33 | 
1 files changed, 19 insertions, 14 deletions
| @@ -151,27 +151,27 @@ pub trait ConfigureOtp {  /// Provides methods to generate OTP codes and to query OTP slots on a Nitrokey  /// device.  pub trait GenerateOtp { -    /// Sets the time on the Nitrokey.  This command may set the time to arbitrary values.  `time` -    /// is the number of seconds since January 1st, 1970 (Unix timestamp). +    /// Sets the time on the Nitrokey. +    /// +    /// `time` is the number of seconds since January 1st, 1970 (Unix timestamp).  Unless `force` +    /// is set to `true`, this command fails if the timestamp on the device is larger than the +    /// given timestamp or if it is zero.       ///      /// The time is used for TOTP generation (see [`get_totp_code`][]).      ///      /// # Example      /// -    /// ```ignore -    /// extern crate chrono; -    /// -    /// use chrono::Utc; -    /// use nitrokey::Device; +    /// ```no_run +    /// use std::time; +    /// use nitrokey::GenerateOtp;      /// # use nitrokey::CommandError;      ///      /// # fn try_main() -> Result<(), CommandError> {      /// let device = nitrokey::connect()?; -    /// let time = Utc::now().timestamp(); -    /// if time < 0 { -    ///     println!("Timestamps before 1970-01-01 are not supported!"); -    /// } else { -    ///     device.set_time(time as u64); +    /// let time = time::SystemTime::now().duration_since(time::UNIX_EPOCH); +    /// match time { +    ///     Ok(time) => device.set_time(time.as_secs(), false)?, +    ///     Err(_) => println!("The system time is before the Unix epoch!"),      /// }      /// #     Ok(())      /// # } @@ -183,8 +183,13 @@ pub trait GenerateOtp {      ///      /// [`get_totp_code`]: #method.get_totp_code      /// [`Timestamp`]: enum.CommandError.html#variant.Timestamp -    fn set_time(&self, time: u64) -> Result<(), CommandError> { -        unsafe { get_command_result(nitrokey_sys::NK_totp_set_time(time)) } +    fn set_time(&self, time: u64, force: bool) -> Result<(), CommandError> { +        let result = if force { +            unsafe { nitrokey_sys::NK_totp_set_time(time) } +        } else { +            unsafe { nitrokey_sys::NK_totp_set_time_soft(time) } +        }; +        get_command_result(result)      }      /// Returns the name of the given HOTP slot. | 
