mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-22 08:26:35 +08:00
* Add ERROR_STATE flag * added prop options and func timeFormatter added property `options`, which can be found in [the code](15fc4b62f5/smoothie.js (L270)). Even though it's not mentioned in the docs, it useful to be able to access these options after chart is initialized when you want to change appearance in real tme. added function `timeFormatter`, which is mentioned in [right here, in the definitions](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/smoothie/smoothie.d.ts#L127) and can be found in [the code](15fc4b62f5/smoothie.js (L795)) * Fix type errors * Added typings for css-modules-require-hook * Remove spaces * Added semver, added explicit ignore callback, unified array definition and removed one time interface * Overwriting method signature * Correct parameter type * Add MobilePhoneLocale * Add isMobilePhone tests * Type definitions for bit-array * Add emit for cluster * To use the definition inline * [logat.d.ts] Type definition for node module 'logat' (#11485) * Create logat.d.ts * Create logat-tests.ts * Update logat-tests.ts * Update logat-tests.ts * Update logat.d.ts * updated logat test * updated type definiton * [dateformat.d.ts] Add definitions for dateformat * Remove the ES6 module hack * Yayson definitions (#11484) * Add yayson Store typings * Add yayson Store tests * Improve yayson coverage * Specify version in yayson definition * Remove yayson generics and tidy * Changed namespace from angularTouchspin to angular.touchspin (#11414) * [perfect-scrollbar.d.ts] Add definitions for perfect-scrollbar (#11486) * Added types for klaw (#11492) * Added types for klaw * addressed pr comments and `tsfmt -r klaw/*.ts` * add typings for onselected and onunselected methods, refs #11493 (#11496) * Improve through2 declarations (#11499) * [through2] Fix typos * [through2] Change return types to stream.Transform `through2` creates `stream.Transform`-flavored streams, so switching the return types to `stream.Transform` gives us richer typing information than using `NodeJS.ReadWriteStream`, which is missing methods (e.g. `stream.Transform#push`) and the ability to use object mode. * [through2] Add through2.ctor method * [through2] Update header and docs * Add module declaration to crossfilter so that it can be explicitly imported (#11521) * Add typings for murmurhash3js * fix module import to be ES6 compliant * newline at EOF * [rethinkdb] Adds missing promise methods to Cursor and Connection * [rethinkdb] Applied TypeScript formatting to the file * [rethinkdb] Adds types to Cursor methods * webpack - HotModuleReplacementPlugin has opts arg * [openlayers] forEachFeatureAtPixel can return a value See doc http://openlayers.org/en/latest/apidoc/ol.Map.html#forEachFeatureAtPixel * Update react.d.ts Added myself as an author so I get notifications of PRs / updates from GitHub. * vue: fixed definition for activate() in ComponentOption * Fix error that came using typescript 2 This error come when try compile with typescript 2 kue.d.ts(13,3): error TS2440: Import declaration conflicts with local declaration of 'redis' * path can be string or a hash of options As per http://restify.com/#client-api it states: > Note that all further documentation refers to the "short-hand" > form of methods like get/put/del which take a string path. You > can also pass in an object to any of those methods with extra > params (notably headers): So the path can be either a string or a hash of options. * Add CognitoIdentity into aws-sdk * Font advanced config options added (for v2.0.6+) * Add missing slider parameters * Add backspaceToRemoveMessage prop * fixup! path can be string or a hash of options * add request.body (#11395) * add request.body * Update koa-bodyparser.d.ts According to the documentation of `koa-bodyparser`: ```javascript // the parsed body will store in this.request.body // if nothing was parsed, body will be an empty object {} ctx.body = ctx.request.body; ``` Therefore the `body` property will exit in the `request` object. Changing the `body` property from optional to required can also fix the conflict problem in Koa's declaration file: ```ts class Koa extend Request, Response {} ``` * Implement tilebelt definition (#11495) * Add import test (#11476) * [validator] Add new stuff which document not mentioned (#11498) * Add new stuff which document not mentioned * Add related test * http.ServerRequest => http.IncomingMessage (#11500) * [node] Add events for dgram (#11501) * Add events for dgram * Add tests for dgram * Correct dgram.RemoteInfo interface * Correct emit * Correct emit * [node] Add events for tls.Server and tls.TLSSocket (#11502) * Add events for tls.Server * Add tests for tls.Server * Add tests for TLSSocket * Add events for TLSSocket * [react-router] Update getComponents signatures (#11319) Update `getComponent(s)` all over the place. See #9530 for more info. * Updated jquery.dataTables for 1.10.7. (#11408) * Updated jquery.dataTables for 1.10.7. Version release notes: https://cdn.datatables.net/1.10.7/ * Added any() * Added i18n() Note: selector-modifier support currently exists with interface ObjectSelectorModifier. * Added strong variable typing in jquery.dataTables-tests.ts * For parameter 'def', replaced 'Object' data type with 'any' per TypeScript declaration file guidance. * [HAPI] Add `IStrictSessionHandler` (#11523) * Fix #11519 * Added FileResizeOptions for the changed resize function call * getEvent should not be set to void it should return a value (#11135) * getEvent should not be set to void it should return a value * Add type to getActionData for testing * pnotify Add type fpr notice styling and state * fix pnotify test * Remove Generics and replaces by return any * convert space tp tabs * Add barTintColor to NavigatorIOS (#11522) * GreenSock TweenMax TweenLite config Object typed refs #11265 (#11310) * refs #9944 * refs #11265 * refs #11265 * Call strategy with only mode or options (#11466) * Call strategy with only mode or options * Refactor `server.auth.strategy` * - add client.exists([params, [callback]]) (#11515) * Update to Electron 1.4.1 (#11481) * Correct fs.createWriteStream (#11560) * add declaration file for weapp (#11554) * add declaration file of weapp * rename "weapp" to "weapp-api" rename "weapp" to "weapp-api" to avoid naming conflicts * Added more methods to Turf (#11558) * Added more methods to Turf - circle - geojsonType - propReduce - coordAll - tesselate * Replace Object with GeoJSON * Implemented cheap-ruler definition * Remove GeoJSON dependency * Cheap-ruler fixes - Removed GeoJSON from tests - Added return-type to fromTile * Update JSDocs cheap-ruler Update based on comments https://github.com/mapbox/cheap-ruler/pull/20 - Removed `{@name}` - Changed {Object} to {CheapRuler} * [bluebird] document .suppressUnhandledRejections http://bluebirdjs.com/docs/api/suppressunhandledrejections.html * Add typings for shallowequal. * URIjs fix .joinPaths() the .joinPaths function is on URIStatic, not an instance of URI https://medialize.github.io/URI.js/docs.html#static-joinPaths * set document id property to be optional * Fixed type of onchallenge * feat(CKEditor): Add missing typings for `focusManager` * sequelize: fix return value type of Model.findOrXXX methods http://docs.sequelizejs.com/en/latest/api/model/#findorinitialize-promiseinstance-initialized * Added type Point for simplicity Comments from @vladima * add interface for mongoose document optional properties * optional constructor for RecurrenceRule * fix the framework type * add parameter support in initialize() * add callback parameter * Added promise() to the JQueryPromise<T> interface jQuery allows calling a promise() function on a Promise object. Updated the interface to reflect this. * optional authorize * add contains fn * Update ip-tests.ts * Added tests for the promise() method on jqXHR Ensures that the jqXHR object exposes a standard promise because it implements the JQueryPromise<T> interface. * angular-dynamic-local Add "storageKey" definition (#11566) Add "storageKey" definition cf : https://github.com/lgalfaso/angular-dynamic-locale/blob/master/src/tmhDynamicLocale.js#L197 * Added declare module for easier including. (#11562) * Adding recompose@0.20.2 typings (#11577) * Added typings for change-emitter@0.1.2 * Adding recompose@0.20.2 typings * Update typescript definition for selectize to 0.12.13 (#11570) * [react-router-redux] Update action payload type (#11559) The payload for React Redux Router action is a location object. For more information look at the source code [here](https://github.com/reactjs/react-router-redux/blob/master/src/sync.js#L95) * [openlayers] Rewrite for openlayers 3.18.2 (#11339) * Added missing config options for release v2.0.8 (#11595) * [graphql] Create graphql (#11598) * Complete graphql/language * Update graphql/error * Update graphql.d.ts * Create graphql-tests.ts * Update graphql/type * Update graphql/error and graphql/execution * Remove null type * Remove comma * ej typings v14.3.0.49 added (#11597) * ej typings v14.3.0.49 added * jquery dependent added * react-bootstrap-table: add ignoreSinglePage option (#11581) As shown in the [docs](http://allenfang.github.io/react-bootstrap-table/docs.html) ``` ignoreSinglePage : Bool Enable to ignore the pagination if only one page, default is false. ``` * There is no INST_EDGE_FALLING exported const but INT_EDGE_FALLING (#11603) Exporting correct `const` `INST_EDGE_FALLING` -> `INT_EDGE_FALLING` * Complete HighchartsBarStates interface. Add Color interface (#11505) - HighchartsBarStates interfaces didn't include `borderColor` and `color` properties, as documented in http://api.highcharts.com/highcharts/plotOptions.bar.states.hover - A Color interface was added, since the documentation refers many times to `Color` as a type. This colors can be either a string or a gradient, as stated in http://www.highcharts.com/docs/chart-design-and-style/colors. The introduction of this type should help alleviating the errors currently present where certain "color" properties are only allowed to be strings. * Add definition for swagger-jsdoc (#11298) * Add definition for swagger-jsdoc * Update files * Remove interface and use any instead for options, fix tests * Fix Usage example * Add definitions for: "bunyan-config", "express-mung", "node-vitalsigns" and "memwatch-next" (#11285) * Add definition for "bunnymq". * Add definition for "strftime". * Add definitions for: "bunyan-config", "express-mung" and "node-vitalsigns". * Add definitions for: "bunyan-config", "express-mung" and "node-vitalsigns". * Add definition for "memwatch-next". * Fix project URL address. * Rename "node-vitalsigns" to "vitalsigns". * Update definitions. * Use {} instead of "Object" type. Remove unnecessary namespace for "memwatch-next" definition. Rewrite "bunyan-config" definition. * Replace "Object" by "{}". * (helmet): change to namespace and export interfaces (#11585) * Replace reference to deprecated http.ClientResponse with newer http.IncomingMessage (#11596) * [cheerio] Adds missing load(CheerioElement) (#11520) * add id (#11619) * add id * remove readonly * add touch after * fix typo * change Topic property latch to boolean type (#11607) * Add AngularJS linky filter definition (#11507) * Support universal modules for SAT (#11632) * changed versionKey in Schema spec to string * better structure * Add argumentless Q() * add definitions for tz-format (#11565) * add definitions for tz-format * fix return type * Create typings for ngeohash (#11634) * [nprogress] Update configuration properties (#11627) Update a couple of nprogress configuration properties: * `ease` is renamed to `easing`. * `trickleRate` is removed. * `parent` is added. More info [here](https://github.com/rstacruz/nprogress/blob/master/nprogress.js#L19-L31) * Fix leaflet L.GeoJSON.addData et al (#11590) (#11591) * NotificationAlertOptions can have a subtitle (#11638) * Parse5 comment data (#11649) * Add test for data * Update parse5.d.ts * feat: add localforage-cordovasqlitedriver definition (#11650) * Fix export for "bunyan-config" and improve definitions (#11653) * Fix export for "bunyan-config". * Update definitions. Replace "Object" to "{}" type. Add "express" property in "VitalSigns" class. * Update ejs.d.ts (#11467) This typings give an error when templating HTML Error: Cannot invoke an expression whose type lacks a call signature. my code ```javascript var templateFunction = EJS.compile(SOMESTRTEMPLATE); myDomElement.innerHTML = templateFunction(someDataObject) // <= ERROR ``` * Added hyperscript module (#11661) * update parsimmon typings for parsimmon 0.9.2 (#11648) * update parsimmon typings for parsimmon 0.9.2 * add overloads for parsimmon#seq * code review * Fix babel-traverse buildCodeFrameError signature (#11654) The Error argument is not an error instance, instead it is a constructor function that returns an error instance. Additionally, the constructor function is optional, by default SyntaxError is used * Added type definition for riot library (#11664) * Added type definition for riot * Added type information for compile function, version, settings and template error handler * Updated namespace name Riot -> riot * Renamed riot-test.ts -> riot-tests.ts * Add definitions for pem (#11666) https://github.com/andris9/pem * Added hapi-decorators.d.ts (#11668) * Add missing each, and correct type of Date.now() (#11670) * Add definitions for spdy (#11672) https://github.com/indutny/node-spdy * Allow interface to be named (#11673) > error TS4023: Exported variable 'DevTools' has or is using name 'IDevTools' from external module "/Users/remojansen/CODE/forks/redux-bootstrap/node_modules/@types/redux-devtools/index" but cannot be named. * Add array methods to LoDashExplicitArrayWrapper to match LoDashImplicitArrayWrapper. (#11518) * add transducers-js types w/ tests (#11676) * Fix redeclare block-scoped Base64 (#11677) Issue found by https://github.com/dankogai/js-base64/issues/38#issuecomment-250999729 * added seed, randomTests and randomizeTests property (#11678) * Add toJSON method to signature (#11682) * Fix instance of cropperjs for library version > 0.8 (#11490) * Updated fbsdk definitions for authentication responses and api calls. (#11686) Fixes #11327 May help with #11007 * Create typings for jquery-alertable (#11642) * ADD: definition file for the moment-duration-format library (#11557) * Update d.ts file for Dialog API updates (#11526) * Add support for Highcharts modules: offline exporting and boost (#11030) * Create highcharts-modules-offline-exporting * Rename highcharts-modules-offline-exporting to highcharts-modules-offline-exporting.d.ts * Create highcharts-modules-boost.d.ts * Added cash-js.d.ts File (#10765) * Added cash-js.d.ts File * Fixed Link break issue * Renamed from cash-js to cash * Fixed the module name as suggested * Update headroom.d.ts (#11313) notBottom missing from definition * Added the definition for the npm package simple-url-cache (#11296) * Added the definition for the npm package simple-url-cache https://www.npmjs.com/package/simple-url-cache * - Some problems with shells.js missing the touch fucntion deifnition * More details on the touch parameters - nice screenshot btw * Updated the RowMethods interface (#11665) * Updated the RowMethods interface This Interface was missing the Definition of the id() method. Link to official documentation: https://datatables.net/reference/api/row().id() * Changed indentation from tabs to spaces * Added definition file for Defaults Js Library (#11451) * Added missing className property to CardProps (#10823) The className property for CardPros is missing, so using it like <Card className={this.myClass}>...</Card> is not possible. * Add missing perMessageDeflate server option (#11380) * Add missing class AgendaView (#11371) * Add missing class AgendaView * Move class to kendo.ui namespace * Change path to interface * Add static fn * Add static extend * Add static extend * Resolve conflicts * adds system faker methods (#11432) * added definitions for SharePoint file Search.ClientControls.js (#11652) * added definitions for SharePoint file Search.ClientControls.js (Srch namespace, heavily used in Search Display Templates) * --noImplicitAny compatibility fixes also small improvements * more fixes for --noImplicitAny * Adding union type for offset (#11689) * add type definitions for msgpack-lite package. (#11690) * Updating jasmine to version 2.5 (#11688) * Updating jasmine to version 2.5 * Fixing 2 small errors in the update of jasmine * withMock now takes a "() => void" * fixed the withMock syntax error * number added as type to seed function * add missing isEmpty function (#11698) * Added type definitions for terminal-menu (#11697) * Update THREE.js definitions to r81 (#11679) * Update THREE.js definitions to r81 * Update test_unit_maths.ts to r81 * Update version in header to r81 * UPDATE localForage type definitions (#11702) * Update Google Maps API type definition to 3.25 (#11626) * Update Google Maps Places Library definition - According to the Places Library documentation (https://goo.gl/EJFiuQ), certain fields are being removed - I have aligned the Places Library definitions with the API reference (https://goo.gl/kYoi9V) and added deprecation comments for the old properties as they are still accepted until February - I could not find an official deprecation attribute or similar for Typescript definitions so I just left a comment * Update the API version in the header * Apply API changes between version 3.20 and 3.25 - Used the Google Maps API release notes (https://goo.gl/nRUZGJ) as a reference * Fix inconsistant type definition * Override ol.layer.Vector#getSource() (#11703) Reference: http://openlayers.org/en/latest/apidoc/ol.layer.Vector.html * Replace number[] by [number, number] (#11704) * [lodash]: memoize.Cache expects construcor (#11707) https://lodash.com/docs/4.15.0#memoize * Added jquery.flagstrap.js definition suport (#11710) * apply declaration merging (#10900) * Update material-ui.d.ts (#11353) Expose ThemePalette interface. * Change ChartAxisXOptions (#11449) Change the type for minimum and maximum options in ChartAxisXOptions to support both number and Date. * Improve support for arrays of promises (#11685) * Alias IWhenable<T> = IPromise<T> | T * Allow all Q functions to work with either promises or raw values * Allow functions expecting arrays to take promises for arrays Q.race is deliberately excluded, as this does not support this type of argument. * scheduler options (#11543) * Added missing move function (#11563) * Added missing move function Added missing move function in typings so that the move function is recognised by the IDE and the compiler. * Minor derp here * Add missing Valdr typings for validation results and constraints (#11636) * Add missing Valdr types Add ValdrValidationConstraints and ValdrValidationResult typings * Refine Valdr-message typings Set a more refined type to messages instead of any * Expand Valdr typings tests Expand tests to include added typings for ValdrValidationResult and ValdrConstraints * Fix spacing Replace tabs by spaces * Rename vars in test Rename vars to make test clearer * Fix TS issues Added missing types * Remove undefined In TS by default null and undefined are subtypes of all other types * Fix wrong type Add missing namespace * Fix wrong version number Set version to only numbers * Fix wrong version number Keep version to only numbers * Use douple quotes * Remove invalid triple-slash references * Add tsconfig.json files and move main file to index.d.ts * Rename file to index.d.ts * Remove tscparams files * Remove unused file * Remove invalid references * Move hapi-decorator to use index.d.ts * Switch to use external modules * Correctely extend angular * Fix tsconfig.json * Remove unused references * HACK: Put back /// reference tag.
365 lines
18 KiB
TypeScript
365 lines
18 KiB
TypeScript
// Type definitions for node-apn
|
|
// Project: https://github.com/argon/node-apn
|
|
// Definitions by: Zenorbi <https://github.com/zenorbi>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
|
|
///<reference types="node"/>
|
|
|
|
import events = require("events");
|
|
import net = require("net");
|
|
export interface ConnectionOptions {
|
|
/**
|
|
* The filename of the connection certificate to load from disk, or a Buffer/String containing the certificate data. (Defaults to: `cert.pem`)
|
|
*/
|
|
cert?: string | Buffer;
|
|
/**
|
|
* The filename of the connection key to load from disk, or a Buffer/String containing the key data. (Defaults to: `key.pem`)
|
|
*/
|
|
key?: string | Buffer;
|
|
/**
|
|
* An array of trusted certificates. Each element should contain either a filename to load, or a Buffer/String (in PEM format) to be used directly. If this is omitted several well known "root" CAs will be used. - You may need to use this as some environments don't include the CA used by Apple (entrust_2048).
|
|
*/
|
|
ca?: (string | Buffer)[];
|
|
/**
|
|
* File path for private key, certificate and CA certs in PFX or PKCS12 format, or a Buffer containing the PFX data. If supplied will always be used instead of certificate and key above.
|
|
*/
|
|
pfx?: string | Buffer;
|
|
/**
|
|
* The passphrase for the connection key, if required
|
|
*/
|
|
passphrase?: string;
|
|
/**
|
|
* Specifies which environment to connect to: Production (if true) or Sandbox - The hostname will be set automatically. (Defaults to NODE_ENV == "production", i.e. false unless the NODE_ENV environment variable is set accordingly)
|
|
*/
|
|
production?: boolean;
|
|
/**
|
|
* Enable when you are using a VoIP certificate to enable paylods up to 4096 bytes.
|
|
*/
|
|
voip?: boolean;
|
|
/**
|
|
* Gateway port (Defaults to: `2195`)
|
|
*/
|
|
port?: number;
|
|
/**
|
|
* Reject Unauthorized property to be passed through to tls.connect() (Defaults to `true`)
|
|
*/
|
|
rejectUnauthorized?: boolean;
|
|
/**
|
|
* Number of notifications to cache for error purposes (See "Handling Errors" below, (Defaults to: `1000`)
|
|
*/
|
|
cacheLength?: number;
|
|
/**
|
|
* Whether the cache should grow in response to messages being lost after errors. (Will still emit a 'cacheTooSmall' event) (Defaults to: `true`)
|
|
*/
|
|
autoAdjustCache?: boolean;
|
|
/**
|
|
* The maximum number of connections to create for sending messages. (Defaults to: `1`)
|
|
*/
|
|
maxConnections?: number;
|
|
/**
|
|
* The duration of time the module should wait, in milliseconds, when trying to establish a connection to Apple before failing. 0 = Disabled. {Defaults to: `10000`}
|
|
*/
|
|
connectTimeout?: number;
|
|
/**
|
|
* The duration the socket should stay alive with no activity in milliseconds. 0 = Disabled. (Defaults to: `3600000` - 1h)
|
|
*/
|
|
connectionTimeout?: number;
|
|
/**
|
|
* The maximum number of connection failures that will be tolerated before `apn` will "terminate". (Defaults to: 10)
|
|
*/
|
|
connectionRetryLimit?: number;
|
|
/**
|
|
* Whether to buffer notifications and resend them after failure. (Defaults to: `true`)
|
|
*/
|
|
buffersNotifications?: number;
|
|
/**
|
|
* Whether to aggresively empty the notification buffer while connected - if set to true node-apn may enter a tight loop under heavy load while delivering notifications. (Defaults to: `false`)
|
|
*/
|
|
fastMode?: boolean;
|
|
}
|
|
export declare class Connection extends events.EventEmitter {
|
|
constructor(options: ConnectionOptions);
|
|
/**
|
|
* This is the business end of the module. Create a `Notification` object and pass it in, along with a single recipient or an array of them and node-apn will take care of the rest, delivering the notification to each recipient.
|
|
*
|
|
* A "recipient" is either a `Device` object, a `String`, or a `Buffer` containing the device token. `Device` objects are used internally and will be created if necessary. Where applicable, all events will return a `Device` regardless of the type passed to this method.
|
|
*/
|
|
pushNotification(notification: Notification, recipient: Device | string | Buffer | (Device | string | Buffer)[]): void;
|
|
/**
|
|
* Used to manually adjust the "cacheLength" property in the options. This is ideal if you choose to use the `cacheTooSmall` event to tweak your environment. It is safe for increasing and reducing cache size.
|
|
*/
|
|
setCacheLength(newLength: number): void;
|
|
/**
|
|
* Indicate to node-apn that when the queue of pending notifications is fully drained that it should close all open connections. This will mean that if there are no other pending resources (open sockets, running timers, etc.) the application will terminate. If notifications are pushed after the connection has completely shutdown a new connection will be established and, if applicable, `shutdown` will need to be called again.
|
|
*/
|
|
shutdown(): void;
|
|
/**
|
|
* Emitted when an error occurs during initialisation of the module, usually due to a problem with the keys and certificates.
|
|
*/
|
|
on(event: "error", listener: (error: Error) => void): this;
|
|
/**
|
|
* Emitted when the connection socket experiences an error. This may be useful for debugging but no action should be necessary.
|
|
*/
|
|
on(event: "socketError", listener: (error: Error) => void): this;
|
|
/**
|
|
* Emitted when a notification has been sent to Apple - not a guarantee that it has been accepted by Apple, an error relating to it may occur later on. A notification may also be "transmitted" several times if a preceding notification caused an error requiring retransmission.
|
|
*/
|
|
on(event: "transmitted", listener: (notification: Notification, decive: Device) => void): this;
|
|
/**
|
|
* Emitted when all pending notifications have been transmitted to Apple and the pending queue is empty. This may be called more than once if a notification error occurs and notifications must be re-sent.
|
|
*/
|
|
on(event: "completed", listener: () => void): this;
|
|
/**
|
|
* Emitted when Apple returns a notification as invalid but the notification has already been expunged from the cache - usually due to high throughput and indicates that notifications will be getting lost. The parameter is an estimate of how many notifications have been lost. You should experiment with increasing the cache size or enabling ```autoAdjustCache``` if you see this frequently.
|
|
*
|
|
* **Note**: With ```autoAdjustCache``` enabled this event will still be emitted when an adjustment is triggered.
|
|
*/
|
|
on(event: "cacheTooSmall", listener: (sizeDifference: number) => void): this;
|
|
/**
|
|
* Emitted when a connection to Apple is successfully established. The parameter indicates the number of open connections. No action is required as the connection is managed internally.
|
|
*/
|
|
on(event: "connected", listener: (openSockets: net.Socket[]) => void): this;
|
|
/**
|
|
* Emitted when the connection to Apple has been closed, this could be for numerous reasons, for example an error has occurred or the connection has timed out. The parameter is the same as for `connected` and again, no action is required.
|
|
*/
|
|
on(event: "disconnected", listener: (openSockets: net.Socket[]) => void): this;
|
|
/**
|
|
* Emitted when the connectionTimeout option has been specified and no activity has occurred on a socket for a specified duration. The socket will be closed immediately after this event and a `disconnected` event will also be emitted.
|
|
*/
|
|
on(event: "timeout", listener: () => void): this;
|
|
/**
|
|
* Emitted when a message has been received from Apple stating that a notification was invalid or if an internal error occurred before that notification could be pushed to Apple. If the notification is still in the cache it will be passed as the second argument, otherwise null. Where possible the associated `Device` object will be passed as a third parameter, however in cases where the token supplied to the module cannot be parsed into a `Buffer` the supplied value will be returned.
|
|
|
|
* Error codes smaller than 512 correspond to those returned by Apple as per their [docs][errors]. Other errors are applicable to `node-apn` itself. Definitions can be found in `lib/errors.js`.
|
|
*/
|
|
on(event: "transmissionError", listener: (errorCode: number, notification: Notification, device: Device | Buffer) => void): this;
|
|
on(event: string, listener: Function): this;
|
|
}
|
|
export interface NotificationAlertOptions {
|
|
title?: string;
|
|
subtitle?: string;
|
|
body: string;
|
|
"title-loc-key"?: string;
|
|
"title-loc-args"?: string[];
|
|
"action-loc-key"?: string;
|
|
"loc-key"?: string;
|
|
"loc-args"?: string[];
|
|
"launch-image"?: string;
|
|
}
|
|
export declare class Notification {
|
|
/**
|
|
* The maximum number of retries which should be performed when sending a notification if an error occurs. A value of 0 will only allow one attempt at sending (0 retries). Set to -1 to disable (default).
|
|
*/
|
|
public retryLimit: number;
|
|
/**
|
|
* The UNIX timestamp representing when the notification should expire. This does not contribute to the 2048 byte payload size limit. An expiry of 0 indicates that the notification expires immediately.
|
|
*/
|
|
public expiry: number;
|
|
/**
|
|
* From Apple's Documentation, Provide one of the following values:
|
|
*
|
|
* - 10 - The push message is sent immediately. (Default)
|
|
* > The push notification must trigger an alert, sound, or badge on the device. It is an error use this priority for a push that contains only the content-available key.
|
|
* - 5 - The push message is sent at a time that conserves power on the device receiving it.
|
|
*/
|
|
public priority: number;
|
|
/**
|
|
* The encoding to use when transmitting the notification to APNS, defaults to `utf8`. `utf16le` is also possible but as each character is represented by a minimum of 2 bytes, will at least halve the possible payload size. If in doubt leave as default.
|
|
*/
|
|
public encoding: string;
|
|
/**
|
|
* This object represents the root JSON object that you can add custom information for your application to. The properties below will only be added to the payload (under `aps`) when the notification is prepared for sending.
|
|
*/
|
|
public payload: any;
|
|
/**
|
|
* The value to specify for `payload.aps.badge`
|
|
*/
|
|
public badge: number;
|
|
/**
|
|
* The value to specify for `payload.aps.sound`
|
|
*/
|
|
public sound: string;
|
|
/**
|
|
* The value to specify for `payload.aps.alert` can be either a `String` or an `Object` as outlined by the payload documentation.
|
|
*/
|
|
public alert: string | NotificationAlertOptions;
|
|
/**
|
|
* Setting this to true will specify "content-available" in the payload when it is compiled.
|
|
*/
|
|
public newsstandAvailable: boolean;
|
|
/**
|
|
* Setting this to true will specify "content-available" in the payload when it is compiled.
|
|
*/
|
|
public contentAvailable: boolean;
|
|
/**
|
|
* The value to specify for the `mdm` field where applicable.
|
|
*/
|
|
public mdm: string | Object;
|
|
/**
|
|
* The value to specify for `payload.aps['url-args']`. This used for Safari Push NOtifications and should be an array of values in accordance with the Web Payload Documentation.
|
|
*/
|
|
public urlArgs: string[];
|
|
/**
|
|
* When this parameter is set and `notification#trim()` is called it will attempt to truncate the string at the nearest space.
|
|
*/
|
|
public truncateAtWordEnd: boolean;
|
|
/**
|
|
* You can optionally pass in an object representing the payload, or configure properties on the returned object.
|
|
*/
|
|
constructor(payload?: any);
|
|
/**
|
|
* Set the `aps.alert` text body. This will use the most space-efficient means.
|
|
*/
|
|
setAlertText(alertText: string): Notification;
|
|
/**
|
|
* Set the `title` property of the `aps.alert` object - used with Safari Push Notifications
|
|
*/
|
|
setAlertTitle(alertTitle: string): Notification;
|
|
/**
|
|
* Set the `action` property of the `aps.alert` object - used with Safari Push Notifications
|
|
*/
|
|
setAlertAction(alertAction: string): Notification;
|
|
/**
|
|
* Set the `action-loc-key` property of the `aps.alert` object.
|
|
*/
|
|
setActionLocKey(key: string): Notification;
|
|
/**
|
|
* Set the `loc-key` property of the `aps.alert` object.
|
|
*/
|
|
setLocKey(key: string): Notification;
|
|
/**
|
|
* Set the `loc-args` property of the `aps.alert` object.
|
|
*/
|
|
setLocArgs(args: string[]): Notification;
|
|
/**
|
|
* Set the `launch-image` property of the `aps.alert` object.
|
|
*/
|
|
setLaunchImage(image: string): Notification;
|
|
/**
|
|
* Set the `mdm` property on the payload.
|
|
*/
|
|
setMDM(mdm: string | Object): Notification;
|
|
/**
|
|
* Set the `content-available` property of the `aps` object.
|
|
*/
|
|
setNewsstandAvailable(available: boolean): Notification;
|
|
/**
|
|
* Set the `content-available` property of the `aps` object.
|
|
*/
|
|
setContentAvailable(available: boolean): Notification;
|
|
/**
|
|
* Set the `url-args` property of the `aps` object.
|
|
*/
|
|
setUrlArgs(urlArgs: string[]): Notification;
|
|
/**
|
|
* Attempt to automatically trim the notification alert text body to meet the payload size limit of 2048 bytes.
|
|
*/
|
|
trim(): number;
|
|
}
|
|
export declare class Device {
|
|
public token: Buffer;
|
|
/**
|
|
* `deviceToken` can be a `Buffer` or a `String` containing a "hex" representation of the token. Throws an error if the deviceToken supplied is invalid.
|
|
*/
|
|
constructor(deviceToken: string | Buffer);
|
|
}
|
|
|
|
export interface FeedbackOptions {
|
|
/**
|
|
* The filename of the connection certificate to load from disk, or a Buffer/String containing the certificate data. (Defaults to: `cert.pem`)
|
|
*/
|
|
cert?: string | Buffer;
|
|
/**
|
|
* The filename of the connection key to load from disk, or a Buffer/String containing the key data. (Defaults to: `key.pem`)
|
|
*/
|
|
key?: string | Buffer;
|
|
/**
|
|
* An array of trusted certificates. Each element should contain either a filename to load, or a Buffer/String (in PEM format) to be used directly. If this is omitted several well known "root" CAs will be used. - You may need to use this as some environments don't include the CA used by Apple (entrust_2048).
|
|
*/
|
|
ca?: (string | Buffer)[];
|
|
/**
|
|
* File path for private key, certificate and CA certs in PFX or PKCS12 format, or a Buffer containing the PFX data. If supplied will be used instead of certificate and key above.
|
|
*/
|
|
pfx?: string | Buffer;
|
|
/**
|
|
* The passphrase for the connection key, if required
|
|
*/
|
|
passphrase?: string;
|
|
/**
|
|
* Specifies which environment to connect to: Production (if true) or Sandbox - The hostname will be set automatically. (Defaults to NODE_ENV == "production", i.e. false unless the NODE_ENV environment variable is set accordingly)
|
|
*/
|
|
production?: boolean;
|
|
/**
|
|
* Feedback server port (Defaults to: `2196`)
|
|
*/
|
|
port?: number;
|
|
/**
|
|
* Sets the behaviour for triggering the `feedback` event. When `true` the event will be triggered once per connection with an array of timestamp and device token tuples. Otherwise a `feedback` event will be emitted once per token received. (Defaults to: true)
|
|
*/
|
|
batchFeedback?: boolean;
|
|
/**
|
|
* The maximum number of tokens to pass when emitting the event - a value of 0 will cause all tokens to be passed after connection is reset. After this number of tokens are received the `feedback` event will be emitted. (Only applies when `batchFeedback` is enabled)
|
|
*/
|
|
batchSize?: number;
|
|
/**
|
|
* How often to automatically poll the feedback service. Set to `0` to disable. (Defaults to: `3600`)
|
|
*/
|
|
interval?: number;
|
|
}
|
|
export interface FeedbackData {
|
|
time: number;
|
|
device: Device;
|
|
}
|
|
/**
|
|
* Connection to the Apple Push Notification Feedback Service and if `interval` isn't disabled automatically begins polling the service. Many of the options are the same as `apn.Connection()`
|
|
*/
|
|
export declare class Feedback {
|
|
constructor(options: FeedbackOptions);
|
|
/**
|
|
* Trigger a query of the feedback service. If `interval` is non-zero then this method will be called automatically.
|
|
*/
|
|
start(): void;
|
|
/**
|
|
* You can cancel the interval by calling `feedback.cancel()`. If you do not wish to have the service automatically queried then set `interval` to 0 and use `feedback.start()` to manually invoke it one time.
|
|
*/
|
|
cancel(): void;
|
|
/**
|
|
* Emitted when an error occurs initialising the module. Usually caused by failing to load the certificates.
|
|
*/
|
|
on(event: "error", listener: (error: Error) => void): Feedback;
|
|
/**
|
|
* Emitted when an error occurs receiving or processing the feedback and in the case of a socket error occurring. These errors are usually informational and node-apn will automatically recover.
|
|
*/
|
|
on(event: "feedbackError", listener: (error: Error) => void): Feedback;
|
|
/**
|
|
* Emitted when data has been received from the feedback service, typically once per connection. `feedbackData` is an array of objects, each containing the `time` returned by the server (epoch time) and the `device` a `Buffer` containing the device token.
|
|
*/
|
|
on(event: "feedback", listener: (feedbackData: FeedbackData[]) => void): Feedback;
|
|
on(event: string, listener: Function): Feedback;
|
|
}
|
|
|
|
export declare enum Errors {
|
|
"noErrorsEncountered" = 0,
|
|
"processingError" = 1,
|
|
"missingDeviceToken" = 2,
|
|
"missingTopic" = 3,
|
|
"missingPayload" = 4,
|
|
"invalidTokenSize" = 5,
|
|
"invalidTopicSize" = 6,
|
|
"invalidPayloadSize" = 7,
|
|
"invalidToken" = 8,
|
|
"apnsShutdown" = 10,
|
|
"none" = 255,
|
|
"retryLimitExceeded" = 512,
|
|
"moduleInitialisationFailed" = 513,
|
|
"connectionRetryLimitExceeded" = 514, // When a connection is unable to be established. Usually because of a network / SSL error this will be emitted
|
|
"connectionTerminated" = 515
|
|
}
|
|
|
|
//Lowercase aliases
|
|
export { Connection as connection };
|
|
export { Device as device };
|
|
export { Errors as error };
|
|
export { Feedback as feedback };
|
|
export { Notification as notification };
|