2022-01-20 16:10:16 +09:00
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
2020-04-30 17:23:40 +02:00
/// <reference no-default-lib="true" />
/// <reference lib="deno.ns" />
declare namespace Deno {
2022-07-04 00:41:52 -05:00
export { } ; // stop default export type behavior
2022-08-17 13:12:24 +10:00
/** @category Testing */
2022-03-11 23:07:02 +01:00
export interface BenchDefinition {
fn : ( ) = > void | Promise < void > ;
name : string ;
ignore? : boolean ;
2022-04-20 22:06:39 +03:00
/ * * G r o u p n a m e f o r t h e b e n c h m a r k .
* Grouped benchmarks produce a time summary * /
group? : string ;
/ * * B e n c h m a r k s h o u l d b e u s e d a s t h e b a s e l i n e f o r o t h e r b e n c h m a r k s
* If there are multiple baselines in a group , the first one is used as the baseline * /
baseline? : boolean ;
2022-03-11 23:07:02 +01:00
/ * * I f a t l e a s t o n e b e n c h h a s ` o n l y ` s e t t o t r u e , o n l y r u n b e n c h e s t h a t h a v e
* ` only ` set to true and fail the bench suite . * /
only? : boolean ;
/ * * E n s u r e t h e b e n c h c a s e d o e s n o t p r e m a t u r e l y c a u s e t h e p r o c e s s t o e x i t ,
* for example via a call to ` Deno.exit ` . Defaults to true . * /
sanitizeExit? : boolean ;
/ * * S p e c i f i e s t h e p e r m i s s i o n s t h a t s h o u l d b e u s e d t o r u n t h e b e n c h .
* Set this to "inherit" to keep the calling thread ' s permissions .
* Set this to "none" to revoke all permissions .
*
* Defaults to "inherit" .
* /
permissions? : Deno.PermissionOptions ;
}
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required .
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( {
* name : "example test" ,
* fn ( ) : void {
* assertEquals ( "world" , "world" ) ;
* } ,
* } ) ;
*
* Deno . bench ( {
* name : "example ignored test" ,
* ignore : Deno.build.os === "windows" ,
* fn ( ) : void {
* // This test is ignored only on Windows machines
* } ,
* } ) ;
*
* Deno . bench ( {
* name : "example async test" ,
* async fn() {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* }
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench ( t : BenchDefinition ) : void ;
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required .
*
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( "My test description" , ( ) : void = > {
* assertEquals ( "hello" , "hello" ) ;
* } ) ;
*
* Deno . bench ( "My async test description" , async ( ) : Promise < void > = > {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench (
name : string ,
fn : ( ) = > void | Promise < void > ,
) : void ;
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required . Declared function must have a name .
*
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( function myTestName ( ) : void {
* assertEquals ( "hello" , "hello" ) ;
* } ) ;
*
* Deno . bench ( async function myOtherTestName ( ) : Promise < void > {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench ( fn : ( ) = > void | Promise < void > ) : void ;
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required .
*
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( "My test description" , { permissions : { read : true } } , ( ) : void = > {
* assertEquals ( "hello" , "hello" ) ;
* } ) ;
*
* Deno . bench ( "My async test description" , { permissions : { read : false } } , async ( ) : Promise < void > = > {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench (
name : string ,
options : Omit < BenchDefinition , "fn" | "name" > ,
fn : ( ) = > void | Promise < void > ,
) : void ;
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required .
*
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( { name : "My test description" , permissions : { read : true } } , ( ) : void = > {
* assertEquals ( "hello" , "hello" ) ;
* } ) ;
*
* Deno . bench ( { name : "My async test description" , permissions : { read : false } } , async ( ) : Promise < void > = > {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench (
options : Omit < BenchDefinition , "fn" > ,
fn : ( ) = > void | Promise < void > ,
) : void ;
/ * * R e g i s t e r a b e n c h w h i c h w i l l b e r u n w h e n ` d e n o b e n c h ` i s u s e d o n t h e c o m m a n d
* line and the containing module looks like a bench module .
* ` fn ` can be async if required . Declared function must have a name .
*
* ` ` ` ts
* import { assert , fail , assertEquals } from "https://deno.land/std/testing/asserts.ts" ;
*
* Deno . bench ( { permissions : { read : true } } , function myTestName ( ) : void {
* assertEquals ( "hello" , "hello" ) ;
* } ) ;
*
* Deno . bench ( { permissions : { read : false } } , async function myOtherTestName ( ) : Promise < void > {
* const decoder = new TextDecoder ( "utf-8" ) ;
* const data = await Deno . readFile ( "hello_world.txt" ) ;
* assertEquals ( decoder . decode ( data ) , "Hello world" ) ;
* } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Testing
2022-03-11 23:07:02 +01:00
* /
export function bench (
options : Omit < BenchDefinition , "fn" | "name" > ,
fn : ( ) = > void | Promise < void > ,
) : void ;
2022-09-13 02:23:34 +01:00
/ * * T h i s A P I i s u n d e r c o n s i d e r a t i o n t o d e t e r m i n e i f p e r m i s s i o n s a r e r e q u i r e d t o c a l l i t .
2020-04-30 17:23:40 +02:00
*
* Retrieve the process umask . If ` mask ` is provided , sets the process umask .
* This call always returns what the umask was before the call .
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* console . log ( Deno . umask ( ) ) ; // e.g. 18 (0o022)
* const prevUmaskValue = Deno . umask ( 0 o077 ) ; // e.g. 18 (0o022)
* console . log ( Deno . umask ( ) ) ; // e.g. 63 (0o077)
* ` ` `
2020-04-30 17:23:40 +02:00
*
* NOTE : This API is not implemented on Windows
2022-08-17 13:12:24 +10:00
*
* @category File System
2020-04-30 17:23:40 +02:00
* /
export function umask ( mask? : number ) : number ;
2022-09-13 02:23:34 +01:00
/ * * G e t s t h e s i z e o f t h e c o n s o l e a s c o l u m n s / r o w s .
2020-07-10 10:07:12 -04:00
*
* ` ` ` ts
2020-08-11 11:22:10 +08:00
* const { columns , rows } = Deno . consoleSize ( Deno . stdout . rid ) ;
2020-07-10 10:07:12 -04:00
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category I / O
2020-07-10 10:07:12 -04:00
* /
export function consoleSize (
2020-07-14 15:24:17 -04:00
rid : number ,
2020-07-10 10:07:12 -04:00
) : {
columns : number ;
rows : number ;
} ;
2022-09-13 02:23:34 +01:00
/ * * T h e r e a r e q u e s t i o n s a r o u n d w h i c h p e r m i s s i o n t h i s n e e d s . A n d
2020-06-03 18:46:09 +01:00
* maybe should be renamed ( loadAverage ? )
*
* Returns an array containing the 1 , 5 , and 15 minute load averages . The
2020-04-30 17:23:40 +02:00
* load average is a measure of CPU and IO utilization of the last one , five ,
* and 15 minute periods expressed as a fractional number . Zero means there
* is no load . On Windows , the three values are always the same and represent
* the current load , not the 1 , 5 and 15 minute load averages .
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* console . log ( Deno . loadavg ( ) ) ; // e.g. [ 0.71, 0.44, 0.44 ]
* ` ` `
2020-04-30 17:23:40 +02:00
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Observability
2020-04-30 17:23:40 +02:00
* /
export function loadavg ( ) : number [ ] ;
2022-09-13 02:23:34 +01:00
/ * * U n d e r c o n s i d e r a t i o n t o p o s s i b l y m o v e t o
2020-06-03 18:46:09 +01:00
* Deno . build or Deno . versions and if it should depend sys - info , which may not
* be desireable .
*
* Returns the release version of the Operating System .
2020-04-30 17:23:40 +02:00
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* console . log ( Deno . osRelease ( ) ) ;
* ` ` `
2020-04-30 17:23:40 +02:00
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Runtime Environment
2020-04-30 17:23:40 +02:00
* /
export function osRelease ( ) : string ;
2022-09-13 02:23:34 +01:00
/ * * D i s p l a y s t h e t o t a l a m o u n t o f f r e e a n d u s e d p h y s i c a l a n d s w a p m e m o r y i n t h e
2020-09-10 14:08:17 +05:30
* system , as well as the buffers and caches used by the kernel .
2020-09-19 22:30:59 +01:00
*
2020-09-10 14:08:17 +05:30
* This is similar to the ` free ` command in Linux
*
* ` ` ` ts
* console . log ( Deno . systemMemoryInfo ( ) ) ;
* ` ` `
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Runtime Environment
2020-09-10 14:08:17 +05:30
* /
export function systemMemoryInfo ( ) : SystemMemoryInfo ;
2022-09-08 01:47:47 +01:00
/** @category Runtime Environment */
2020-09-10 14:08:17 +05:30
export interface SystemMemoryInfo {
/** Total installed memory */
total : number ;
/** Unused memory */
free : number ;
/ * * E s t i m a t i o n o f h o w m u c h m e m o r y i s a v a i l a b l e f o r s t a r t i n g n e w
* applications , without swapping . Unlike the data provided by the cache or
* free fields , this field takes into account page cache and also that not
* all reclaimable memory slabs will be reclaimed due to items being in use
* /
available : number ;
/** Memory used by kernel buffers */
buffers : number ;
/** Memory used by the page cache and slabs */
cached : number ;
/** Total swap memory */
swapTotal : number ;
/** Unused swap memory */
swapFree : number ;
}
2022-08-17 13:12:24 +10:00
/ * * T h e i n f o r m a t i o n o f t h e n e t w o r k i n t e r f a c e .
*
* @category Network
* /
2022-01-24 18:39:28 +09:00
export interface NetworkInterfaceInfo {
/** The network interface name */
name : string ;
/** The IP protocol version */
family : "IPv4" | "IPv6" ;
/** The IP address */
address : string ;
/** The netmask */
netmask : string ;
/** The IPv6 scope id or null */
scopeid : number | null ;
/** The CIDR range */
cidr : string ;
/** The MAC address */
mac : string ;
}
2022-09-13 02:23:34 +01:00
/ * * R e t u r n s a n a r r a y o f t h e n e t w o r k i n t e r f a c e i n f o r m a t i o n s .
2022-01-24 18:39:28 +09:00
*
* ` ` ` ts
* console . log ( Deno . networkInterfaces ( ) ) ;
* ` ` `
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Network
2022-01-24 18:39:28 +09:00
* /
export function networkInterfaces ( ) : NetworkInterfaceInfo [ ] ;
2022-01-31 14:44:19 +09:00
2022-09-13 02:23:34 +01:00
/ * * R e t u r n s t h e u s e r i d o f t h e p r o c e s s o n P O S I X p l a t f o r m s . R e t u r n s n u l l o n w i n d o w s .
2022-01-31 14:44:19 +09:00
*
* ` ` ` ts
* console . log ( Deno . getUid ( ) ) ;
* ` ` `
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Runtime Environment
2022-01-31 14:44:19 +09:00
* /
export function getUid ( ) : number | null ;
2022-05-31 10:42:44 +02:00
2022-09-13 02:23:34 +01:00
/ * * R e t u r n s t h e g r o u p i d o f t h e p r o c e s s o n P O S I X p l a t f o r m s . R e t u r n s n u l l o n w i n d o w s .
2022-05-31 10:42:44 +02:00
*
* ` ` ` ts
* console . log ( Deno . getGid ( ) ) ;
* ` ` `
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Runtime Environment
2022-05-31 10:42:44 +02:00
* /
export function getGid ( ) : number | null ;
2022-01-24 18:39:28 +09:00
2022-08-17 13:12:24 +10:00
/ * * A l l p l a i n n u m b e r t y p e s f o r i n t e r f a c i n g w i t h f o r e i g n f u n c t i o n s .
*
* @category FFI
* /
2022-06-21 05:50:33 +03:00
type NativeNumberType =
2021-08-06 23:28:10 +02:00
| "u8"
| "i8"
| "u16"
| "i16"
| "u32"
| "i32"
2022-06-21 05:50:33 +03:00
| "f32"
| "f64" ;
2022-08-17 13:12:24 +10:00
/ * * A l l B i g I n t n u m b e r t y p e s f o r i n t e r f a c i n g w i t h f o r e i g n f u n c t i o n s .
*
* @category FFI
* /
2022-06-21 05:50:33 +03:00
type NativeBigIntType =
2021-08-06 23:28:10 +02:00
| "u64"
| "i64"
| "usize"
2022-06-21 05:50:33 +03:00
| "isize" ;
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-09-05 06:26:52 +03:00
type NativeBooleanType = "bool" ;
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
type NativePointerType = "pointer" ;
2021-08-06 23:28:10 +02:00
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-08-23 09:16:43 +05:30
type NativeBufferType = "buffer" ;
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
type NativeFunctionType = "function" ;
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
type NativeVoidType = "void" ;
2022-08-17 13:12:24 +10:00
/ * * A l l p o s s i b l e t y p e s f o r i n t e r f a c i n g w i t h f o r e i g n f u n c t i o n s .
*
* @category FFI
* /
2022-06-21 05:50:33 +03:00
export type NativeType =
| NativeNumberType
| NativeBigIntType
2022-09-05 06:26:52 +03:00
| NativeBooleanType
2022-06-21 05:50:33 +03:00
| NativePointerType
2022-08-23 09:16:43 +05:30
| NativeBufferType
2022-06-21 05:50:33 +03:00
| NativeFunctionType ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
export type NativeResultType = NativeType | NativeVoidType ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type ToNativeTypeMap =
& Record < NativeNumberType , number >
2022-07-24 13:41:11 +03:00
& Record < NativeBigIntType , PointerValue >
2022-09-05 06:26:52 +03:00
& Record < NativeBooleanType , boolean >
2022-08-23 09:16:43 +05:30
& Record < NativePointerType , PointerValue | null >
& Record < NativeFunctionType , PointerValue | null >
2022-09-01 20:31:05 +03:00
& Record < NativeBufferType , TypedArray | null > ;
2022-06-27 07:41:58 -05:00
2022-08-17 13:12:24 +10:00
/ * * T y p e c o n v e r s i o n f o r f o r e i g n s y m b o l p a r a m e t e r s a n d u n s a f e c a l l b a c k r e t u r n
* types .
*
* @category FFI
* /
2022-06-27 07:41:58 -05:00
type ToNativeType < T extends NativeType = NativeType > = ToNativeTypeMap [ T ] ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type ToNativeResultTypeMap = ToNativeTypeMap & Record < NativeVoidType , void > ;
2022-06-21 05:50:33 +03:00
2022-08-17 13:12:24 +10:00
/ * * T y p e c o n v e r s i o n f o r u n s a f e c a l l b a c k r e t u r n t y p e s .
*
* @category FFI
* /
2022-06-21 05:50:33 +03:00
type ToNativeResultType < T extends NativeResultType = NativeResultType > =
2022-06-27 07:41:58 -05:00
ToNativeResultTypeMap [ T ] ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type ToNativeParameterTypes < T extends readonly NativeType [ ] > =
//
[ ( T [ number ] ) [ ] ] extends [ T ] ? ToNativeType < T [ number ] > [ ]
: [ readonly ( T [ number ] ) [ ] ] extends [ T ]
? readonly ToNativeType < T [ number ] > [ ]
: T extends readonly [ . . . NativeType [ ] ] ? {
[ K in keyof T ] : ToNativeType < T [ K ] > ;
}
2022-06-21 05:50:33 +03:00
: never ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type FromNativeTypeMap =
& Record < NativeNumberType , number >
2022-07-24 13:41:11 +03:00
& Record < NativeBigIntType , PointerValue >
2022-09-05 06:26:52 +03:00
& Record < NativeBooleanType , boolean >
2022-07-24 13:41:11 +03:00
& Record < NativePointerType , PointerValue >
2022-08-23 09:16:43 +05:30
& Record < NativeBufferType , PointerValue >
2022-07-24 13:41:11 +03:00
& Record < NativeFunctionType , PointerValue > ;
2022-06-21 05:50:33 +03:00
2022-08-17 13:12:24 +10:00
/ * * T y p e c o n v e r s i o n f o r f o r e i g n s y m b o l r e t u r n t y p e s a n d u n s a f e c a l l b a c k
* parameters .
*
* @category FFI
* /
2022-06-27 07:41:58 -05:00
type FromNativeType < T extends NativeType = NativeType > = FromNativeTypeMap [ T ] ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type FromNativeResultTypeMap =
& FromNativeTypeMap
& Record < NativeVoidType , void > ;
2022-06-21 05:50:33 +03:00
2022-08-17 13:12:24 +10:00
/ * * T y p e c o n v e r s i o n f o r f o r e i g n s y m b o l r e t u r n t y p e s .
*
* @category FFI
* /
2022-06-21 05:50:33 +03:00
type FromNativeResultType < T extends NativeResultType = NativeResultType > =
2022-06-27 07:41:58 -05:00
FromNativeResultTypeMap [ T ] ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-27 07:41:58 -05:00
type FromNativeParameterTypes <
T extends readonly NativeType [ ] ,
> =
//
[ ( T [ number ] ) [ ] ] extends [ T ] ? FromNativeType < T [ number ] > [ ]
: [ readonly ( T [ number ] ) [ ] ] extends [ T ]
? readonly FromNativeType < T [ number ] > [ ]
: T extends readonly [ . . . NativeType [ ] ] ? {
[ K in keyof T ] : FromNativeType < T [ K ] > ;
}
2022-06-21 05:50:33 +03:00
: never ;
2022-08-17 13:12:24 +10:00
/ * * A f o r e i g n f u n c t i o n a s d e f i n e d b y i t s p a r a m e t e r a n d r e s u l t t y p e s .
*
* @category FFI
* /
2022-01-10 21:03:25 +05:30
export interface ForeignFunction <
2022-06-21 05:50:33 +03:00
Parameters extends readonly NativeType [ ] = readonly NativeType [ ] ,
Result extends NativeResultType = NativeResultType ,
2022-01-10 21:03:25 +05:30
NonBlocking extends boolean = boolean ,
> {
2022-01-11 11:51:16 +05:30
/** Name of the symbol, defaults to the key name in symbols object. */
name? : string ;
2022-01-10 21:03:25 +05:30
parameters : Parameters ;
result : Result ;
2021-10-11 18:39:11 +05:30
/** When true, function calls will run on a dedicated blocking thread and will return a Promise resolving to the `result`. */
2022-01-10 21:03:25 +05:30
nonblocking? : NonBlocking ;
2022-07-09 18:41:07 +05:30
/** When true, function calls can safely callback into JS or trigger a GC event. Default is `false`. */
callback? : boolean ;
2021-08-06 23:28:10 +02:00
}
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-02-18 14:21:19 +02:00
export interface ForeignStatic < Type extends NativeType = NativeType > {
/** Name of the symbol, defaults to the key name in symbols object. */
name? : string ;
2022-06-21 05:50:33 +03:00
type : Type ;
2022-02-18 14:21:19 +02:00
}
2022-08-17 13:12:24 +10:00
/ * * A f o r e i g n l i b r a r y i n t e r f a c e d e s c r i p t o r .
*
* @category FFI
* /
2022-02-18 14:21:19 +02:00
export interface ForeignLibraryInterface {
[ name : string ] : ForeignFunction | ForeignStatic ;
2022-01-10 21:03:25 +05:30
}
2022-08-17 13:12:24 +10:00
/ * * I n f e r s a f o r e i g n s y m b o l .
*
* @category FFI
* /
2022-02-18 14:21:19 +02:00
type StaticForeignSymbol < T extends ForeignFunction | ForeignStatic > =
2022-06-21 05:50:33 +03:00
T extends ForeignFunction ? FromForeignFunction < T >
: T extends ForeignStatic ? FromNativeType < T [ "type" ] >
2022-02-18 14:21:19 +02:00
: never ;
2022-01-10 21:03:25 +05:30
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
type FromForeignFunction < T extends ForeignFunction > = T [ "parameters" ] extends
readonly [ ] ? ( ) = > StaticForeignSymbolReturnType < T >
: (
. . . args : ToNativeParameterTypes < T [ "parameters" ] >
) = > StaticForeignSymbolReturnType < T > ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-06-21 05:50:33 +03:00
type StaticForeignSymbolReturnType < T extends ForeignFunction > =
ConditionalAsync < T [ "nonblocking" ] , FromNativeResultType < T [ "result" ] > > ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2022-01-10 21:03:25 +05:30
type ConditionalAsync < IsAsync extends boolean | undefined , T > =
IsAsync extends true ? Promise < T > : T ;
2022-08-17 13:12:24 +10:00
/ * * I n f e r s a f o r e i g n l i b r a r y i n t e r f a c e .
*
* @category FFI
* /
2022-02-18 14:21:19 +02:00
type StaticForeignLibraryInterface < T extends ForeignLibraryInterface > = {
[ K in keyof T ] : StaticForeignSymbol < T [ K ] > ;
2022-01-10 21:03:25 +05:30
} ;
2022-08-17 13:12:24 +10:00
/** @category FFI */
2021-12-15 15:41:49 +01:00
type TypedArray =
| Int8Array
| Uint8Array
| Int16Array
| Uint16Array
| Int32Array
| Uint32Array
| Uint8ClampedArray
| Float32Array
| Float64Array
| BigInt64Array
| BigUint64Array ;
2022-07-24 13:41:11 +03:00
/ * *
* Pointer type depends on the architecture and actual pointer value .
*
* On a 32 bit system all pointer values are plain numbers . On a 64 bit
* system pointer values are represented as numbers if the value is below
* ` Number.MAX_SAFE_INTEGER ` .
2022-08-17 13:12:24 +10:00
*
* @category FFI
2022-07-24 13:41:11 +03:00
* /
export type PointerValue = number | bigint ;
2022-09-13 02:23:34 +01:00
/ * * A n u n s a f e p o i n t e r t o a m e m o r y l o c a t i o n f o r p a s s i n g a n d r e t u r n i n g p o i n t e r s
2022-08-17 13:12:24 +10:00
* to and from the FFI .
*
* @category FFI
2021-12-15 15:41:49 +01:00
* /
export class UnsafePointer {
/ * *
* Return the direct memory pointer to the typed array in memory
* /
2022-07-24 13:41:11 +03:00
static of ( value : Deno.UnsafeCallback | TypedArray ) : PointerValue ;
2021-12-15 15:41:49 +01:00
}
2022-09-13 02:23:34 +01:00
/ * * A n u n s a f e p o i n t e r v i e w t o a m e m o r y l o c a t i o n a s s p e c i f i e d b y t h e ` p o i n t e r `
2021-12-15 15:41:49 +01:00
* value . The ` UnsafePointerView ` API mimics the standard built in interface
* ` DataView ` for accessing the underlying types at an memory location
* ( numbers , strings and raw bytes ) .
2022-08-17 13:12:24 +10:00
*
* @category FFI
2021-12-15 15:41:49 +01:00
* /
export class UnsafePointerView {
2022-06-20 19:08:10 +05:30
constructor ( pointer : bigint ) ;
2021-12-15 15:41:49 +01:00
2022-06-20 19:08:10 +05:30
pointer : bigint ;
2021-12-15 15:41:49 +01:00
2022-09-05 06:26:52 +03:00
/** Gets a boolean at the specified byte offset from the pointer. */
getBool ( offset? : number ) : boolean ;
2021-12-15 15:41:49 +01:00
/** Gets an unsigned 8-bit integer at the specified byte offset from the pointer. */
getUint8 ( offset? : number ) : number ;
/** Gets a signed 8-bit integer at the specified byte offset from the pointer. */
getInt8 ( offset? : number ) : number ;
/** Gets an unsigned 16-bit integer at the specified byte offset from the pointer. */
getUint16 ( offset? : number ) : number ;
/** Gets a signed 16-bit integer at the specified byte offset from the pointer. */
getInt16 ( offset? : number ) : number ;
/** Gets an unsigned 32-bit integer at the specified byte offset from the pointer. */
getUint32 ( offset? : number ) : number ;
/** Gets a signed 32-bit integer at the specified byte offset from the pointer. */
getInt32 ( offset? : number ) : number ;
/** Gets an unsigned 64-bit integer at the specified byte offset from the pointer. */
2022-07-24 13:41:11 +03:00
getBigUint64 ( offset? : number ) : PointerValue ;
2021-12-15 15:41:49 +01:00
/** Gets a signed 64-bit integer at the specified byte offset from the pointer. */
2022-07-24 13:41:11 +03:00
getBigInt64 ( offset? : number ) : PointerValue ;
2021-12-15 15:41:49 +01:00
/** Gets a signed 32-bit float at the specified byte offset from the pointer. */
getFloat32 ( offset? : number ) : number ;
/** Gets a signed 64-bit float at the specified byte offset from the pointer. */
getFloat64 ( offset? : number ) : number ;
/** Gets a C string (null terminated string) at the specified byte offset from the pointer. */
getCString ( offset? : number ) : string ;
2022-08-05 19:27:12 +03:00
/** Gets a C string (null terminated string) at the specified byte offset from the specified pointer. */
2022-09-01 20:31:05 +03:00
static getCString ( pointer : PointerValue , offset? : number ) : string ;
2021-12-15 15:41:49 +01:00
/** Gets an ArrayBuffer of length `byteLength` at the specified byte offset from the pointer. */
getArrayBuffer ( byteLength : number , offset? : number ) : ArrayBuffer ;
2022-08-05 19:27:12 +03:00
/** Gets an ArrayBuffer of length `byteLength` at the specified byte offset from the specified pointer. */
static getArrayBuffer (
2022-09-01 20:31:05 +03:00
pointer : PointerValue ,
2022-08-05 19:27:12 +03:00
byteLength : number ,
offset? : number ,
) : ArrayBuffer ;
/** Copies the memory of the pointer into a typed array. Length is determined from the typed array's `byteLength`. Also takes optional byte offset from the pointer. */
2021-12-15 15:41:49 +01:00
copyInto ( destination : TypedArray , offset? : number ) : void ;
2022-08-05 19:27:12 +03:00
/** Copies the memory of the specified pointer into a typed array. Length is determined from the typed array's `byteLength`. Also takes optional byte offset from the pointer. */
static copyInto (
2022-09-01 20:31:05 +03:00
pointer : PointerValue ,
2022-08-05 19:27:12 +03:00
destination : TypedArray ,
offset? : number ,
) : void ;
2021-12-15 15:41:49 +01:00
}
2022-09-13 02:23:34 +01:00
/ * * A n u n s a f e p o i n t e r t o a f u n c t i o n , f o r c a l l i n g f u n c t i o n s t h a t a r e n o t
2022-01-12 17:08:26 +05:30
* present as symbols .
2022-08-17 13:12:24 +10:00
*
* @category FFI
2022-01-12 17:08:26 +05:30
* /
export class UnsafeFnPointer < Fn extends ForeignFunction > {
2022-06-20 19:08:10 +05:30
pointer : bigint ;
2022-01-12 17:08:26 +05:30
definition : Fn ;
2022-06-20 19:08:10 +05:30
constructor ( pointer : bigint , definition : Fn ) ;
2022-01-12 17:08:26 +05:30
2022-06-21 05:50:33 +03:00
call : FromForeignFunction < Fn > ;
2022-01-12 17:08:26 +05:30
}
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-06-20 14:06:04 +03:00
export interface UnsafeCallbackDefinition <
Parameters extends readonly NativeType [ ] = readonly NativeType [ ] ,
2022-06-21 05:50:33 +03:00
Result extends NativeResultType = NativeResultType ,
2022-06-20 14:06:04 +03:00
> {
parameters : Parameters ;
result : Result ;
}
2022-09-08 01:47:47 +01:00
/** @category FFI */
2022-06-20 14:06:04 +03:00
type UnsafeCallbackFunction <
Parameters extends readonly NativeType [ ] = readonly NativeType [ ] ,
2022-06-21 05:50:33 +03:00
Result extends NativeResultType = NativeResultType ,
> = Parameters extends readonly [ ] ? ( ) = > ToNativeResultType < Result > : (
. . . args : FromNativeParameterTypes < Parameters >
) = > ToNativeResultType < Result > ;
2022-06-20 14:06:04 +03:00
2022-09-13 02:23:34 +01:00
/ * * A n u n s a f e f u n c t i o n p o i n t e r f o r p a s s i n g J a v a S c r i p t f u n c t i o n s
2022-06-20 14:06:04 +03:00
* as C function pointers to ffi calls .
*
* The function pointer remains valid until the ` close() ` method is called .
2022-06-28 12:23:36 +03:00
*
* The callback can be explicitly ref 'ed and deref' ed to stop Deno ' s
* process from exiting .
2022-08-17 13:12:24 +10:00
*
* @category FFI
2022-06-20 14:06:04 +03:00
* /
export class UnsafeCallback <
2022-06-21 05:50:33 +03:00
Definition extends UnsafeCallbackDefinition = UnsafeCallbackDefinition ,
2022-06-20 14:06:04 +03:00
> {
constructor (
2022-06-21 05:50:33 +03:00
definition : Definition ,
callback : UnsafeCallbackFunction <
Definition [ "parameters" ] ,
Definition [ "result" ]
> ,
2022-06-20 14:06:04 +03:00
) ;
2022-06-20 19:08:10 +05:30
pointer : bigint ;
2022-06-21 05:50:33 +03:00
definition : Definition ;
callback : UnsafeCallbackFunction <
Definition [ "parameters" ] ,
Definition [ "result" ]
> ;
2022-06-20 14:06:04 +03:00
2022-06-28 12:23:36 +03:00
/ * *
* Adds one to this callback ' s reference counting .
*
* If the callback ' s reference count becomes non - zero , it will keep
* Deno ' s process from exiting .
* /
ref ( ) : void ;
/ * *
* Removes one from this callback ' s reference counting .
*
* If the callback ' s reference counter becomes zero , it will no longer
* keep Deno ' s process from exiting .
* /
unref ( ) : void ;
/ * *
* Removes the C function pointer associated with the UnsafeCallback .
* Continuing to use the instance after calling this object will lead to errors
* and crashes .
*
* Calling this method will also immediately set the callback ' s reference
* counting to zero and it will no longer keep Deno ' s process from exiting .
* /
2022-06-20 14:06:04 +03:00
close ( ) : void ;
}
2022-09-08 01:47:47 +01:00
/ * *
* A dynamic library resource
*
* @category FFI
* /
2022-02-18 14:21:19 +02:00
export interface DynamicLibrary < S extends ForeignLibraryInterface > {
/** All of the registered library along with functions for calling them */
symbols : StaticForeignLibraryInterface < S > ;
2021-08-06 23:28:10 +02:00
close ( ) : void ;
}
2022-09-13 02:23:34 +01:00
/ * * O p e n s a d y n a m i c l i b r a r y a n d r e g i s t e r s s y m b o l s
2022-08-17 13:12:24 +10:00
*
* @category FFI
2021-07-11 18:12:26 -07:00
* /
2022-02-18 14:21:19 +02:00
export function dlopen < S extends ForeignLibraryInterface > (
2021-08-24 14:09:00 +01:00
filename : string | URL ,
2021-08-06 23:28:10 +02:00
symbols : S ,
) : DynamicLibrary < S > ;
2021-07-11 18:12:26 -07:00
2022-08-17 13:12:24 +10:00
/** @category I/O */
2020-11-30 10:08:03 -06:00
export type SetRawOptions = {
cbreak : boolean ;
} ;
2022-09-13 02:23:34 +01:00
/ * * S e t T T Y t o b e u n d e r r a w m o d e o r n o t . I n r a w m o d e , c h a r a c t e r s a r e r e a d a n d
2020-04-30 17:23:40 +02:00
* returned as is , without being processed . All special processing of
* characters by the terminal is disabled , including echoing input characters .
* Reading from a TTY device in raw mode is faster than reading from a TTY
* device in canonical mode .
*
2020-11-30 10:08:03 -06:00
* The ` cbreak ` option can be used to indicate that characters that correspond
* to a signal should still be generated . When disabling raw mode , this option
* is ignored . This functionality currently only works on Linux and Mac OS .
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
2021-05-13 20:20:55 +08:00
* Deno . setRaw ( Deno . stdin . rid , true , { cbreak : true } ) ;
2020-05-16 21:23:48 +02:00
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category I / O
2020-04-30 17:23:40 +02:00
* /
2020-11-30 10:08:03 -06:00
export function setRaw (
rid : number ,
mode : boolean ,
options? : SetRawOptions ,
) : void ;
2020-04-30 17:23:40 +02:00
2022-09-13 02:23:34 +01:00
/ * * N e e d s i n v e s t i g a t i o n i n t o h i g h p r e c i s i o n t i m e .
2020-04-30 17:23:40 +02:00
*
* Synchronously changes the access ( ` atime ` ) and modification ( ` mtime ` ) times
* of a file system object referenced by ` path ` . Given times are either in
* seconds ( UNIX epoch time ) or as ` Date ` objects .
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* Deno . utimeSync ( "myfile.txt" , 1556495550 , new Date ( ) ) ;
* ` ` `
2020-04-30 17:23:40 +02:00
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-write ` permission .
*
2022-08-23 10:57:01 +10:00
* @tags allow - write
2022-08-17 13:12:24 +10:00
* @category File System
* /
2020-04-30 17:23:40 +02:00
export function utimeSync (
2021-06-01 02:05:57 +08:00
path : string | URL ,
2020-04-30 17:23:40 +02:00
atime : number | Date ,
2020-07-14 15:24:17 -04:00
mtime : number | Date ,
2020-04-30 17:23:40 +02:00
) : void ;
2022-09-13 02:23:34 +01:00
/ * * N e e d s i n v e s t i g a t i o n i n t o h i g h p r e c i s i o n t i m e .
2020-04-30 17:23:40 +02:00
*
* Changes the access ( ` atime ` ) and modification ( ` mtime ` ) times of a file
* system object referenced by ` path ` . Given times are either in seconds
* ( UNIX epoch time ) or as ` Date ` objects .
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* await Deno . utime ( "myfile.txt" , 1556495550 , new Date ( ) ) ;
* ` ` `
2020-04-30 17:23:40 +02:00
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-write ` permission .
*
2022-08-23 10:57:01 +10:00
* @tags allow - write
2022-08-17 13:12:24 +10:00
* @category File System
* /
2020-04-30 17:23:40 +02:00
export function utime (
2021-06-01 02:05:57 +08:00
path : string | URL ,
2020-04-30 17:23:40 +02:00
atime : number | Date ,
2020-07-14 15:24:17 -04:00
mtime : number | Date ,
2020-04-30 17:23:40 +02:00
) : Promise < void > ;
2022-08-17 13:12:24 +10:00
/** @category Sub Process */
2021-08-04 21:47:43 +02:00
export function run <
T extends RunOptions & {
clearEnv? : boolean ;
2021-09-13 19:26:23 +02:00
gid? : number ;
uid? : number ;
2021-08-04 21:47:43 +02:00
} = RunOptions & {
clearEnv? : boolean ;
2021-09-13 19:26:23 +02:00
gid? : number ;
uid? : number ;
2021-08-04 21:47:43 +02:00
} ,
> ( opt : T ) : Process < T > ;
2022-09-13 02:23:34 +01:00
/ * * A d d i t i o n a l c o n s i d e r a t i o n i s s t i l l n e c e s s a r y a r o u n d t h e p e r m i s s i o n s r e q u i r e d .
2020-06-03 18:46:09 +01:00
*
* Get the ` hostname ` of the machine the Deno process is running on .
2020-05-09 12:44:35 -04:00
*
2020-05-16 21:23:48 +02:00
* ` ` ` ts
* console . log ( Deno . hostname ( ) ) ;
* ` ` `
2020-05-09 12:44:35 -04:00
*
* Requires ` allow-env ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - env
2022-08-17 13:12:24 +10:00
* @category Runtime Environment
2020-05-09 12:44:35 -04:00
* /
export function hostname ( ) : string ;
2020-06-11 13:00:29 +10:00
2022-09-13 02:23:34 +01:00
/ * * A c u s t o m H t t p C l i e n t f o r u s e w i t h ` f e t c h ` .
2020-08-10 21:41:51 +01:00
*
2020-08-05 20:44:03 +02:00
* ` ` ` ts
2021-09-30 09:26:15 +02:00
* const caCert = await Deno . readTextFile ( "./ca.pem" ) ;
* const client = Deno . createHttpClient ( { caCerts : [ caCert ] } ) ;
2020-08-05 20:44:03 +02:00
* const req = await fetch ( "https://myserver.com" , { client } ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Fetch API
2020-08-05 20:44:03 +02:00
* /
export class HttpClient {
rid : number ;
close ( ) : void ;
}
2022-09-13 02:23:34 +01:00
/ * * T h e o p t i o n s u s e d w h e n c r e a t i n g a [ H t t p C l i e n t ] .
2022-08-17 13:12:24 +10:00
*
* @category Fetch API
2020-08-05 20:44:03 +02:00
* /
2021-04-10 01:41:59 +01:00
export interface CreateHttpClientOptions {
2021-09-30 09:26:15 +02:00
/ * * A l i s t o f r o o t c e r t i f i c a t e s t h a t w i l l b e u s e d i n a d d i t i o n t o t h e
* default root certificates to verify the peer ' s certificate .
*
* Must be in PEM format . * /
caCerts? : string [ ] ;
/** A HTTP proxy to use for new connections. */
2021-06-22 12:21:57 +09:00
proxy? : Proxy ;
2021-09-30 09:26:15 +02:00
/** PEM formatted client certificate chain. */
2021-08-25 09:25:12 -03:00
certChain? : string ;
2021-09-30 09:26:15 +02:00
/** PEM formatted (RSA or PKCS8) private key of client certificate. */
2021-08-25 09:25:12 -03:00
privateKey? : string ;
2021-06-22 12:21:57 +09:00
}
2022-08-17 13:12:24 +10:00
/** @category Fetch API */
2021-06-22 12:21:57 +09:00
export interface Proxy {
url : string ;
basicAuth? : BasicAuth ;
}
2022-08-17 13:12:24 +10:00
/** @category Fetch API */
2021-06-22 12:21:57 +09:00
export interface BasicAuth {
username : string ;
password : string ;
2020-08-05 20:44:03 +02:00
}
2022-09-13 02:23:34 +01:00
/ * * C r e a t e a c u s t o m H t t p C l i e n t f o r t o u s e w i t h ` f e t c h ` .
2020-08-10 21:41:51 +01:00
*
2020-08-05 20:44:03 +02:00
* ` ` ` ts
2021-09-30 09:26:15 +02:00
* const caCert = await Deno . readTextFile ( "./ca.pem" ) ;
* const client = Deno . createHttpClient ( { caCerts : [ caCert ] } ) ;
2021-06-22 12:21:57 +09:00
* const response = await fetch ( "https://myserver.com" , { client } ) ;
* ` ` `
*
* ` ` ` ts
* const client = Deno . createHttpClient ( { proxy : { url : "http://myproxy.com:8080" } } ) ;
* const response = await fetch ( "https://myserver.com" , { client } ) ;
2020-08-05 20:44:03 +02:00
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Fetch API
2020-08-05 20:44:03 +02:00
* /
export function createHttpClient (
options : CreateHttpClientOptions ,
) : HttpClient ;
2020-09-01 02:29:43 +08:00
2022-09-13 02:23:34 +01:00
/ * * N e e d s i n v e s t i g a t i o n i n t o h i g h p r e c i s i o n t i m e .
2020-09-01 02:29:43 +08:00
*
* Synchronously changes the access ( ` atime ` ) and modification ( ` mtime ` ) times
* of a file stream resource referenced by ` rid ` . Given times are either in
* seconds ( UNIX epoch time ) or as ` Date ` objects .
*
* ` ` ` ts
2021-04-02 02:23:31 +04:30
* const file = Deno . openSync ( "file.txt" , { create : true , write : true } ) ;
2020-09-01 02:29:43 +08:00
* Deno . futimeSync ( file . rid , 1556495550 , new Date ( ) ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category File System
2020-09-01 02:29:43 +08:00
* /
export function futimeSync (
rid : number ,
atime : number | Date ,
mtime : number | Date ,
) : void ;
2022-09-13 02:23:34 +01:00
/ * * N e e d s i n v e s t i g a t i o n i n t o h i g h p r e c i s i o n t i m e .
2020-09-01 02:29:43 +08:00
*
* Changes the access ( ` atime ` ) and modification ( ` mtime ` ) times of a file
* stream resource referenced by ` rid ` . Given times are either in seconds
* ( UNIX epoch time ) or as ` Date ` objects .
*
* ` ` ` ts
2021-04-02 02:23:31 +04:30
* const file = await Deno . open ( "file.txt" , { create : true , write : true } ) ;
2020-09-01 02:29:43 +08:00
* await Deno . futime ( file . rid , 1556495550 , new Date ( ) ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category File System
2020-09-01 02:29:43 +08:00
* /
export function futime (
rid : number ,
atime : number | Date ,
mtime : number | Date ,
) : Promise < void > ;
2020-10-15 21:06:31 -04:00
2022-09-13 02:23:34 +01:00
/ * * A g e n e r i c t r a n s p o r t l i s t e n e r f o r m e s s a g e - o r i e n t e d p r o t o c o l s .
2022-08-17 13:12:24 +10:00
*
* @category Network
* /
2021-08-31 11:25:15 +02:00
export interface DatagramConn extends AsyncIterable < [ Uint8Array , Addr ] > {
2022-09-13 02:23:34 +01:00
/** Waits for and resolves to the next message to the `UDPConn`. */
2021-08-31 11:25:15 +02:00
receive ( p? : Uint8Array ) : Promise < [ Uint8Array , Addr ] > ;
2022-09-13 02:23:34 +01:00
/** Sends a message to the target. */
2021-08-31 11:25:15 +02:00
send ( p : Uint8Array , addr : Addr ) : Promise < number > ;
2022-09-13 02:23:34 +01:00
/ * * C l o s e c l o s e s t h e s o c k e t . A n y p e n d i n g m e s s a g e p r o m i s e s w i l l b e r e j e c t e d
2021-08-31 11:25:15 +02:00
* with errors . * /
close ( ) : void ;
/** Return the address of the `UDPConn`. */
readonly addr : Addr ;
[ Symbol . asyncIterator ] ( ) : AsyncIterableIterator < [ Uint8Array , Addr ] > ;
}
2022-08-17 13:12:24 +10:00
/** @category Network */
2021-08-31 11:25:15 +02:00
export interface UnixListenOptions {
/** A Path to the Unix Socket. */
path : string ;
}
2022-09-13 02:23:34 +01:00
/ * *
2021-08-31 11:25:15 +02:00
* Listen announces on the local transport address .
*
* ` ` ` ts
* const listener = Deno . listen ( { path : "/foo/bar.sock" , transport : "unix" } )
* ` ` `
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-read ` and ` allow-write ` permission .
*
2022-08-23 10:57:01 +10:00
* @tags allow - read , allow - write
2022-08-17 13:12:24 +10:00
* @category Network
* /
2021-08-31 11:25:15 +02:00
export function listen (
options : UnixListenOptions & { transport : "unix" } ,
) : Listener ;
2022-09-13 02:23:34 +01:00
/ * * L i s t e n a n n o u n c e s o n t h e l o c a l t r a n s p o r t a d d r e s s .
2021-08-31 11:25:15 +02:00
*
* ` ` ` ts
* const listener1 = Deno . listenDatagram ( {
* port : 80 ,
* transport : "udp"
* } ) ;
* const listener2 = Deno . listenDatagram ( {
* hostname : "golang.org" ,
* port : 80 ,
* transport : "udp"
* } ) ;
* ` ` `
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-net ` permission .
*
2022-08-23 10:57:01 +10:00
* @tags allow - net
2022-08-17 13:12:24 +10:00
* @category Network
* /
2021-08-31 11:25:15 +02:00
export function listenDatagram (
options : ListenOptions & { transport : "udp" } ,
) : DatagramConn ;
2022-09-13 02:23:34 +01:00
/ * * L i s t e n a n n o u n c e s o n t h e l o c a l t r a n s p o r t a d d r e s s .
2021-08-31 11:25:15 +02:00
*
* ` ` ` ts
* const listener = Deno . listenDatagram ( {
* path : "/foo/bar.sock" ,
* transport : "unixpacket"
* } ) ;
* ` ` `
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-read ` and ` allow-write ` permission .
*
2022-08-23 10:57:01 +10:00
* @tags allow - read , allow - write
2022-08-17 13:12:24 +10:00
* @category Network
* /
2021-08-31 11:25:15 +02:00
export function listenDatagram (
options : UnixListenOptions & { transport : "unixpacket" } ,
) : DatagramConn ;
2022-09-08 01:47:47 +01:00
/** @category Network */
2021-08-31 11:25:15 +02:00
export interface UnixConnectOptions {
transport : "unix" ;
path : string ;
}
2022-09-13 02:23:34 +01:00
/ * * T h e T C P t r a n s p o r t i s c o n s i d e r e d s t a b l e .
2021-08-31 11:25:15 +02:00
*
* Connects to the hostname ( default is "127.0.0.1" ) and port on the named
* transport ( default is "tcp" ) , and resolves to the connection ( ` Conn ` ) .
*
* ` ` ` ts
* const conn1 = await Deno . connect ( { port : 80 } ) ;
* const conn2 = await Deno . connect ( { hostname : "192.0.2.1" , port : 80 } ) ;
* const conn3 = await Deno . connect ( { hostname : "[2001:db8::1]" , port : 80 } ) ;
* const conn4 = await Deno . connect ( { hostname : "golang.org" , port : 80 , transport : "tcp" } ) ;
* const conn5 = await Deno . connect ( { path : "/foo/bar.sock" , transport : "unix" } ) ;
* ` ` `
*
2022-08-17 13:12:24 +10:00
* Requires ` allow-net ` permission for "tcp" and ` allow-read ` for "unix" .
*
2022-08-23 10:57:01 +10:00
* @tags allow - net , allow - read
2022-08-17 13:12:24 +10:00
* @category Network
* /
2021-08-31 11:25:15 +02:00
export function connect (
2022-02-27 15:18:30 +01:00
options : ConnectOptions ,
) : Promise < TcpConn > ;
export function connect (
options : UnixConnectOptions ,
2022-03-04 20:33:13 +01:00
) : Promise < UnixConn > ;
2021-08-31 11:25:15 +02:00
2022-09-08 01:47:47 +01:00
/** @category Network */
2021-09-30 09:26:15 +02:00
export interface ConnectTlsOptions {
2021-08-31 11:25:15 +02:00
/** PEM formatted client certificate chain. */
2021-09-30 09:26:15 +02:00
certChain? : string ;
2021-08-31 11:25:15 +02:00
/** PEM formatted (RSA or PKCS8) private key of client certificate. */
2021-09-30 09:26:15 +02:00
privateKey? : string ;
2022-09-13 02:23:34 +01:00
/ * * A p p l i c a t i o n - L a y e r P r o t o c o l N e g o t i a t i o n ( A L P N ) p r o t o c o l s s u p p o r t e d b y
2021-11-26 10:59:53 -08:00
* the client . If not specified , no ALPN extension will be included in the
* TLS handshake .
* /
alpnProtocols? : string [ ] ;
}
2022-08-17 13:12:24 +10:00
/** @category Network */
2021-11-26 10:59:53 -08:00
export interface TlsHandshakeInfo {
2022-09-13 02:23:34 +01:00
/ * * C o n t a i n s t h e A L P N p r o t o c o l s e l e c t e d d u r i n g n e g o t i a t i o n w i t h t h e s e r v e r .
2021-11-26 10:59:53 -08:00
* If no ALPN protocol selected , returns ` null ` .
* /
alpnProtocol : string | null ;
}
2022-08-17 13:12:24 +10:00
/** @category Network */
2021-11-26 10:59:53 -08:00
export interface TlsConn extends Conn {
/ * * R u n s t h e c l i e n t o r s e r v e r h a n d s h a k e p r o t o c o l t o c o m p l e t i o n i f t h a t h a s
* not happened yet . Calling this method is optional ; the TLS handshake
* will be completed automatically as soon as data is sent or received . * /
handshake ( ) : Promise < TlsHandshakeInfo > ;
2021-08-31 11:25:15 +02:00
}
2022-09-13 02:23:34 +01:00
/ * * C r e a t e a T L S c o n n e c t i o n w i t h a n a t t a c h e d c l i e n t c e r t i f i c a t e .
2021-09-02 18:28:12 -04:00
*
* ` ` ` ts
* const conn = await Deno . connectTls ( {
* hostname : "deno.land" ,
* port : 443 ,
* certChain : "---- BEGIN CERTIFICATE ----\n ..." ,
* privateKey : "---- BEGIN PRIVATE KEY ----\n ..." ,
* } ) ;
* ` ` `
*
* Requires ` allow-net ` permission .
2022-08-17 13:12:24 +10:00
*
2022-08-23 10:57:01 +10:00
* @tags allow - net
2022-08-17 13:12:24 +10:00
* @category Network
2021-09-02 18:28:12 -04:00
* /
2021-10-26 22:27:47 +02:00
export function connectTls ( options : ConnectTlsOptions ) : Promise < TlsConn > ;
2021-08-31 11:25:15 +02:00
2022-08-17 13:12:24 +10:00
/** @category Network */
2021-08-31 11:25:15 +02:00
export interface ListenTlsOptions {
2022-09-13 02:23:34 +01:00
/ * * A p p l i c a t i o n - L a y e r P r o t o c o l N e g o t i a t i o n ( A L P N ) p r o t o c o l s t o a n n o u n c e t o
2021-08-31 11:25:15 +02:00
* the client . If not specified , no ALPN extension will be included in the
* TLS handshake .
* /
alpnProtocols? : string [ ] ;
}
2021-09-19 20:46:54 +08:00
2022-08-17 13:12:24 +10:00
/** @category Network */
2021-11-26 10:59:53 -08:00
export interface StartTlsOptions {
2022-09-13 02:23:34 +01:00
/ * * A p p l i c a t i o n - L a y e r P r o t o c o l N e g o t i a t i o n ( A L P N ) p r o t o c o l s t o a n n o u n c e t o
2021-11-26 10:59:53 -08:00
* the client . If not specified , no ALPN extension will be included in the
* TLS handshake .
* /
alpnProtocols? : string [ ] ;
}
2022-08-17 13:12:24 +10:00
/** @category Network */
2022-03-23 12:04:20 +09:00
export interface Listener extends AsyncIterable < Conn > {
2022-09-13 02:23:34 +01:00
/ * * M a k e t h e l i s t e n e r b l o c k t h e e v e n t l o o p f r o m f i n i s h i n g .
2022-03-23 12:04:20 +09:00
*
* Note : the listener blocks the event loop from finishing by default .
* This method is only meaningful after ` .unref() ` is called .
* /
ref ( ) : void ;
2022-09-13 02:23:34 +01:00
/** Make the listener not block the event loop from finishing. */
2022-03-23 12:04:20 +09:00
unref ( ) : void ;
}
2022-09-13 02:23:34 +01:00
/ * * A c q u i r e a n a d v i s o r y f i l e - s y s t e m l o c k f o r t h e p r o v i d e d f i l e . ` e x c l u s i v e `
2021-09-19 20:46:54 +08:00
* defaults to ` false ` .
2022-08-17 13:12:24 +10:00
*
* @category File System
2021-09-19 20:46:54 +08:00
* /
export function flock ( rid : number , exclusive? : boolean ) : Promise < void > ;
2022-09-13 02:23:34 +01:00
/ * * A c q u i r e a n a d v i s o r y f i l e - s y s t e m l o c k f o r t h e p r o v i d e d f i l e . ` e x c l u s i v e `
2021-09-19 20:46:54 +08:00
* defaults to ` false ` .
2022-08-17 13:12:24 +10:00
*
* @category File System
2021-09-19 20:46:54 +08:00
* /
export function flockSync ( rid : number , exclusive? : boolean ) : void ;
2022-09-13 02:23:34 +01:00
/ * * R e l e a s e a n a d v i s o r y f i l e - s y s t e m l o c k f o r t h e p r o v i d e d f i l e .
2022-08-17 13:12:24 +10:00
*
* @category File System
2021-09-19 20:46:54 +08:00
* /
export function funlock ( rid : number ) : Promise < void > ;
2022-09-13 02:23:34 +01:00
/ * * R e l e a s e a n a d v i s o r y f i l e - s y s t e m l o c k f o r t h e p r o v i d e d f i l e .
2022-08-17 13:12:24 +10:00
*
* @category File System
2021-09-19 20:46:54 +08:00
* /
export function funlockSync ( rid : number ) : void ;
2021-12-09 17:00:55 +09:00
2022-09-13 02:23:34 +01:00
/ * * M a k e t h e t i m e r o f t h e g i v e n i d b l o c k i n g t h e e v e n t l o o p f r o m f i n i s h i n g .
2022-08-17 13:12:24 +10:00
*
* @category Timers
2021-12-09 17:00:55 +09:00
* /
export function refTimer ( id : number ) : void ;
2022-09-13 02:23:34 +01:00
/ * * M a k e t h e t i m e r o f t h e g i v e n i d n o t b l o c k i n g t h e e v e n t l o o p f r o m f i n i s h i n g .
2022-08-17 13:12:24 +10:00
*
* @category Timers
2021-12-09 17:00:55 +09:00
* /
export function unrefTimer ( id : number ) : void ;
2022-03-16 14:54:18 +01:00
2022-08-18 17:35:02 +05:30
/ * *
2022-08-24 00:08:56 +02:00
* A handler for HTTP requests . Consumes a request and returns a response .
*
* If a handler throws , the server calling the handler will assume the impact
* of the error is isolated to the individual request . It will catch the error
* and if necessary will close the underlying connection .
*
2022-08-18 17:35:02 +05:30
* @category HTTP Server
* /
2022-08-24 00:08:56 +02:00
export type ServeHandler = ( request : Request ) = > Response | Promise < Response > ;
2022-08-19 14:36:01 +02:00
2022-08-24 00:08:56 +02:00
/ * *
* @category HTTP Server
* /
export interface ServeOptions extends Partial < Deno.ListenOptions > {
2022-08-18 17:35:02 +05:30
/** An AbortSignal to close the server and all connections. */
signal? : AbortSignal ;
/** The handler to invoke when route handlers throw an error. */
onError ? : ( error : unknown ) = > Response | Promise < Response > ;
/** The callback which is called when the server started listening */
onListen ? : ( params : { hostname : string ; port : number } ) = > void ;
}
/ * *
* @category HTTP Server
* /
2022-08-24 00:08:56 +02:00
export interface ServeTlsOptions extends ServeOptions {
2022-08-18 17:35:02 +05:30
/** Server private key in PEM format */
cert : string ;
/** Cert chain in PEM format */
key : string ;
}
2022-08-24 00:08:56 +02:00
/ * *
* @category HTTP Server
* /
export interface ServeInit {
/** The handler to invoke to process each incoming request. */
handler : ServeHandler ;
}
2022-09-13 02:23:34 +01:00
/ * * S e r v e s H T T P r e q u e s t s w i t h t h e g i v e n h a n d l e r .
2022-08-18 17:35:02 +05:30
*
* You can specify an object with a port and hostname option , which is the
* address to listen on . The default is port 9000 on hostname "127.0.0.1" .
*
* The below example serves with the port 9000 .
*
* ` ` ` ts
2022-08-24 00:08:56 +02:00
* Deno . serve ( ( _req ) = > new Response ( "Hello, world" ) ) ;
2022-08-18 17:35:02 +05:30
* ` ` `
*
2022-08-24 00:08:56 +02:00
* You can change the address to listen on using the ` hostname ` and ` port `
* options . The below example serves on port 3000 .
2022-08-18 17:35:02 +05:30
*
* ` ` ` ts
2022-08-24 00:08:56 +02:00
* Deno . serve ( { port : 3000 } , ( _req ) = > new Response ( "Hello, world" ) ) ;
2022-08-19 14:36:01 +02:00
* ` ` `
*
2022-08-24 00:08:56 +02:00
* You can stop the server with an AbortSignal . The abort signal needs to be
* passed as the ` signal ` option in the options bag . The server aborts when
* the abort signal is aborted . To wait for the server to close , await the
* promise returned from the ` Deno.serve ` API .
2022-08-19 14:36:01 +02:00
*
* ` ` ` ts
* const ac = new AbortController ( ) ;
*
2022-08-24 00:08:56 +02:00
* Deno . serve ( { signal : ac.signal } , ( _req ) = > new Response ( "Hello, world" ) )
* . then ( ( ) = > console . log ( "Server closed" ) ) ;
2022-08-19 14:36:01 +02:00
*
* console . log ( "Closing server..." ) ;
* ac . abort ( ) ;
2022-08-18 17:35:02 +05:30
* ` ` `
*
2022-08-24 00:08:56 +02:00
* By default ` Deno.serve ` prints the message ` Listening on http://<hostname>:<port>/ `
* on start up . If you like to change this behaviour , you can specify a custom
* ` onListen ` callback .
2022-08-18 17:35:02 +05:30
*
* ` ` ` ts
2022-08-19 14:36:01 +02:00
* Deno . serve ( {
2022-08-18 17:35:02 +05:30
* onListen ( { port , hostname } ) {
* console . log ( ` Server started at http:// ${ hostname } : ${ port } ` ) ;
* // ... more info specific to your server ..
* } ,
2022-08-24 00:08:56 +02:00
* handler : ( _req ) = > new Response ( "Hello, world" ) ,
2022-08-18 17:35:02 +05:30
* } ) ;
* ` ` `
*
2022-08-24 00:08:56 +02:00
* To enable TLS you must specify the ` key ` and ` cert ` options .
2022-08-18 17:35:02 +05:30
*
* ` ` ` ts
* const cert = "-----BEGIN CERTIFICATE-----\n...\n-----END CERTIFICATE-----\n" ;
* const key = "-----BEGIN PRIVATE KEY-----\n...\n-----END PRIVATE KEY-----\n" ;
2022-08-24 00:08:56 +02:00
* Deno . serve ( { cert , key } , ( _req ) = > new Response ( "Hello, world" ) ) ;
2022-08-27 21:20:25 +02:00
* ` ` `
2022-08-18 17:35:02 +05:30
*
* @category HTTP Server
* /
2022-08-19 14:36:01 +02:00
export function serve (
2022-08-24 00:08:56 +02:00
handler : ServeHandler ,
options? : ServeOptions | ServeTlsOptions ,
) : Promise < void > ;
export function serve (
options : ServeOptions | ServeTlsOptions ,
handler : ServeHandler ,
) : Promise < void > ;
export function serve (
options : ServeInit & ( ServeOptions | ServeTlsOptions ) ,
2022-08-18 17:35:02 +05:30
) : Promise < void > ;
2022-09-13 02:23:34 +01:00
/ * * A l l o w s " h i j a c k i n g " t h e c o n n e c t i o n t h a t t h e r e q u e s t i s a s s o c i a t e d w i t h .
2022-08-24 14:10:57 +02:00
* This can be used to implement protocols that build on top of HTTP ( eg .
2022-03-16 14:54:18 +01:00
* WebSockets ) .
*
* The returned promise returns underlying connection and first packet
* received . The promise shouldn ' t be awaited before responding to the
* ` request ` , otherwise event loop might deadlock .
2022-08-17 13:12:24 +10:00
*
2022-08-24 14:10:57 +02:00
* ` ` ` ts
* function handler ( req : Request ) : Response {
* Deno . upgradeHttp ( req ) . then ( ( [ conn , firstPacket ] ) = > {
* // ...
* } ) ;
* return new Response ( null , { status : 101 } ) ;
* }
* ` ` `
*
* This method can only be called on requests originating the ` Deno.serveHttp `
* server .
*
2022-08-17 13:12:24 +10:00
* @category HTTP Server
2022-03-16 14:54:18 +01:00
* /
export function upgradeHttp (
request : Request ,
2022-08-24 14:10:57 +02:00
) : Promise < [ Deno . Conn , Uint8Array ] > ;
2022-09-13 02:23:34 +01:00
/ * * A l l o w s " h i j a c k i n g " t h e c o n n e c t i o n t h a t t h e r e q u e s t i s a s s o c i a t e d w i t h .
2022-08-24 14:10:57 +02:00
* This can be used to implement protocols that build on top of HTTP ( eg .
* WebSockets ) .
* Unlike ` Deno.upgradeHttp ` this function does not require that you respond
* to the request with a ` Response ` object . Instead this function returns
* the underlying connection and first packet received immediately , and then
* the caller is responsible for writing the response to the connection .
*
* This method can only be called on requests originating the ` Deno.serve `
* server .
*
* @category HTTP Server
* /
export function upgradeHttpRaw ( request : Request ) : [ Deno . Conn , Uint8Array ] ;
2022-04-21 00:20:33 +02:00
2022-08-17 13:12:24 +10:00
/** @category Sub Process */
2022-04-21 00:20:33 +02:00
export interface SpawnOptions {
/** Arguments to pass to the process. */
args? : string [ ] ;
/ * *
* The working directory of the process .
* If not specified , the cwd of the parent process is used .
* /
cwd? : string | URL ;
/ * *
* Clear environmental variables from parent process .
* Doesn ' t guarantee that only ` opt.env ` variables are present ,
* as the OS may set environmental variables for processes .
* /
clearEnv? : boolean ;
/** Environmental variables to pass to the subprocess. */
env? : Record < string , string > ;
/ * *
* Sets the child process ’ s user ID . This translates to a setuid call
* in the child process . Failure in the setuid call will cause the spawn to fail .
* /
uid? : number ;
/** Similar to `uid`, but sets the group ID of the child process. */
gid? : number ;
2022-05-11 07:59:39 +02:00
/ * *
* An AbortSignal that allows closing the process using the corresponding
* AbortController by sending the process a SIGTERM signal .
2022-09-14 16:37:05 +10:00
* Not supported in spawnSync .
2022-05-11 07:59:39 +02:00
* /
signal? : AbortSignal ;
2022-04-21 00:20:33 +02:00
/** Defaults to "null". */
stdin ? : "piped" | "inherit" | "null" ;
/** Defaults to "piped". */
stdout ? : "piped" | "inherit" | "null" ;
/** Defaults to "piped". */
stderr ? : "piped" | "inherit" | "null" ;
}
/ * *
* Spawns a child process .
*
2022-07-18 14:16:12 +01:00
* If any stdio options are not set to ` "piped" ` , accessing the corresponding
* field on the ` Child ` or its ` SpawnOutput ` will throw a ` TypeError ` .
*
* If stdin is set to ` "piped" ` , the stdin WritableStream needs to be closed
* manually .
2022-04-21 00:20:33 +02:00
*
* ` ` ` ts
* const child = Deno . spawnChild ( Deno . execPath ( ) , {
* args : [
* "eval" ,
* "console.log('Hello World')" ,
* ] ,
* stdin : "piped" ,
* } ) ;
*
* // open a file and pipe the subprocess output to it.
* child . stdout . pipeTo ( Deno . openSync ( "output" ) . writable ) ;
*
* // manually close stdin
* child . stdin . close ( ) ;
* const status = await child . status ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Sub Process
2022-04-21 00:20:33 +02:00
* /
2022-07-18 14:16:12 +01:00
export function spawnChild (
2022-04-21 00:20:33 +02:00
command : string | URL ,
2022-07-18 14:16:12 +01:00
options? : SpawnOptions ,
) : Child ;
2022-04-21 00:20:33 +02:00
2022-08-17 13:12:24 +10:00
/** @category Sub Process */
2022-07-18 14:16:12 +01:00
export class Child {
get stdin ( ) : WritableStream < Uint8Array > ;
get stdout ( ) : ReadableStream < Uint8Array > ;
get stderr ( ) : ReadableStream < Uint8Array > ;
2022-04-21 00:20:33 +02:00
readonly pid : number ;
/** Get the status of the child. */
readonly status : Promise < ChildStatus > ;
/** Waits for the child to exit completely, returning all its output and status. */
2022-07-18 14:16:12 +01:00
output ( ) : Promise < SpawnOutput > ;
2022-05-19 14:05:57 +02:00
/** Kills the process with given Signal. Defaults to SIGTERM. */
kill ( signo? : Signal ) : void ;
2022-07-18 22:24:35 +02:00
ref ( ) : void ;
unref ( ) : void ;
2022-04-21 00:20:33 +02:00
}
/ * *
* Executes a subprocess , waiting for it to finish and
* collecting all of its output .
2022-04-24 16:21:22 +01:00
* Will throw an error if ` stdin: "piped" ` is passed .
2022-04-21 00:20:33 +02:00
*
2022-07-18 14:16:12 +01:00
* If options ` stdout ` or ` stderr ` are not set to ` "piped" ` , accessing the
* corresponding field on ` SpawnOutput ` will throw a ` TypeError ` .
*
2022-04-21 00:20:33 +02:00
* ` ` ` ts
2022-07-18 14:16:12 +01:00
* const { code , stdout , stderr } = await Deno . spawn ( Deno . execPath ( ) , {
2022-04-21 00:20:33 +02:00
* args : [
* "eval" ,
* "console.log('hello'); console.error('world')" ,
* ] ,
* } ) ;
2022-07-18 14:16:12 +01:00
* console . assert ( code === 0 ) ;
2022-04-21 00:20:33 +02:00
* console . assert ( "hello\n" === new TextDecoder ( ) . decode ( stdout ) ) ;
* console . assert ( "world\n" === new TextDecoder ( ) . decode ( stderr ) ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Sub Process
2022-04-21 00:20:33 +02:00
* /
2022-07-18 14:16:12 +01:00
export function spawn (
2022-04-21 00:20:33 +02:00
command : string | URL ,
2022-07-18 14:16:12 +01:00
options? : SpawnOptions ,
) : Promise < SpawnOutput > ;
2022-04-21 00:20:33 +02:00
/ * *
* Synchronously executes a subprocess , waiting for it to finish and
* collecting all of its output .
2022-04-24 16:21:22 +01:00
* Will throw an error if ` stdin: "piped" ` is passed .
2022-04-21 00:20:33 +02:00
*
2022-07-18 14:16:12 +01:00
* If options ` stdout ` or ` stderr ` are not set to ` "piped" ` , accessing the
* corresponding field on ` SpawnOutput ` will throw a ` TypeError ` .
*
2022-04-21 21:36:57 +09:00
* ` ` ` ts
2022-07-18 14:16:12 +01:00
* const { code , stdout , stderr } = Deno . spawnSync ( Deno . execPath ( ) , {
2022-04-21 00:20:33 +02:00
* args : [
* "eval" ,
* "console.log('hello'); console.error('world')" ,
* ] ,
* } ) ;
2022-07-18 14:16:12 +01:00
* console . assert ( code === 0 ) ;
2022-04-21 00:20:33 +02:00
* console . assert ( "hello\n" === new TextDecoder ( ) . decode ( stdout ) ) ;
* console . assert ( "world\n" === new TextDecoder ( ) . decode ( stderr ) ) ;
* ` ` `
2022-08-17 13:12:24 +10:00
*
* @category Sub Process
2022-04-21 00:20:33 +02:00
* /
2022-07-18 14:16:12 +01:00
export function spawnSync (
2022-04-21 00:20:33 +02:00
command : string | URL ,
2022-07-18 14:16:12 +01:00
options? : SpawnOptions ,
) : SpawnOutput ;
2022-09-08 01:47:47 +01:00
/** @category Sub Process */
2022-07-18 14:16:12 +01:00
export interface ChildStatus {
success : boolean ;
code : number ;
signal : Signal | null ;
}
2022-04-21 00:20:33 +02:00
2022-09-08 01:47:47 +01:00
/** @category Sub Process */
2022-07-18 14:16:12 +01:00
export interface SpawnOutput extends ChildStatus {
get stdout ( ) : Uint8Array ;
get stderr ( ) : Uint8Array ;
2022-04-21 00:20:33 +02:00
}
2020-04-30 17:23:40 +02:00
}
2020-08-05 20:44:03 +02:00
2022-08-23 10:57:01 +10:00
/ * *
* @tags allow - net , allow - read
* @category Fetch API
* /
2020-08-05 20:44:03 +02:00
declare function fetch (
input : Request | URL | string ,
init? : RequestInit & { client : Deno.HttpClient } ,
) : Promise < Response > ;
2021-01-29 13:15:59 +00:00
2022-08-17 13:12:24 +10:00
/** @category Web Workers */
2021-01-29 13:15:59 +00:00
declare interface WorkerOptions {
2022-09-13 02:23:34 +01:00
/ * * C o n f i g u r e p e r m i s s i o n s o p t i o n s t o c h a n g e t h e l e v e l o f a c c e s s t h e w o r k e r w i l l
2022-03-24 11:27:24 -04:00
* have . By default it will have no permissions . Note that the permissions
2021-01-29 13:15:59 +00:00
* of a worker can 't be extended beyond its parent' s permissions reach .
* - "inherit" will take the permissions of the thread the worker is created in
2022-03-24 11:27:24 -04:00
* - "none" will use the default behavior and have no permission
2021-01-29 13:15:59 +00:00
* - You can provide a list of routes relative to the file the worker
* is created in to limit the access of the worker ( read / write permissions only )
*
* Example :
*
* ` ` ` ts
* // mod.ts
* const worker = new Worker (
* new URL ( "deno_worker.ts" , import . meta . url ) . href , {
* type : "module" ,
* deno : {
* permissions : {
* read : true ,
* } ,
* } ,
* }
* ) ;
* ` ` `
* /
2022-05-17 21:27:17 +01:00
deno ? : {
2021-01-29 13:15:59 +00:00
/** Set to `"none"` to disable all the permissions in the worker. */
2022-03-11 01:35:33 +01:00
permissions? : Deno.PermissionOptions ;
2021-01-29 13:15:59 +00:00
} ;
}
2021-08-10 00:28:17 +02:00
2022-08-17 13:12:24 +10:00
/** @category Web Sockets */
2021-08-10 00:28:17 +02:00
declare interface WebSocketStreamOptions {
protocols? : string [ ] ;
signal? : AbortSignal ;
2022-01-05 17:41:44 +01:00
headers? : HeadersInit ;
2021-08-10 00:28:17 +02:00
}
2022-08-17 13:12:24 +10:00
/** @category Web Sockets */
2021-08-10 00:28:17 +02:00
declare interface WebSocketConnection {
readable : ReadableStream < string | Uint8Array > ;
writable : WritableStream < string | Uint8Array > ;
extensions : string ;
protocol : string ;
}
2022-08-17 13:12:24 +10:00
/** @category Web Sockets */
2021-08-10 00:28:17 +02:00
declare interface WebSocketCloseInfo {
code? : number ;
reason? : string ;
}
2022-08-23 10:57:01 +10:00
/ * *
* @tags allow - net
* @category Web Sockets
* /
2021-08-10 00:28:17 +02:00
declare class WebSocketStream {
constructor ( url : string , options? : WebSocketStreamOptions ) ;
url : string ;
connection : Promise < WebSocketConnection > ;
closed : Promise < WebSocketCloseInfo > ;
close ( closeInfo? : WebSocketCloseInfo ) : void ;
}