2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2020-09-06 02:34:02 +02:00
|
|
|
|
2020-09-14 18:48:57 +02:00
|
|
|
use deno_core::error::AnyError;
|
2023-09-12 00:10:43 +02:00
|
|
|
use deno_core::op2;
|
2020-06-11 13:00:29 +10:00
|
|
|
use deno_core::ModuleSpecifier;
|
2020-09-10 09:57:45 -04:00
|
|
|
use deno_core::OpState;
|
2024-06-06 23:37:53 -04:00
|
|
|
use deno_permissions::PermissionsContainer;
|
2020-01-28 03:12:25 +01:00
|
|
|
|
2023-03-17 12:22:15 -06:00
|
|
|
deno_core::extension!(
|
|
|
|
deno_runtime,
|
2023-05-01 14:21:27 -04:00
|
|
|
ops = [op_main_module, op_ppid],
|
2023-03-17 16:15:27 -06:00
|
|
|
options = { main_module: ModuleSpecifier },
|
|
|
|
state = |state, options| {
|
|
|
|
state.put::<ModuleSpecifier>(options.main_module);
|
2023-03-18 18:30:04 -04:00
|
|
|
},
|
2023-03-17 12:22:15 -06:00
|
|
|
);
|
2020-01-28 03:12:25 +01:00
|
|
|
|
2023-09-12 00:10:43 +02:00
|
|
|
#[op2]
|
|
|
|
#[string]
|
2022-03-14 23:38:53 +01:00
|
|
|
fn op_main_module(state: &mut OpState) -> Result<String, AnyError> {
|
2023-02-22 18:22:24 -05:00
|
|
|
let main_url = state.borrow::<ModuleSpecifier>();
|
|
|
|
let main_path = main_url.to_string();
|
2021-02-17 13:47:18 -05:00
|
|
|
if main_url.scheme() == "file" {
|
2023-02-22 18:22:24 -05:00
|
|
|
let main_path = main_url.to_file_path().unwrap();
|
2023-01-07 17:25:34 +01:00
|
|
|
state
|
|
|
|
.borrow_mut::<PermissionsContainer>()
|
|
|
|
.check_read_blind(&main_path, "main_module", "Deno.mainModule")?;
|
2020-06-11 13:00:29 +10:00
|
|
|
}
|
2023-02-22 18:22:24 -05:00
|
|
|
Ok(main_path)
|
2021-04-05 18:40:24 +02:00
|
|
|
}
|
|
|
|
|
2023-05-01 14:21:27 -04:00
|
|
|
/// This is an op instead of being done at initialization time because
|
2023-06-26 15:10:27 +02:00
|
|
|
/// it's expensive to retrieve the ppid on Windows.
|
2023-10-05 03:13:58 +05:30
|
|
|
#[op2(fast)]
|
2024-01-30 15:34:31 +09:00
|
|
|
#[number]
|
2023-05-01 14:21:27 -04:00
|
|
|
pub fn op_ppid() -> i64 {
|
2020-07-08 23:35:45 +09:00
|
|
|
#[cfg(windows)]
|
|
|
|
{
|
|
|
|
// Adopted from rustup:
|
|
|
|
// https://github.com/rust-lang/rustup/blob/1.21.1/src/cli/self_update.rs#L1036
|
|
|
|
// Copyright Diggory Blake, the Mozilla Corporation, and rustup contributors.
|
|
|
|
// Licensed under either of
|
|
|
|
// - Apache License, Version 2.0
|
|
|
|
// - MIT license
|
|
|
|
use std::mem;
|
|
|
|
use winapi::shared::minwindef::DWORD;
|
2023-01-14 20:18:58 -08:00
|
|
|
use winapi::um::handleapi::CloseHandle;
|
|
|
|
use winapi::um::handleapi::INVALID_HANDLE_VALUE;
|
2020-07-08 23:35:45 +09:00
|
|
|
use winapi::um::processthreadsapi::GetCurrentProcessId;
|
2023-01-14 20:18:58 -08:00
|
|
|
use winapi::um::tlhelp32::CreateToolhelp32Snapshot;
|
|
|
|
use winapi::um::tlhelp32::Process32First;
|
|
|
|
use winapi::um::tlhelp32::Process32Next;
|
|
|
|
use winapi::um::tlhelp32::PROCESSENTRY32;
|
|
|
|
use winapi::um::tlhelp32::TH32CS_SNAPPROCESS;
|
2022-07-15 12:30:25 -04:00
|
|
|
// SAFETY: winapi calls
|
2020-07-08 23:35:45 +09:00
|
|
|
unsafe {
|
|
|
|
// Take a snapshot of system processes, one of which is ours
|
|
|
|
// and contains our parent's pid
|
|
|
|
let snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
|
|
|
|
if snapshot == INVALID_HANDLE_VALUE {
|
2021-04-05 18:40:24 +02:00
|
|
|
return -1;
|
2020-07-08 23:35:45 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
let mut entry: PROCESSENTRY32 = mem::zeroed();
|
|
|
|
entry.dwSize = mem::size_of::<PROCESSENTRY32>() as DWORD;
|
|
|
|
|
|
|
|
// Iterate over system processes looking for ours
|
|
|
|
let success = Process32First(snapshot, &mut entry);
|
|
|
|
if success == 0 {
|
|
|
|
CloseHandle(snapshot);
|
2021-04-05 18:40:24 +02:00
|
|
|
return -1;
|
2020-07-08 23:35:45 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
let this_pid = GetCurrentProcessId();
|
|
|
|
while entry.th32ProcessID != this_pid {
|
|
|
|
let success = Process32Next(snapshot, &mut entry);
|
|
|
|
if success == 0 {
|
|
|
|
CloseHandle(snapshot);
|
2021-04-05 18:40:24 +02:00
|
|
|
return -1;
|
2020-07-08 23:35:45 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
CloseHandle(snapshot);
|
|
|
|
|
|
|
|
// FIXME: Using the process ID exposes a race condition
|
|
|
|
// wherein the parent process already exited and the OS
|
|
|
|
// reassigned its ID.
|
|
|
|
let parent_id = entry.th32ParentProcessID;
|
2021-04-05 18:40:24 +02:00
|
|
|
parent_id.into()
|
2020-07-08 23:35:45 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#[cfg(not(windows))]
|
|
|
|
{
|
|
|
|
use std::os::unix::process::parent_id;
|
2021-04-05 18:40:24 +02:00
|
|
|
parent_id().into()
|
2020-07-08 23:35:45 +09:00
|
|
|
}
|
|
|
|
}
|