diff options
Diffstat (limited to 'runtime')
-rw-r--r-- | runtime/js/90_deno_ns.js | 4 | ||||
-rw-r--r-- | runtime/ops/fs.rs | 7 |
2 files changed, 6 insertions, 5 deletions
diff --git a/runtime/js/90_deno_ns.js b/runtime/js/90_deno_ns.js index 84c6b7ade..bd56538d1 100644 --- a/runtime/js/90_deno_ns.js +++ b/runtime/js/90_deno_ns.js @@ -88,6 +88,8 @@ fsync: __bootstrap.fs.fsync, fdatasyncSync: __bootstrap.fs.fdatasyncSync, fdatasync: __bootstrap.fs.fdatasync, + link: __bootstrap.fs.link, + linkSync: __bootstrap.fs.linkSync, permissions: __bootstrap.permissions.permissions, Permissions: __bootstrap.permissions.Permissions, PermissionStatus: __bootstrap.permissions.PermissionStatus, @@ -122,8 +124,6 @@ ftruncateSync: __bootstrap.fs.ftruncateSync, ftruncate: __bootstrap.fs.ftruncate, umask: __bootstrap.fs.umask, - link: __bootstrap.fs.link, - linkSync: __bootstrap.fs.linkSync, futime: __bootstrap.fs.futime, futimeSync: __bootstrap.fs.futimeSync, utime: __bootstrap.fs.utime, diff --git a/runtime/ops/fs.rs b/runtime/ops/fs.rs index 629afbfe6..5f5425dfa 100644 --- a/runtime/ops/fs.rs +++ b/runtime/ops/fs.rs @@ -1140,13 +1140,14 @@ fn op_link_sync( args: Value, _zero_copy: &mut [ZeroCopyBuf], ) -> Result<Value, AnyError> { - super::check_unstable(state, "Deno.link"); let args: LinkArgs = serde_json::from_value(args)?; let oldpath = PathBuf::from(&args.oldpath); let newpath = PathBuf::from(&args.newpath); let permissions = state.borrow::<Permissions>(); permissions.check_read(&oldpath)?; + permissions.check_write(&oldpath)?; + permissions.check_read(&newpath)?; permissions.check_write(&newpath)?; debug!("op_link_sync {} {}", oldpath.display(), newpath.display()); @@ -1159,8 +1160,6 @@ async fn op_link_async( args: Value, _zero_copy: BufVec, ) -> Result<Value, AnyError> { - super::check_unstable2(&state, "Deno.link"); - let args: LinkArgs = serde_json::from_value(args)?; let oldpath = PathBuf::from(&args.oldpath); let newpath = PathBuf::from(&args.newpath); @@ -1169,6 +1168,8 @@ async fn op_link_async( let state = state.borrow(); let permissions = state.borrow::<Permissions>(); permissions.check_read(&oldpath)?; + permissions.check_write(&oldpath)?; + permissions.check_read(&newpath)?; permissions.check_write(&newpath)?; } |