diff options
author | Ryan Dahl <ry@tinyclouds.org> | 2020-09-10 09:57:45 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-10 09:57:45 -0400 |
commit | 7c2e7c660804afca823d60e6496aa853f75db16c (patch) | |
tree | b7746b181c1564c6b1abd2e906662f9e6b008417 /cli/ops/permissions.rs | |
parent | 6f70e6e72ba2d5c1de7495adac37c1e4f4e86b24 (diff) |
Use gotham-like state for ops (#7385)
Provides a concrete state type that can be dynamically added. This is necessary for op crates.
* renames BasicState to OpState
* async ops take `Rc<RefCell<OpState>>`
* sync ops take `&mut OpState`
* removes `OpRegistry`, `OpRouter` traits
* `get_error_class_fn` moved to OpState
* ResourceTable moved to OpState
Diffstat (limited to 'cli/ops/permissions.rs')
-rw-r--r-- | cli/ops/permissions.rs | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/cli/ops/permissions.rs b/cli/ops/permissions.rs index 90d21a726..76d105ba7 100644 --- a/cli/ops/permissions.rs +++ b/cli/ops/permissions.rs @@ -1,18 +1,16 @@ // Copyright 2018-2020 the Deno authors. All rights reserved. MIT license. -use crate::state::State; use deno_core::ErrBox; -use deno_core::OpRegistry; +use deno_core::OpState; use deno_core::ZeroCopyBuf; use serde_derive::Deserialize; use serde_json::Value; use std::path::Path; -use std::rc::Rc; -pub fn init(s: &Rc<State>) { - s.register_op_json_sync("op_query_permission", op_query_permission); - s.register_op_json_sync("op_revoke_permission", op_revoke_permission); - s.register_op_json_sync("op_request_permission", op_request_permission); +pub fn init(rt: &mut deno_core::JsRuntime) { + super::reg_json_sync(rt, "op_query_permission", op_query_permission); + super::reg_json_sync(rt, "op_revoke_permission", op_revoke_permission); + super::reg_json_sync(rt, "op_request_permission", op_request_permission); } #[derive(Deserialize)] @@ -23,12 +21,13 @@ struct PermissionArgs { } pub fn op_query_permission( - state: &State, + state: &mut OpState, args: Value, _zero_copy: &mut [ZeroCopyBuf], ) -> Result<Value, ErrBox> { let args: PermissionArgs = serde_json::from_value(args)?; - let permissions = state.permissions.borrow(); + let cli_state = super::cli_state(state); + let permissions = cli_state.permissions.borrow(); let path = args.path.as_deref(); let perm = match args.name.as_ref() { "read" => permissions.query_read(&path.as_deref().map(Path::new)), @@ -49,12 +48,13 @@ pub fn op_query_permission( } pub fn op_revoke_permission( - state: &State, + state: &mut OpState, args: Value, _zero_copy: &mut [ZeroCopyBuf], ) -> Result<Value, ErrBox> { let args: PermissionArgs = serde_json::from_value(args)?; - let mut permissions = state.permissions.borrow_mut(); + let cli_state = super::cli_state(state); + let mut permissions = cli_state.permissions.borrow_mut(); let path = args.path.as_deref(); let perm = match args.name.as_ref() { "read" => permissions.revoke_read(&path.as_deref().map(Path::new)), @@ -75,12 +75,13 @@ pub fn op_revoke_permission( } pub fn op_request_permission( - state: &State, + state: &mut OpState, args: Value, _zero_copy: &mut [ZeroCopyBuf], ) -> Result<Value, ErrBox> { let args: PermissionArgs = serde_json::from_value(args)?; - let permissions = &mut state.permissions.borrow_mut(); + let cli_state = super::cli_state(state); + let permissions = &mut cli_state.permissions.borrow_mut(); let path = args.path.as_deref(); let perm = match args.name.as_ref() { "read" => permissions.request_read(&path.as_deref().map(Path::new)), |