// Copyright 2020 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. use proxy_wasm_experimental as proxy_wasm; use cfg_if::cfg_if; use chrono::{DateTime, Utc}; use log::info; use proxy_wasm::traits::*; use proxy_wasm::types::*; use std::time::Duration; #[cfg(not(all(target_arch = "wasm32", target_os = "unknown")))] use getrandom::getrandom; #[no_mangle] pub fn _start() { proxy_wasm::set_log_level(LogLevel::Trace); proxy_wasm::set_root_context(|_| -> Box { Box::new(HelloWorld) }); } struct HelloWorld; impl Context for HelloWorld {} impl RootContext for HelloWorld { fn on_vm_start(&mut self, _: usize) -> bool { info!("Hello, World!"); self.set_tick_period(Duration::from_secs(5)); true } fn on_tick(&mut self) { cfg_if! { if #[cfg(all(target_arch = "wasm32", target_os = "unknown"))] { let now: DateTime = self.get_current_time().into(); info!("It's {}, there is no lucky number.", now); } else { let now: DateTime = Utc::now(); let mut buf = [0u8; 1]; getrandom(&mut buf).unwrap(); info!("It's {}, your lucky number is {}.", now, buf[0]); } } } }