CTAP library move (#602)
* Moves all CTAP logic into its own library * workflows fix test * more coveralls workflow tests
This commit is contained in:
123
libraries/opensk/src/lib.rs
Normal file
123
libraries/opensk/src/lib.rs
Normal file
@@ -0,0 +1,123 @@
|
||||
// Copyright 2019-2022 Google LLC
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
#![cfg_attr(not(feature = "std"), no_std)]
|
||||
|
||||
extern crate alloc;
|
||||
#[macro_use]
|
||||
extern crate arrayref;
|
||||
|
||||
use crate::ctap::hid::{HidPacket, HidPacketIterator};
|
||||
use crate::ctap::main_hid::MainHid;
|
||||
#[cfg(feature = "vendor_hid")]
|
||||
use crate::ctap::vendor_hid::VendorHid;
|
||||
use crate::ctap::CtapState;
|
||||
pub use crate::ctap::Transport;
|
||||
use crate::env::Env;
|
||||
|
||||
// Those macros should eventually be split into trace, debug, info, warn, and error macros when
|
||||
// adding either the defmt or log feature and crate dependency.
|
||||
#[cfg(feature = "debug_ctap")]
|
||||
macro_rules! debug_ctap {
|
||||
($env: expr, $($rest:tt)*) => {{
|
||||
use core::fmt::Write;
|
||||
writeln!($env.write(), $($rest)*).unwrap();
|
||||
}};
|
||||
}
|
||||
#[cfg(not(feature = "debug_ctap"))]
|
||||
macro_rules! debug_ctap {
|
||||
($env: expr, $($rest:tt)*) => {
|
||||
// To avoid unused variable warnings.
|
||||
let _ = $env;
|
||||
};
|
||||
}
|
||||
|
||||
pub mod api;
|
||||
// TODO(kaczmarczyck): Refactor this so that ctap module isn't public.
|
||||
pub mod ctap;
|
||||
pub mod env;
|
||||
#[cfg(feature = "std")]
|
||||
pub mod test_helpers;
|
||||
|
||||
/// CTAP implementation parameterized by its environment.
|
||||
pub struct Ctap<E: Env> {
|
||||
env: E,
|
||||
state: CtapState<E>,
|
||||
hid: MainHid<E>,
|
||||
#[cfg(feature = "vendor_hid")]
|
||||
vendor_hid: VendorHid<E>,
|
||||
}
|
||||
|
||||
impl<E: Env> Ctap<E> {
|
||||
/// Instantiates a CTAP implementation given its environment.
|
||||
// This should only take the environment, but it temporarily takes the boot time until the
|
||||
// clock is part of the environment.
|
||||
pub fn new(mut env: E) -> Self {
|
||||
let state = CtapState::<E>::new(&mut env);
|
||||
let hid = MainHid::default();
|
||||
#[cfg(feature = "vendor_hid")]
|
||||
let vendor_hid = VendorHid::default();
|
||||
Ctap {
|
||||
env,
|
||||
state,
|
||||
hid,
|
||||
#[cfg(feature = "vendor_hid")]
|
||||
vendor_hid,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn state(&mut self) -> &mut CtapState<E> {
|
||||
&mut self.state
|
||||
}
|
||||
|
||||
pub fn hid(&mut self) -> &mut MainHid<E> {
|
||||
&mut self.hid
|
||||
}
|
||||
|
||||
pub fn env(&mut self) -> &mut E {
|
||||
&mut self.env
|
||||
}
|
||||
|
||||
pub fn process_hid_packet(
|
||||
&mut self,
|
||||
packet: &HidPacket,
|
||||
transport: Transport,
|
||||
) -> HidPacketIterator {
|
||||
match transport {
|
||||
Transport::MainHid => {
|
||||
self.hid
|
||||
.process_hid_packet(&mut self.env, packet, &mut self.state)
|
||||
}
|
||||
#[cfg(feature = "vendor_hid")]
|
||||
Transport::VendorHid => {
|
||||
self.vendor_hid
|
||||
.process_hid_packet(&mut self.env, packet, &mut self.state)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn should_wink(&mut self) -> bool {
|
||||
self.hid.should_wink(&mut self.env)
|
||||
}
|
||||
|
||||
#[cfg(feature = "with_ctap1")]
|
||||
pub fn u2f_grant_user_presence(&mut self) {
|
||||
self.state.u2f_grant_user_presence(&mut self.env)
|
||||
}
|
||||
|
||||
#[cfg(feature = "with_ctap1")]
|
||||
pub fn u2f_needs_user_presence(&mut self) -> bool {
|
||||
self.state.u2f_needs_user_presence(&mut self.env)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user