forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tedious-connection-pool.d.ts
109 lines (86 loc) · 2.63 KB
/
tedious-connection-pool.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Type definitions for tedious-connection-pool
// Project: https://github.com/pekim/tedious-connection-pool
// Definitions by: Cyprien Autexier <https://github.com/sandorfr>
// Definitions: https://github.com/borisyankov/DefinitelyTyped
/// <reference path="../tedious/tedious.d.ts" />
declare module "tedious-connection-pool" {
import tedious = require('tedious');
module tcp {
/**
* Extends Tedious Connection with release function
*/
export class PooledConnection extends tedious.Connection {
/**
* If the connection is issued from a connection pool returns the connection to the pool.
*/
release():void;
}
/**
* Acquire function callback signature
*/
export interface ConnectionCallback {
/**
* Provides a connection or an error
* @param err error if any
* @param connection issued from the pool
*/
(err:Error, connection:PooledConnection): void;
}
/**
* Pool Configuration interface
*/
export interface PoolConfig {
/**
* Minimum concurrent connections
*/
min?: number;
/**
* Maximum concurrent connections
*/
max?: number;
/**
* Defines if logging is activated
*/
log?: boolean;
/**
* Idle timeout
*/
idleTimeout?: number;
/**
* Retry delay
*/
retryDelay?: number;
/**
* Acquire timeout
*/
acquireTimeout?: number;
}
}
/**
* Tedious Connection Pool Class
*/
class tcp {
/**
* Connection Pool constructor
* @param poolConfig the pool configuration
* @param connectionConfig the connection configuration
*/
constructor(poolConfig:tcp.PoolConfig, connectionConfig:tedious.ConnectionConfig);
/**
* acquires a connection from the pool
* @param callback invoked when the connection is retrieved and ready
*/
acquire(callback:tcp.ConnectionCallback):void;
/**
* listens for a specific connection pool event
* @param event the event name
* @param callback invoked when the event is raised
*/
on(event:string, callback:Function):void;
/**
* closes opened connections
*/
drain():void;
}
export = tcp;
}