@sebbo2002/vestaboard2mqtt 4.0.5-develop.4 → 5.0.0-develop.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/index.ts","../../src/lib/cache.ts","../../src/lib/config.ts","../../src/lib/message.ts","../../src/lib/pages/message.ts","../../src/lib/pages/calendar.ts","../../src/lib/pages/today.ts","../../src/lib/pages/index.ts","../../src/bin/start.ts"],"sourcesContent":["import mqtt from 'async-mqtt';\nimport Config from './config.js';\nimport Cache from './cache.js';\nimport { MqttClient } from 'mqtt';\nimport Message from './message.js';\nimport pages from './pages/index.js';\nimport Page from './page.js';\nimport { Vesta } from 'vestaboard-api';\n\nexport default class Vestaboard2MQTT {\n private readonly mqtt: MqttClient;\n private readonly board: Vesta;\n private readonly pageConfig = new Cache('page-config');\n private subscriptionIds?: string[];\n private currentMessage?: {page: Page<unknown>, payload: string};\n private currentTimer?: NodeJS.Timeout;\n\n public static async run(): Promise<Vestaboard2MQTT> {\n await Config.load();\n return new Vestaboard2MQTT();\n }\n\n constructor() {\n this.board = new Vesta({\n apiKey: Config.board.key,\n apiSecret: Config.board.secret\n });\n\n this.mqtt = mqtt.connect(Config.mqtt.url, {\n will: {\n topic: Config.mqtt.prefix + '/status',\n payload: 'offline',\n qos: 0,\n retain: true\n }\n });\n this.mqtt.on('connect', () => {\n this.mqtt.publish(Config.mqtt.prefix + '/status', 'online', {\n retain: true\n });\n\n this.setupBrokerSubscriptions().catch(error => {\n console.error(new Error(`Unable to setup mqtt subscriptions: ${error.stack}`));\n process.exit(1);\n });\n });\n this.mqtt.on('message', (topic, message) => {\n this.handleMessage(topic, message.toString()).catch(error => {\n this.debug(`Unable to handle message: ${error.stack}`);\n });\n });\n }\n\n private async setupBrokerSubscriptions() {\n if(!this.mqtt) {\n throw new Error('Unable to setup subscriptions: client not set.');\n }\n\n await this.mqtt.subscribe(Config.mqtt.prefix + '/#');\n }\n\n private debug(message: Error | string) {\n const msg = String(message);\n this.mqtt.publish(Config.mqtt.prefix + '/debug', msg);\n console.log(msg);\n }\n\n private async handleMessage(topic: string, payload: string): Promise<void> {\n if([Config.mqtt.prefix + '/debug', Config.mqtt.prefix + '/status'].includes(topic)) {\n // just ignore my own events\n }\n else if(topic === Config.mqtt.prefix + '/disabled') {\n const value = ['1', 'true', 'TRUE'].includes(payload);\n await Config.updateDisabled(value);\n if(!value) {\n this.debug('Board not disabled anymore, update with latest message');\n await this.updateCurrentMessage();\n }\n }\n else if(Object.keys(pages).map(id => Config.mqtt.prefix + '/' + id).includes(topic)) {\n const page = pages[ topic.substr(Config.mqtt.prefix.length + 1) ];\n await this.renderMessage(page, payload);\n }\n else {\n const page = Object.entries(pages)\n .find(([id]) => topic.startsWith(Config.mqtt.prefix + '/' + id + '/'));\n\n if(!page) {\n this.debug(`Unknown topic ${topic}, I'm sorry`);\n return;\n }\n\n const key = topic.substr((Config.mqtt.prefix + '/' + page[0] + '/').length);\n const cache = await this.pageConfig.get<Partial<unknown>>(page[0]);\n\n const config = page[1].parseConfig(key, payload, cache || {});\n const newConfig = Object.assign(cache || {}, config);\n await this.pageConfig.set(page[0], newConfig);\n await this.updateCurrentMessage();\n this.debug(`Update config for page module ${page[0]}: ${JSON.stringify(newConfig, null, ' ')}`);\n }\n }\n\n private async updateCurrentMessage() {\n if(this.currentMessage) {\n await this.renderMessage(\n this.currentMessage.page,\n this.currentMessage.payload\n );\n }\n }\n\n private async renderMessage(page: Page<unknown>, payload: string) {\n this.currentMessage = {\n page,\n payload\n };\n\n const pageEntry = Object.entries(pages).find(([,pageInstance]) => pageInstance === page);\n if(Config.board.disabled || !pageEntry) {\n return;\n }\n\n const parsePayload = await page.parsePayload(payload);\n const config = await this.pageConfig.get<Partial<unknown>>(pageEntry[0]);\n\n const response = await page.render(parsePayload, config || {});\n if (response.message) {\n await this.sendMessage(response.message);\n }\n\n if(this.currentTimer) {\n clearTimeout(this.currentTimer);\n delete this.currentTimer;\n }\n if(response.validTill) {\n this.debug(`Set timer for ${response.validTill.toString()} to update message`);\n this.currentTimer = setTimeout(() => {\n this.debug('Here I am again, updating the message now…');\n this.renderMessage(page, payload).catch(error => {\n this.debug(`Unable to update page: ${error}`);\n });\n }, response.validTill.getTime() - new Date().getTime());\n }\n }\n\n private async sendMessage(message: Message = new Message()): Promise<void> {\n const charArray = message.export();\n\n if(!this.subscriptionIds) {\n const subscriptions = await this.board.getSubscriptions();\n this.subscriptionIds = subscriptions.map(i => i._id);\n }\n\n this.debug('Sending Message:\\n\\n' + message.toString());\n\n await Promise.all(this.subscriptionIds.map(id => this.board.postMessage(id, charArray)));\n }\n}\n","import {join} from 'path';\nimport {existsSync} from 'fs';\nimport {promises} from 'fs';\n\ntype CacheData = Record<string, CacheNamespace>;\ntype CacheNamespace = Record<string, CacheItem>;\ntype CacheItem = CacheItemObject | CacheValue;\ntype CacheItemObject = {updated: number, value: CacheValue};\ntype CacheValue = unknown;\n\n// as node@12 has no 'fs/promises'\nconst {readFile, writeFile} = promises;\n\nexport default class Cache {\n private static readonly file: string = join(process.env.HOME || '~', '.vestaboard2mqtt');\n private readonly namespace: string;\n private static currentFetch?: Promise<void>;\n private static currentData?: CacheData = {};\n\n constructor(namespace: string) {\n this.namespace = namespace;\n }\n\n static async fetch(): Promise<void> {\n if(this.currentFetch) {\n return this.currentFetch;\n }\n\n const fetch = this.fetchFromFile();\n this.currentFetch = fetch;\n return fetch;\n }\n\n static async fetchFromFile (): Promise<void> {\n if(!existsSync(this.file)) {\n return;\n }\n\n try {\n const content = await readFile(this.file, {encoding: 'utf8'});\n this.currentData = JSON.parse(content);\n }\n catch(error) {\n console.warn(`Unable to parse cache file: ${error}`);\n }\n }\n\n static isCacheItemObject(obj: CacheItem): obj is CacheItemObject {\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n return typeof obj === 'object' && typeof obj.updated === 'number' && typeof obj.value !== 'undefined';\n }\n\n async get<T>(key: string, maxAge = 0): Promise<T | null> {\n await Cache.fetch();\n\n if(\n !Cache.currentData ||\n !Cache.currentData[this.namespace] ||\n !Cache.currentData[this.namespace][key]\n ) {\n return null;\n }\n\n const item = Cache.currentData[this.namespace][key];\n if(!Cache.isCacheItemObject(item) && maxAge > 0) {\n return null;\n }\n if(!Cache.isCacheItemObject(item)) {\n return item as T;\n }\n\n if(maxAge > 0 && new Date().getTime() - item.updated > maxAge) {\n return null;\n }\n\n return item.value as T;\n }\n\n async set(key: string, value: unknown): Promise<void> {\n await Cache.fetch();\n\n if(!Cache.currentData) {\n throw new Error('Unable to set value: currentData is empty!');\n }\n\n Cache.currentData[this.namespace] = Cache.currentData[this.namespace] || {};\n Cache.currentData[this.namespace][key] = {\n updated: new Date().getTime(),\n value\n };\n\n await Cache.save().catch(error => {\n console.warn(`Unable to update cache: ${error}`);\n });\n }\n\n async delete(key: string): Promise<void> {\n if(\n !Cache.currentData ||\n !Cache.currentData[this.namespace]\n ) {\n return;\n }\n\n delete Cache.currentData[this.namespace][key];\n\n if(Object.keys(Cache.currentData[this.namespace]).length === 0) {\n delete Cache.currentData[this.namespace];\n }\n\n await Cache.save().catch(error => {\n console.warn(`Unable to update cache: ${error}`);\n });\n }\n\n static async save(): Promise<void> {\n await writeFile(this.file, JSON.stringify(this.currentData, null, ' '));\n }\n}\n","import Cache from './cache.js';\n\nexport interface ConfigBoardData {\n id: string;\n key: string;\n secret: string;\n disabled: boolean;\n}\n\nexport interface ConfigMQTTData {\n url: string;\n prefix: string;\n}\n\nexport interface ConfigCalendarData {\n urls: Record<string, string>;\n cacheTTL: number;\n}\n\nexport interface ConfigData {\n board: ConfigBoardData;\n mqtt: ConfigMQTTData;\n calendar: ConfigCalendarData;\n}\n\nexport default class Config {\n private static readonly cache = new Cache('config');\n private static data?: ConfigData;\n\n public static get loaded(): boolean {\n return !!this.data && !!this.cache;\n }\n\n public static get board(): ConfigBoardData {\n if(this.loaded && this.data?.board) {\n return this.data.board;\n }\n\n throw new Error('Unable to access board config, is config loaded?');\n }\n\n public static get mqtt(): ConfigMQTTData {\n if(this.loaded && this.data?.mqtt) {\n return this.data.mqtt;\n }\n\n throw new Error('Unable to access mqtt config, is config loaded?');\n }\n\n public static get calendar(): ConfigCalendarData {\n if(this.loaded && this.data?.calendar) {\n return this.data.calendar;\n }\n\n throw new Error('Unable to access calendar config, is config loaded?');\n }\n\n public static async load(): Promise<void> {\n const data = await this.cache.get<ConfigData>('default');\n if(!data) {\n throw new Error('Unable to load configuration, try to run the setup script…');\n }\n\n this.data = data;\n }\n\n public static async save(data: ConfigData): Promise<void> {\n this.data = data;\n await this.cache.set('default', data);\n }\n\n public static async updateDisabled(newValue: boolean): Promise<void> {\n if(newValue === this.data?.board.disabled || !this.loaded || !this.data?.mqtt) {\n return;\n }\n\n this.data.board.disabled = newValue;\n await this.save(this.data);\n }\n}\n","import {BoardCharArray, characterCode, emptyBoard, LINE_LENGTH} from 'vestaboard-api/lib/cjs/values.js';\n\nexport enum MessageWriteOptionsLine {\n CURRENT = 'CURRENT',\n NEXT = 'NEXT'\n}\n\nexport interface MessageWriteOptions {\n line?: number | MessageWriteOptionsLine;\n row?: number;\n}\n\nexport interface MessageDrawOptions {\n line?: number;\n}\n\n\nconst SPECIAL_CHAR_MAP = [\n ['ä', [1, 5]],\n ['Ä', [1, 5]],\n ['ö', [15, 5]],\n ['Ö', [15, 5]],\n ['ü', [21, 5]],\n ['Ü', [21, 5]],\n ['ß', [19, 19]],\n ['🟥', [63]],\n ['🟧', [64]],\n ['🟨', [65]],\n ['🟩', [66]],\n ['🟦', [67]],\n ['🟪', [68]],\n ['⬜️', [69]],\n ['⬜', [69]],\n ['⬛️', [0]],\n ['⬛', [0]],\n ['﹫', [38]],\n ['@', [38]],\n ['0️⃣', [36]],\n ['1️⃣', [27]],\n ['2️⃣', [28]],\n ['3️⃣', [29]],\n ['4️⃣', [30]],\n ['5️⃣', [31]],\n ['6️⃣', [32]],\n ['7️⃣', [33]],\n ['8️⃣', [34]],\n ['9️⃣', [35]],\n ['❕', [37]],\n ['‼️', [37, 37]],\n ['❗️', [37]],\n ['⁉️', [37, 60]],\n ['⚠️', [65]],\n ['#️⃣', [39]],\n ['💸', [40]],\n ['💲', [40]],\n ['💵', [40]],\n ['💰', [40]],\n ['$', [40]],\n ['﹩', [40]],\n ['$', [40]],\n ['←', [44]],\n ['→', [44]],\n ['➡', [44]],\n ['⬅', [44]],\n ['➔', [44]],\n ['↔', [44]],\n ['–', [44]],\n ['➕', [46]],\n ['+', [46]],\n ['﹪', [54]],\n ['%', [54]],\n ['❓', [60]],\n ['❔', [60]],\n ['℃', [62, 3]],\n ['℉', [62, 6]]\n];\n\n\nexport default class Message {\n private board: BoardCharArray;\n private currentLine: number | null = null;\n private isFilled = false;\n\n constructor(board: BoardCharArray = Message.newBoardCharArray()) {\n this.board = board;\n }\n\n static newBoardCharArray(): BoardCharArray {\n return JSON.parse(JSON.stringify(emptyBoard));\n }\n\n write(text: string, options: MessageWriteOptions = {}) : void{\n let firstLine = 0;\n if(this.isFilled) {\n return;\n }\n\n if(options.line === MessageWriteOptionsLine.CURRENT) {\n firstLine = this.currentLine || 0;\n }\n else if(options.line === MessageWriteOptionsLine.NEXT && this.currentLine === null) {\n this.currentLine = 0;\n firstLine = this.currentLine;\n }\n else if(\n options.line === MessageWriteOptionsLine.NEXT &&\n typeof this.currentLine === 'number' &&\n this.currentLine < this.board.length - 1\n ) {\n // console.log('write() → current line + 1');\n this.currentLine++;\n firstLine = this.currentLine;\n }\n else if(options.line === MessageWriteOptionsLine.NEXT) {\n this.isFilled = true;\n return;\n }\n else if(options.line !== undefined) {\n firstLine = options.line;\n }\n\n const status = {\n firstLine,\n lastLine: this.board.length - 1,\n firstRow: options.row || 0,\n lastRow: LINE_LENGTH - 1\n };\n const pointer = [status.firstRow, status.firstLine];\n\n const words = text.split(/\\s+/);\n words.forEach((word, i) => {\n\n // Space\n if(i !== 0 && pointer[0] !== status.firstRow) {\n this.board[pointer[1]][pointer[0]] = 0;\n pointer[0]++;\n }\n\n let charsLeftInLine = status.lastRow - pointer[0] + 1;\n const chars = Message.word2chars(word);\n // console.log(\n // 'write()',\n // 'chars =', chars,\n // 'left =', charsLeftInLine,\n // `(${status.lastRow} - ${pointer[0]})`,\n // 'pointer =', pointer,\n // 'charsLeftInLine =', charsLeftInLine\n // );\n\n // Unsupported Word / emoji?\n if(chars.filter(c => c === 60).length === chars.length && chars.length > 0) {\n return;\n }\n\n // New Line?\n if(\n chars.length > charsLeftInLine &&\n chars.length <= status.lastRow - status.firstRow + 1 &&\n pointer[1] < status.lastLine\n ) {\n pointer[0] = status.firstRow;\n pointer[1]++;\n charsLeftInLine = status.lastRow - pointer[0];\n // console.log('write() → new line', 'chars =', chars, 'left =', charsLeftInLine, `(${status.lastRow} - ${pointer[0]})`, 'pointer =', pointer);\n }\n\n // Add Word\n if(chars.length <= charsLeftInLine) {\n this.board[pointer[1]].splice(pointer[0], chars.length, ...chars);\n pointer[0] += chars.length;\n }\n else if(chars.length > charsLeftInLine && charsLeftInLine > 5) {\n this.board[pointer[1]].splice(pointer[0], charsLeftInLine, ...chars.slice(0, charsLeftInLine));\n pointer[0] += charsLeftInLine;\n }\n });\n this.currentLine = pointer[1];\n }\n\n static word2chars(word: string): number[] {\n const result: number[] = [];\n for(const char of word) {\n result.push(...this.char2char(char));\n }\n\n return result;\n }\n\n static char2char(char: string): number[] {\n const fromVestaMap = Object.entries(characterCode)\n .find(([key]) => char === key);\n if(fromVestaMap) {\n return [ fromVestaMap[1]] ;\n }\n\n const fromMyMap = SPECIAL_CHAR_MAP\n .find(([mapChar]) => char === mapChar);\n if(fromMyMap && Array.isArray(fromMyMap[1])) {\n return fromMyMap[1];\n }\n\n return [60];\n }\n\n repeat(char: string, options: MessageDrawOptions = {}): void {\n const line = this.board[options.line || 0];\n line.fill(Message.char2char(char)[0]);\n }\n\n centerLines(): void {\n this.board.forEach(line => {\n const space = [line.findIndex(c => c !== 0), line.slice().reverse().findIndex(c => c !== 0)];\n\n // Line is completely full, continue…\n if(space[0] === -1 || space[1] === -1) {\n return;\n }\n\n const content = line.slice(space[0], line.length - space[1]);\n const padding = Math.floor((space[0] + space[1]) / 2);\n\n line.fill(0, 0, padding);\n line.splice(padding, content.length, ...content);\n line.fill(0, padding + content.length);\n });\n }\n\n center(): void {\n const space = [\n this.board.findIndex(l => l.find(c => c !== 0)),\n Math.min(...this.board.map(l => l.find(c => c !== 0) ? l.slice().reverse().findIndex(c => c !== 0) : l.length)),\n this.board.slice().reverse().findIndex(l => l.find(c => c !== 0)),\n Math.min(...this.board.map(l => l.find(c => c !== 0) ? l.findIndex(c => c !== 0) : l.length)),\n ];\n\n const padding = [\n Math.floor((space[0] + space[2]) / 2),\n Math.floor((space[1] + space[3]) / 2)\n ];\n\n // Move up/down\n if(space[0] !== padding[0]) {\n const add = padding[0] - space[0];\n this.board.splice(space[0] < padding[0] ? 0 : this.board.length - add, 0,\n ...this.board.splice(this.board.length - add, add)\n );\n }\n\n // Move left/right\n if(space[3] !== padding[1]) {\n const add = padding[1] - space[3];\n\n this.board.forEach(line => {\n line.splice(space[3] < padding[1] ? 0 : line.length - add, 0,\n ...line.splice(line.length - add, add)\n );\n });\n }\n }\n\n isEmpty (): boolean {\n return !this.board.find(line =>\n line.find(char => char !== 0)\n );\n }\n\n toString(): string {\n return '#=' + '='.repeat(LINE_LENGTH * 2) + '=#\\n' +\n this.board\n .map(line => '# ' + line.map(char => Message.charToString(char)).join('') + ' #\\n')\n .join('') +\n '#=' + '='.repeat(LINE_LENGTH * 2) + '=#\\n';\n }\n\n static charToString(char: number): string {\n const entry = Object.entries(characterCode)\n .filter(([name]) => name.length <= 2)\n .find(([, code]) => code === char);\n\n if (entry) {\n return entry[0].toUpperCase() + ' ';\n }\n\n switch (char) {\n case 63:\n return '🟥';\n case 64:\n return '🟧';\n case 65:\n return '🟨';\n case 66:\n return '🟩';\n case 67:\n return '🟦';\n case 68:\n return '🟪';\n case 69:\n return '⬜️';\n default:\n return ' ';\n }\n }\n\n export(): BoardCharArray {\n return this.board;\n }\n}\n","import Cache from '../cache.js';\nimport Page, {PageRenderResponse} from '../page.js';\nimport Message, {MessageWriteOptionsLine} from '../message.js';\n\n\nexport default class MessagePage implements Page<string> {\n static readonly cache = new Cache('calendar');\n\n parsePayload(payload: string | null): string {\n return payload || '';\n }\n\n parseConfig(): Partial<Record<string, never>> {\n return {};\n }\n\n public async render (content: string): Promise<PageRenderResponse> {\n const message = new Message();\n\n content.split('\\n').forEach(line => {\n message.write(line, {line: MessageWriteOptionsLine.NEXT});\n });\n\n message.centerLines();\n message.center();\n return {message};\n }\n}\n","import Cache from '../cache.js';\nimport Page, {PageRenderResponse} from '../page.js';\nimport Message, {MessageWriteOptionsLine} from '../message.js';\nimport ical, { VEvent } from 'node-ical';\nimport Config from '../config.js';\nimport TodayPage, {TodayPagePayload} from './today.js';\n\n\nexport interface CalendarPagePayload {\n calendars: string[];\n}\n\nexport type CalendarPageItem = {start: Date, end: Date, summary: string};\n\nexport default class CalendarPage implements Page<CalendarPagePayload> {\n static readonly cache = new Cache('calendar');\n\n public parsePayload(payload: string | null): CalendarPagePayload {\n return {\n calendars: (payload || '').split(',')\n };\n }\n\n parseConfig(): Partial<Record<string, never>> {\n return {};\n }\n\n public async fetchURL(url: string): Promise<CalendarPageItem[]> {\n let preCached = await CalendarPage.cache.get<CalendarPageItem[]>(url, 1000 * 60 * 10);\n if(!preCached) {\n const calendar = await ical.async.fromURL(url);\n const events = Object.values(calendar)\n .filter(entry =>\n entry.type === 'VEVENT' &&\n entry.start &&\n entry.end &&\n entry.summary\n ) as VEvent[];\n preCached = events\n .map(entry => ({\n start: new Date(String(entry.start)),\n end: new Date(String(entry.end)),\n summary: String(entry.summary).trim()\n }))\n .filter(entry => entry.end > new Date())\n .sort((a, b) => a.end.getTime() - b.end.getTime())\n .slice(0, 6);\n\n await CalendarPage.cache.set(url, preCached);\n }\n\n return preCached\n .map(entry => ({\n start: new Date(String(entry.start)),\n end: new Date(String(entry.end)),\n summary: String(entry.summary)\n }))\n .filter(entry =>\n entry.end > new Date()\n );\n }\n\n public static isSameDay (a: Date, b: Date): boolean {\n const result = Boolean(\n a.getFullYear() === b.getFullYear() &&\n a.getMonth() === b.getMonth() &&\n a.getDate() === b.getDate()\n );\n\n return result;\n }\n\n public static isMidnight (date: Date): boolean {\n const result = Boolean(\n !date.getHours() &&\n !date.getMinutes() &&\n !date.getSeconds() &&\n !date.getMilliseconds()\n );\n\n return result;\n }\n\n public async fetchURLs(urls: string[]): Promise<CalendarPageItem[]> {\n const rawResult: {start: Date, end: Date, summary: string}[][] = await Promise.all(urls.map(url => this.fetchURL(url)));\n return ([] as CalendarPageItem[])\n .concat(...rawResult)\n .filter(entry => entry.end > new Date())\n .sort((a, b) => a.end.getTime() - b.end.getTime());\n }\n\n public static getTimeStr (event: CalendarPageItem, oneLine = false): string {\n if(\n this.isMidnight(event.start) &&\n this.isMidnight(event.end) &&\n this.isSameDay(new Date(), event.start)\n ) {\n return 'Heute';\n }\n if(\n this.isMidnight(event.start) &&\n this.isMidnight(event.end) &&\n this.isSameDay(new Date(new Date().getTime() + 1000 * 60 * 60 * 24), event.start)\n ) {\n return oneLine ? 'Morgen' : 'Morgn';\n }\n\n return event.start.getHours().toString().padStart(2, '⬛️') + ':' +\n event.start.getMinutes().toString().padStart(2, '0');\n }\n\n public async render (payload: CalendarPagePayload): Promise<PageRenderResponse> {\n const message = new Message();\n const urls = payload.calendars\n .map(id => Config.calendar.urls[id])\n .filter(Boolean);\n\n const calendar = await this.fetchURLs(urls)\n .then(calendar => calendar.filter(entry => {\n if (CalendarPage.isMidnight(entry.start) && CalendarPage.isMidnight(entry.end)) {\n return CalendarPage.isSameDay(new Date(), entry.start) || (\n new Date().getHours() >= 20 &&\n CalendarPage.isSameDay(new Date(new Date().getTime() + 1000 * 60 * 60 * 24), entry.start)\n );\n } else {\n return entry.start < new Date(new Date().getTime() + (1000 * 60 * 60 * 12));\n }\n }));\n\n if(!calendar.length) {\n const today = new TodayPage();\n const pageConfigCache = new Cache('page-config');\n const config = await pageConfigCache.get<Partial<TodayPagePayload>>('today');\n return today.render({}, config || {});\n }\n\n let validTill = new Date(new Date().getTime() + 1000 * 60 * 10);\n calendar.forEach(event => {\n message.write(\n CalendarPage.getTimeStr(event, calendar.length === 1),\n {line: MessageWriteOptionsLine.NEXT}\n );\n\n message.write(event.summary, {line: MessageWriteOptionsLine.CURRENT, row: 6});\n message.write('', {line: MessageWriteOptionsLine.NEXT});\n\n if(event.end < validTill) {\n validTill = event.end;\n }\n });\n\n message.center();\n return {\n message,\n validTill\n };\n }\n}\n","import Cache from '../cache.js';\nimport Page, {PageRenderResponse} from '../page.js';\nimport Message, {MessageWriteOptionsLine} from '../message.js';\n\nexport interface TodayPagePayload {\n temp?: [number, number];\n precip?: number;\n locale: string;\n}\n\nexport default class TodayPage implements Page<Partial<TodayPagePayload>, TodayPagePayload> {\n static readonly cache = new Cache('calendar');\n\n parsePayload(payload: string | null): Partial<TodayPagePayload> {\n try {\n return JSON.parse(payload || '') as Partial<TodayPagePayload>;\n }\n catch(error) {\n return {};\n }\n }\n\n parseConfig(key: string, value: string | null, config: Partial<TodayPagePayload>): Partial<TodayPagePayload> {\n const result: Partial<TodayPagePayload> = {};\n console.log('parseConfig', config);\n\n if(key === 'min-temp' && Array.isArray(config.temp)) {\n result.temp = [\n parseInt(value || ''),\n Math.max(...config.temp)\n ];\n }\n else if(key === 'min-temp') {\n result.temp = [\n parseInt(value || ''),\n parseInt(value || '')\n ];\n }\n else if(key === 'max-temp' && Array.isArray(config.temp)) {\n result.temp = [\n Math.min(...config.temp),\n parseInt(value || '')\n ];\n }\n else if(key === 'max-temp') {\n result.temp = [\n parseInt(value || ''),\n parseInt(value || '')\n ];\n }\n else if(key === 'precip') {\n result.precip = parseInt(value || '', 10);\n }\n else if(key === 'locale') {\n result.locale = String(value);\n }\n\n return result;\n }\n\n public async render (payload: Partial<TodayPagePayload>, config: Partial<TodayPagePayload>): Promise<PageRenderResponse> {\n const message = new Message();\n const today = new Date();\n\n const mergedPayload: TodayPagePayload = Object.assign({\n temp: undefined,\n precip: undefined,\n locale: 'en'\n }, config, payload);\n\n message.write(today.toLocaleString(mergedPayload.locale, {weekday: 'long'}));\n message.write(\n today.toLocaleString(mergedPayload.locale, {day: 'numeric', month: 'long'}),\n {line: MessageWriteOptionsLine.NEXT}\n );\n\n message.write('', {line: MessageWriteOptionsLine.NEXT});\n\n const varContent = [];\n if(Array.isArray(mergedPayload.temp)) {\n varContent.push(`${Math.min(...mergedPayload.temp)}-${Math.max(...mergedPayload.temp)}°C`);\n }\n if(typeof mergedPayload.precip === 'number' && mergedPayload.precip > 0) {\n varContent.push(`${mergedPayload.precip}%`);\n }\n if(varContent.length) {\n message.write(varContent.join(', '), {line: MessageWriteOptionsLine.NEXT});\n }\n\n message.center();\n\n const validTill = new Date();\n validTill.setHours(24,0,0,0);\n\n return { message, validTill };\n }\n}\n","import Page from '../page.js';\nimport MessagePage from './message.js';\nimport CalendarPage from './calendar.js';\nimport TodayPage from './today.js';\n\nconst pages: Record<string, Page<unknown, unknown>> = {\n message: new MessagePage(),\n calendar: new CalendarPage(),\n today: new TodayPage()\n};\n\nexport default pages;\n","#!/usr/bin/env node\n'use strict';\n\nimport Vestaboard2MQTT from '../lib/index.js';\n\nVestaboard2MQTT.run().catch(error => {\n console.log(error);\n process.exit(1);\n});\n"],"mappings":"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","names":["import_async_mqtt","import_path","import_fs","readFile","writeFile","_Cache","namespace","__async","fetch","content","error","obj","key","maxAge","item","value","Cache","Config","_a","__async","data","newValue","_b","Cache","import_values","SPECIAL_CHAR_MAP","Message","_Message","board","text","options","firstLine","status","pointer","word","i","charsLeftInLine","chars","c","result","char","fromVestaMap","key","fromMyMap","mapChar","line","space","content","padding","l","add","entry","name","code","MessagePage","payload","content","__async","message","Message","line","Cache","import_node_ical","TodayPage","payload","error","key","value","config","result","__async","message","Message","today","mergedPayload","varContent","validTill","Cache","_CalendarPage","payload","url","__async","preCached","calendar","ical","entry","a","b","date","urls","rawResult","event","oneLine","message","Message","id","Config","today","TodayPage","config","Cache","validTill","CalendarPage","pages","MessagePage","CalendarPage","TodayPage","pages_default","import_vestaboard_api","Vestaboard2MQTT","_Vestaboard2MQTT","Cache","Config","mqtt","error","topic","message","__async","msg","payload","value","pages_default","id","page","key","cache","config","newConfig","pageEntry","pageInstance","parsePayload","response","Message","charArray","subscriptions","i","Vestaboard2MQTT","error"]}
1
+ {"version":3,"sources":["../../node_modules/xtend/immutable.js","../../node_modules/readable-stream/lib/internal/streams/stream.js","../../node_modules/readable-stream/lib/internal/streams/buffer_list.js","../../node_modules/readable-stream/lib/internal/streams/destroy.js","../../node_modules/readable-stream/errors.js","../../node_modules/readable-stream/lib/internal/streams/state.js","../../node_modules/inherits/inherits_browser.js","../../node_modules/inherits/inherits.js","../../node_modules/util-deprecate/node.js","../../node_modules/readable-stream/lib/_stream_writable.js","../../node_modules/readable-stream/lib/_stream_duplex.js","../../node_modules/string_decoder/node_modules/safe-buffer/index.js","../../node_modules/string_decoder/lib/string_decoder.js","../../node_modules/readable-stream/lib/internal/streams/end-of-stream.js","../../node_modules/readable-stream/lib/internal/streams/async_iterator.js","../../node_modules/readable-stream/lib/internal/streams/from.js","../../node_modules/readable-stream/lib/_stream_readable.js","../../node_modules/readable-stream/lib/_stream_transform.js","../../node_modules/readable-stream/lib/_stream_passthrough.js","../../node_modules/readable-stream/lib/internal/streams/pipeline.js","../../node_modules/readable-stream/readable.js","../../node_modules/mqtt/lib/store.js","../../node_modules/mqtt/lib/topic-alias-recv.js","../../node_modules/yallist/iterator.js","../../node_modules/yallist/yallist.js","../../node_modules/lru-cache/index.js","../../node_modules/js-sdsl/dist/esm/container/ContainerBase/index.js","../../node_modules/js-sdsl/dist/esm/container/OtherContainer/Stack.js","../../node_modules/js-sdsl/dist/esm/container/SequentialContainer/Base/index.js","../../node_modules/js-sdsl/dist/esm/utils/checkParams.js","../../node_modules/js-sdsl/dist/esm/container/SequentialContainer/Base/RandomIterator.js","../../node_modules/js-sdsl/dist/esm/container/SequentialContainer/Deque.js","../../node_modules/js-sdsl/dist/esm/container/OtherContainer/Queue.js","../../node_modules/js-sdsl/dist/esm/container/OtherContainer/PriorityQueue.js","../../node_modules/js-sdsl/dist/esm/container/SequentialContainer/Vector.js","../../node_modules/js-sdsl/dist/esm/container/SequentialContainer/LinkList.js","../../node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/TreeNode.js","../../node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/index.js","../../node_modules/js-sdsl/dist/esm/container/TreeContainer/Base/TreeIterator.js","../../node_modules/js-sdsl/dist/esm/container/TreeContainer/OrderedSet.js","../../node_modules/js-sdsl/dist/esm/container/TreeContainer/OrderedMap.js","../../node_modules/js-sdsl/dist/esm/container/HashContainer/Base/index.js","../../node_modules/js-sdsl/dist/esm/container/HashContainer/HashSet.js","../../node_modules/js-sdsl/dist/esm/container/HashContainer/HashMap.js","../../node_modules/js-sdsl/dist/esm/index.js","../../node_modules/ms/index.js","../../node_modules/debug/src/common.js","../../node_modules/debug/src/browser.js","../../node_modules/has-flag/index.js","../../node_modules/supports-color/index.js","../../node_modules/debug/src/node.js","../../node_modules/debug/src/index.js","../../node_modules/number-allocator/lib/number-allocator.js","../../node_modules/number-allocator/index.js","../../node_modules/mqtt/lib/topic-alias-send.js","../../node_modules/bl/BufferList.js","../../node_modules/bl/bl.js","../../node_modules/mqtt-packet/packet.js","../../node_modules/mqtt-packet/constants.js","../../node_modules/mqtt-packet/parser.js","../../node_modules/mqtt-packet/numbers.js","../../node_modules/process-nextick-args/index.js","../../node_modules/mqtt-packet/writeToStream.js","../../node_modules/mqtt-packet/generate.js","../../node_modules/mqtt-packet/mqtt.js","../../node_modules/mqtt/lib/default-message-id-provider.js","../../node_modules/reinterval/index.js","../../node_modules/rfdc/index.js","../../node_modules/rfdc/default.js","../../node_modules/mqtt/lib/validations.js","../../node_modules/mqtt/lib/client.js","../../node_modules/mqtt/lib/connect/tcp.js","../../node_modules/mqtt/lib/connect/tls.js","../../node_modules/wrappy/wrappy.js","../../node_modules/once/once.js","../../node_modules/end-of-stream/index.js","../../node_modules/stream-shift/index.js","../../node_modules/duplexify/index.js","../../node_modules/mqtt/lib/connect/wx.js","../../node_modules/mqtt/lib/connect/ali.js","../../node_modules/ws/lib/constants.js","../../node_modules/ws/lib/buffer-util.js","../../node_modules/ws/lib/limiter.js","../../node_modules/ws/lib/permessage-deflate.js","../../node_modules/ws/lib/validation.js","../../node_modules/ws/lib/receiver.js","../../node_modules/ws/lib/sender.js","../../node_modules/ws/lib/event-target.js","../../node_modules/ws/lib/extension.js","../../node_modules/ws/lib/websocket.js","../../node_modules/ws/lib/stream.js","../../node_modules/ws/lib/websocket-server.js","../../node_modules/ws/index.js","../../node_modules/mqtt/lib/connect/ws.js","../../node_modules/mqtt/lib/connect/index.js","../../node_modules/mqtt/lib/unique-message-id-provider.js","../../node_modules/mqtt/mqtt.js","../../src/lib/index.ts","../../src/lib/cache.ts","../../src/lib/config.ts","../../src/lib/message.ts","../../src/lib/pages/message.ts","../../src/lib/pages/calendar.ts","../../src/lib/pages/today.ts","../../src/lib/pages/index.ts","../../src/bin/start.ts"],"sourcesContent":["module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n var target = {}\n\n for (var i = 0; i < arguments.length; i++) {\n var source = arguments[i]\n\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n target[key] = source[key]\n }\n }\n }\n\n return target\n}\n","module.exports = require('stream');\n","'use strict';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\n\nvar _require2 = require('util'),\n inspect = _require2.inspect;\n\nvar custom = inspect && inspect.custom || 'inspect';\n\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\n\nmodule.exports =\n/*#__PURE__*/\nfunction () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n\n while (p = p.next) {\n ret += s + p.data;\n }\n\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n\n return ret;\n } // Consumes a specified amount of bytes or characters from the buffered data.\n\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n } // Consumes a specified amount of characters from the buffered data.\n\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Consumes a specified amount of bytes from the buffered data.\n\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n\n break;\n }\n\n ++c;\n }\n\n this.length -= c;\n return ret;\n } // Make sure the linked list only shows the minimal necessary information.\n\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread({}, options, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n\n return BufferList;\n}();","'use strict'; // undocumented cb() API, needed for core, not for public API\n\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n\n return this;\n } // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n } // if this is a duplex stream mark the writable part as destroyed as well\n\n\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n\n return this;\n}\n\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\n\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nconst codes = {};\n\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error\n }\n\n function getMessage (arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message\n } else {\n return message(arg1, arg2, arg3)\n }\n }\n\n class NodeError extends Base {\n constructor (arg1, arg2, arg3) {\n super(getMessage(arg1, arg2, arg3));\n }\n }\n\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n\n codes[code] = NodeError;\n}\n\n// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n const len = expected.length;\n expected = expected.map((i) => String(i));\n if (len > 2) {\n return `one of ${thing} ${expected.slice(0, len - 1).join(', ')}, or ` +\n expected[len - 1];\n } else if (len === 2) {\n return `one of ${thing} ${expected[0]} or ${expected[1]}`;\n } else {\n return `of ${thing} ${expected[0]}`;\n }\n } else {\n return `of ${thing} ${String(expected)}`;\n }\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\nfunction startsWith(str, search, pos) {\n\treturn str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\nfunction endsWith(str, search, this_len) {\n\tif (this_len === undefined || this_len > str.length) {\n\t\tthis_len = str.length;\n\t}\n\treturn str.substring(this_len - search.length, this_len) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\n\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"'\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n let determiner;\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n\n let msg;\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = `The ${name} ${determiner} ${oneOf(expected, 'type')}`;\n } else {\n const type = includes(name, '.') ? 'property' : 'argument';\n msg = `The \"${name}\" ${type} ${determiner} ${oneOf(expected, 'type')}`;\n }\n\n msg += `. Received type ${typeof actual}`;\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented'\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\n\nmodule.exports.codes = codes;\n","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\n\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\n\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n\n return Math.floor(hwm);\n } // Default value\n\n\n return state.objectMode ? 16 : 16 * 1024;\n}\n\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","try {\n var util = require('util');\n /* istanbul ignore next */\n if (typeof util.inherits !== 'function') throw '';\n module.exports = util.inherits;\n} catch (e) {\n /* istanbul ignore next */\n module.exports = require('./inherits_browser.js');\n}\n","\n/**\n * For Node.js, simply re-export the core `util.deprecate` function.\n */\n\nmodule.exports = require('util').deprecate;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n'use strict';\n\nmodule.exports = Writable;\n/* <replacement> */\n\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n} // It seems a linked list but it is not\n// there will be only 2 of these for each stream\n\n\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* </replacement> */\n\n/*<replacement>*/\n\n\nvar Duplex;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n/*<replacement>*/\n\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\n\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\n\nrequire('inherits')(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex); // if _final has been called\n\n this.finalCalled = false; // drain event flag.\n\n this.needDrain = false; // at the start of calling end()\n\n this.ending = false; // when end() has been called, and returned\n\n this.ended = false; // when 'finish' is emitted\n\n this.finished = false; // has it been destroyed\n\n this.destroyed = false; // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n\n this.length = 0; // a flag to see when we're in the middle of a write.\n\n this.writing = false; // when true all writes will be buffered until .uncork() call\n\n this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n\n this.sync = true; // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n\n this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb)\n\n this.onwrite = function (er) {\n onwrite(stream, er);\n }; // the callback that the user supplies to write(chunk,encoding,cb)\n\n\n this.writecb = null; // the amount that is being written when _write is called.\n\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null; // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n\n this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n\n this.prefinished = false; // True if the error was already emitted and should not be thrown again\n\n this.errorEmitted = false; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'finish' (and potentially 'end')\n\n this.autoDestroy = !!options.autoDestroy; // count buffered requests\n\n this.bufferedRequestCount = 0; // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n\n while (current) {\n out.push(current);\n current = current.next;\n }\n\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})(); // Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\n\n\nvar realHasInstance;\n\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex'); // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex); // legacy.\n\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n} // Otherwise people can pipe Writable streams, which is just wrong.\n\n\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END(); // TODO: defer error events consistently everywhere, not just the cb\n\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n} // Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\n\n\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n\n return true;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\n\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n}); // if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\n\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false.\n\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er); // this can emit finish, and it will always happen\n // after error\n\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er); // this can emit finish, but finish must\n // always follow error\n\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n} // Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\n\n\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n} // if there's something in the buffer waiting, then process it\n\n\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n\n state.pendingcb++;\n state.lastBufferedRequest = null;\n\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--; // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks\n\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n } // ignore unnecessary end() calls.\n\n\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\n\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n\n if (err) {\n errorOrDestroy(stream, err);\n }\n\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\n\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n\n if (need) {\n prefinish(stream, state);\n\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n } // reuse the free corkReq.\n\n\n state.corkedRequestsFree.next = corkReq;\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\n\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n'use strict';\n/*<replacement>*/\n\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n\n for (var key in obj) {\n keys.push(key);\n }\n\n return keys;\n};\n/*</replacement>*/\n\n\nmodule.exports = Duplex;\n\nvar Readable = require('./_stream_readable');\n\nvar Writable = require('./_stream_writable');\n\nrequire('inherits')(Duplex, Readable);\n\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n}); // the no-half-open enforcer\n\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return; // no more data can be written.\n // But allow more writes to happen in this tick.\n\n process.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","/*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/*<replacement>*/\n\nvar Buffer = require('safe-buffer').Buffer;\n/*</replacement>*/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n callback.apply(this, args);\n };\n}\n\nfunction noop() {}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n\n var writableEnded = stream._writableState && stream._writableState.finished;\n\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n\n var onclose = function onclose() {\n var err;\n\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\n\nmodule.exports = eos;","'use strict';\n\nvar _Object$setPrototypeO;\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar finished = require('./end-of-stream');\n\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\n\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\n\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n\n if (resolve !== null) {\n var data = iter[kStream].read(); // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\n\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\n\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\n\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n\n next: function next() {\n var _this = this;\n\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n\n if (error !== null) {\n return Promise.reject(error);\n }\n\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n } // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n\n\n var lastPromise = this[kLastPromise];\n var promise;\n\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n\n promise = new Promise(this[kHandlePromise]);\n }\n\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\n\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject]; // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n\n iterator[kError] = err;\n return;\n }\n\n var resolve = iterator[kLastResolve];\n\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\n\nmodule.exports = createReadableStreamAsyncIterator;","'use strict';\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar ERR_INVALID_ARG_TYPE = require('../../../errors').codes.ERR_INVALID_ARG_TYPE;\n\nfunction from(Readable, iterable, opts) {\n var iterator;\n\n if (iterable && typeof iterable.next === 'function') {\n iterator = iterable;\n } else if (iterable && iterable[Symbol.asyncIterator]) iterator = iterable[Symbol.asyncIterator]();else if (iterable && iterable[Symbol.iterator]) iterator = iterable[Symbol.iterator]();else throw new ERR_INVALID_ARG_TYPE('iterable', ['Iterable'], iterable);\n\n var readable = new Readable(_objectSpread({\n objectMode: true\n }, opts)); // Reading boolean to protect against _read\n // being called before last iteration completion.\n\n var reading = false;\n\n readable._read = function () {\n if (!reading) {\n reading = true;\n next();\n }\n };\n\n function next() {\n return _next2.apply(this, arguments);\n }\n\n function _next2() {\n _next2 = _asyncToGenerator(function* () {\n try {\n var _ref = yield iterator.next(),\n value = _ref.value,\n done = _ref.done;\n\n if (done) {\n readable.push(null);\n } else if (readable.push((yield value))) {\n next();\n } else {\n reading = false;\n }\n } catch (err) {\n readable.destroy(err);\n }\n });\n return _next2.apply(this, arguments);\n }\n\n return readable;\n}\n\nmodule.exports = from;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n'use strict';\n\nmodule.exports = Readable;\n/*<replacement>*/\n\nvar Duplex;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n/*<replacement>*/\n\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\n\n\nvar Stream = require('./internal/streams/stream');\n/*</replacement>*/\n\n\nvar Buffer = require('buffer').Buffer;\n\nvar OurUint8Array = global.Uint8Array || function () {};\n\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\n\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n/*<replacement>*/\n\n\nvar debugUtil = require('util');\n\nvar debug;\n\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/*</replacement>*/\n\n\nvar BufferList = require('./internal/streams/buffer_list');\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\n\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.\n\n\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\n\nrequire('inherits')(Readable, Stream);\n\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {}; // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n\n this.sync = true; // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true; // Should close be emitted on destroy. Defaults to true.\n\n this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')\n\n this.autoDestroy = !!options.autoDestroy; // has it been destroyed\n\n this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n\n this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s\n\n this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled\n\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex); // legacy\n\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n } // backward compatibility, the user is explicitly\n // managing destroyed\n\n\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\n\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n}; // Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\n\n\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n}; // Unshift should *always* be something directly out of read()\n\n\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n } // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n\n\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n\n return er;\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n}; // backwards compatibility.\n\n\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8\n\n this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:\n\n var p = this._readableState.buffer.head;\n var content = '';\n\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n\n this._readableState.buffer.clear();\n\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n}; // Don't raise the hwm > 1GB\n\n\nvar MAX_HWM = 0x40000000;\n\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n\n return n;\n} // This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\n\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n } // If we're asking for more than the current hwm, then raise the hwm.\n\n\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n; // Don't have enough\n\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n\n return state.length;\n} // you can override either this method, or the async _read(n) below.\n\n\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.\n\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n } // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n // if we need a readable event, then we need to do some reading.\n\n\n var doRead = state.needReadable;\n debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some\n\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n } // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n\n\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true; // if the length is currently zero, then we *need* a readable event.\n\n if (state.length === 0) state.needReadable = true; // call internal read method\n\n this._read(state.highWaterMark);\n\n state.sync = false; // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.\n\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n\n if (state.decoder) {\n var chunk = state.decoder.end();\n\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n\n state.ended = true;\n\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n} // Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\n\n\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\n\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n } // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n\n\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n} // at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\n\n\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length) // didn't get any data, stop spinning.\n break;\n }\n\n state.readingMore = false;\n} // abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\n\n\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n\n default:\n state.pipes.push(dest);\n break;\n }\n\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n } // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n\n\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n\n function cleanup() {\n debug('cleanup'); // cleanup event handlers once the pipe is broken\n\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true; // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n src.on('data', ondata);\n\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n\n src.pause();\n }\n } // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n\n\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n } // Make sure our error handler is attached before userland ones.\n\n\n prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.\n\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n\n dest.once('close', onclose);\n\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n } // tell the dest that it's being piped to\n\n\n dest.emit('pipe', src); // start the flow if it hasn't been started already.\n\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n }; // if we're not piping anywhere, then do nothing.\n\n if (state.pipesCount === 0) return this; // just one destination. most common case.\n\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes; // got a match.\n\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n } // slow case. multiple pipe destinations.\n\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n }\n\n return this;\n } // try to find the right one.\n\n\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n}; // set up data events if they are asked for\n// Ensure readable listeners eventually get something\n\n\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused\n\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n\n return res;\n};\n\nReadable.prototype.addListener = Readable.prototype.on;\n\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n\n return res;\n};\n\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true; // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n} // pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\n\n\nReadable.prototype.resume = function () {\n var state = this._readableState;\n\n if (!state.flowing) {\n debug('resume'); // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n\n state.paused = false;\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n\n if (!state.reading) {\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n\n this._readableState.paused = true;\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n\n while (state.flowing && stream.read() !== null) {\n ;\n }\n} // wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\n\n\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode\n\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n\n if (!ret) {\n paused = true;\n stream.pause();\n }\n }); // proxy all the other methods.\n // important when wrapping filters and duplexes.\n\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n } // proxy certain important events.\n\n\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n } // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n\n\n this._read = function (n) {\n debug('wrapped _read', n);\n\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n\n return createReadableStreamAsyncIterator(this);\n };\n}\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n}); // exposed for testing purposes only.\n\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n}); // Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\n\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.\n\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\n\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n\n return from(Readable, iterable, opts);\n };\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n'use strict';\n\nmodule.exports = Transform;\n\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\n\nvar Duplex = require('./_stream_duplex');\n\nrequire('inherits')(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n }; // start out asking for a readable event once data is transformed.\n\n this._readableState.needReadable = true; // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n } // When the writable side finishes, then flush out anything remaining.\n\n\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n}; // This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\n\n\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n}; // Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\n\n\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data); // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\nrequire('inherits')(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n'use strict';\n\nvar eos;\n\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\n\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\n\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\n\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\n\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true; // request.destroy just do .end - .abort is what we want\n\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\n\nfunction call(fn) {\n fn();\n}\n\nfunction pipe(from, to) {\n return from.pipe(to);\n}\n\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\n\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\n\nmodule.exports = pipeline;","var Stream = require('stream');\nif (process.env.READABLE_STREAM === 'disable' && Stream) {\n module.exports = Stream.Readable;\n Object.assign(module.exports, Stream);\n module.exports.Stream = Stream;\n} else {\n exports = module.exports = require('./lib/_stream_readable.js');\n exports.Stream = Stream || exports;\n exports.Readable = exports;\n exports.Writable = require('./lib/_stream_writable.js');\n exports.Duplex = require('./lib/_stream_duplex.js');\n exports.Transform = require('./lib/_stream_transform.js');\n exports.PassThrough = require('./lib/_stream_passthrough.js');\n exports.finished = require('./lib/internal/streams/end-of-stream.js');\n exports.pipeline = require('./lib/internal/streams/pipeline.js');\n}\n","'use strict'\n\n/**\n * Module dependencies\n */\nconst xtend = require('xtend')\n\nconst Readable = require('readable-stream').Readable\nconst streamsOpts = { objectMode: true }\nconst defaultStoreOptions = {\n clean: true\n}\n\n/**\n * In-memory implementation of the message store\n * This can actually be saved into files.\n *\n * @param {Object} [options] - store options\n */\nfunction Store (options) {\n if (!(this instanceof Store)) {\n return new Store(options)\n }\n\n this.options = options || {}\n\n // Defaults\n this.options = xtend(defaultStoreOptions, options)\n\n this._inflights = new Map()\n}\n\n/**\n * Adds a packet to the store, a packet is\n * anything that has a messageId property.\n *\n */\nStore.prototype.put = function (packet, cb) {\n this._inflights.set(packet.messageId, packet)\n\n if (cb) {\n cb()\n }\n\n return this\n}\n\n/**\n * Creates a stream with all the packets in the store\n *\n */\nStore.prototype.createStream = function () {\n const stream = new Readable(streamsOpts)\n const values = []\n let destroyed = false\n let i = 0\n\n this._inflights.forEach(function (value, key) {\n values.push(value)\n })\n\n stream._read = function () {\n if (!destroyed && i < values.length) {\n this.push(values[i++])\n } else {\n this.push(null)\n }\n }\n\n stream.destroy = function () {\n if (destroyed) {\n return\n }\n\n const self = this\n\n destroyed = true\n\n setTimeout(function () {\n self.emit('close')\n }, 0)\n }\n\n return stream\n}\n\n/**\n * deletes a packet from the store.\n */\nStore.prototype.del = function (packet, cb) {\n packet = this._inflights.get(packet.messageId)\n if (packet) {\n this._inflights.delete(packet.messageId)\n cb(null, packet)\n } else if (cb) {\n cb(new Error('missing packet'))\n }\n\n return this\n}\n\n/**\n * get a packet from the store.\n */\nStore.prototype.get = function (packet, cb) {\n packet = this._inflights.get(packet.messageId)\n if (packet) {\n cb(null, packet)\n } else if (cb) {\n cb(new Error('missing packet'))\n }\n\n return this\n}\n\n/**\n * Close the store\n */\nStore.prototype.close = function (cb) {\n if (this.options.clean) {\n this._inflights = null\n }\n if (cb) {\n cb()\n }\n}\n\nmodule.exports = Store\n","'use strict'\n\n/**\n * Topic Alias receiving manager\n * This holds alias to topic map\n * @param {Number} [max] - topic alias maximum entries\n */\nfunction TopicAliasRecv (max) {\n if (!(this instanceof TopicAliasRecv)) {\n return new TopicAliasRecv(max)\n }\n this.aliasToTopic = {}\n this.max = max\n}\n\n/**\n * Insert or update topic - alias entry.\n * @param {String} [topic] - topic\n * @param {Number} [alias] - topic alias\n * @returns {Boolean} - if success return true otherwise false\n */\nTopicAliasRecv.prototype.put = function (topic, alias) {\n if (alias === 0 || alias > this.max) {\n return false\n }\n this.aliasToTopic[alias] = topic\n this.length = Object.keys(this.aliasToTopic).length\n return true\n}\n\n/**\n * Get topic by alias\n * @param {String} [topic] - topic\n * @returns {Number} - if mapped topic exists return topic alias, otherwise return undefined\n */\nTopicAliasRecv.prototype.getTopicByAlias = function (alias) {\n return this.aliasToTopic[alias]\n}\n\n/**\n * Clear all entries\n */\nTopicAliasRecv.prototype.clear = function () {\n this.aliasToTopic = {}\n}\n\nmodule.exports = TopicAliasRecv\n","'use strict'\nmodule.exports = function (Yallist) {\n Yallist.prototype[Symbol.iterator] = function* () {\n for (let walker = this.head; walker; walker = walker.next) {\n yield walker.value\n }\n }\n}\n","'use strict'\nmodule.exports = Yallist\n\nYallist.Node = Node\nYallist.create = Yallist\n\nfunction Yallist (list) {\n var self = this\n if (!(self instanceof Yallist)) {\n self = new Yallist()\n }\n\n self.tail = null\n self.head = null\n self.length = 0\n\n if (list && typeof list.forEach === 'function') {\n list.forEach(function (item) {\n self.push(item)\n })\n } else if (arguments.length > 0) {\n for (var i = 0, l = arguments.length; i < l; i++) {\n self.push(arguments[i])\n }\n }\n\n return self\n}\n\nYallist.prototype.removeNode = function (node) {\n if (node.list !== this) {\n throw new Error('removing node which does not belong to this list')\n }\n\n var next = node.next\n var prev = node.prev\n\n if (next) {\n next.prev = prev\n }\n\n if (prev) {\n prev.next = next\n }\n\n if (node === this.head) {\n this.head = next\n }\n if (node === this.tail) {\n this.tail = prev\n }\n\n node.list.length--\n node.next = null\n node.prev = null\n node.list = null\n\n return next\n}\n\nYallist.prototype.unshiftNode = function (node) {\n if (node === this.head) {\n return\n }\n\n if (node.list) {\n node.list.removeNode(node)\n }\n\n var head = this.head\n node.list = this\n node.next = head\n if (head) {\n head.prev = node\n }\n\n this.head = node\n if (!this.tail) {\n this.tail = node\n }\n this.length++\n}\n\nYallist.prototype.pushNode = function (node) {\n if (node === this.tail) {\n return\n }\n\n if (node.list) {\n node.list.removeNode(node)\n }\n\n var tail = this.tail\n node.list = this\n node.prev = tail\n if (tail) {\n tail.next = node\n }\n\n this.tail = node\n if (!this.head) {\n this.head = node\n }\n this.length++\n}\n\nYallist.prototype.push = function () {\n for (var i = 0, l = arguments.length; i < l; i++) {\n push(this, arguments[i])\n }\n return this.length\n}\n\nYallist.prototype.unshift = function () {\n for (var i = 0, l = arguments.length; i < l; i++) {\n unshift(this, arguments[i])\n }\n return this.length\n}\n\nYallist.prototype.pop = function () {\n if (!this.tail) {\n return undefined\n }\n\n var res = this.tail.value\n this.tail = this.tail.prev\n if (this.tail) {\n this.tail.next = null\n } else {\n this.head = null\n }\n this.length--\n return res\n}\n\nYallist.prototype.shift = function () {\n if (!this.head) {\n return undefined\n }\n\n var res = this.head.value\n this.head = this.head.next\n if (this.head) {\n this.head.prev = null\n } else {\n this.tail = null\n }\n this.length--\n return res\n}\n\nYallist.prototype.forEach = function (fn, thisp) {\n thisp = thisp || this\n for (var walker = this.head, i = 0; walker !== null; i++) {\n fn.call(thisp, walker.value, i, this)\n walker = walker.next\n }\n}\n\nYallist.prototype.forEachReverse = function (fn, thisp) {\n thisp = thisp || this\n for (var walker = this.tail, i = this.length - 1; walker !== null; i--) {\n fn.call(thisp, walker.value, i, this)\n walker = walker.prev\n }\n}\n\nYallist.prototype.get = function (n) {\n for (var i = 0, walker = this.head; walker !== null && i < n; i++) {\n // abort out of the list early if we hit a cycle\n walker = walker.next\n }\n if (i === n && walker !== null) {\n return walker.value\n }\n}\n\nYallist.prototype.getReverse = function (n) {\n for (var i = 0, walker = this.tail; walker !== null && i < n; i++) {\n // abort out of the list early if we hit a cycle\n walker = walker.prev\n }\n if (i === n && walker !== null) {\n return walker.value\n }\n}\n\nYallist.prototype.map = function (fn, thisp) {\n thisp = thisp || this\n var res = new Yallist()\n for (var walker = this.head; walker !== null;) {\n res.push(fn.call(thisp, walker.value, this))\n walker = walker.next\n }\n return res\n}\n\nYallist.prototype.mapReverse = function (fn, thisp) {\n thisp = thisp || this\n var res = new Yallist()\n for (var walker = this.tail; walker !== null;) {\n res.push(fn.call(thisp, walker.value, this))\n walker = walker.prev\n }\n return res\n}\n\nYallist.prototype.reduce = function (fn, initial) {\n var acc\n var walker = this.head\n if (arguments.length > 1) {\n acc = initial\n } else if (this.head) {\n walker = this.head.next\n acc = this.head.value\n } else {\n throw new TypeError('Reduce of empty list with no initial value')\n }\n\n for (var i = 0; walker !== null; i++) {\n acc = fn(acc, walker.value, i)\n walker = walker.next\n }\n\n return acc\n}\n\nYallist.prototype.reduceReverse = function (fn, initial) {\n var acc\n var walker = this.tail\n if (arguments.length > 1) {\n acc = initial\n } else if (this.tail) {\n walker = this.tail.prev\n acc = this.tail.value\n } else {\n throw new TypeError('Reduce of empty list with no initial value')\n }\n\n for (var i = this.length - 1; walker !== null; i--) {\n acc = fn(acc, walker.value, i)\n walker = walker.prev\n }\n\n return acc\n}\n\nYallist.prototype.toArray = function () {\n var arr = new Array(this.length)\n for (var i = 0, walker = this.head; walker !== null; i++) {\n arr[i] = walker.value\n walker = walker.next\n }\n return arr\n}\n\nYallist.prototype.toArrayReverse = function () {\n var arr = new Array(this.length)\n for (var i = 0, walker = this.tail; walker !== null; i++) {\n arr[i] = walker.value\n walker = walker.prev\n }\n return arr\n}\n\nYallist.prototype.slice = function (from, to) {\n to = to || this.length\n if (to < 0) {\n to += this.length\n }\n from = from || 0\n if (from < 0) {\n from += this.length\n }\n var ret = new Yallist()\n if (to < from || to < 0) {\n return ret\n }\n if (from < 0) {\n from = 0\n }\n if (to > this.length) {\n to = this.length\n }\n for (var i = 0, walker = this.head; walker !== null && i < from; i++) {\n walker = walker.next\n }\n for (; walker !== null && i < to; i++, walker = walker.next) {\n ret.push(walker.value)\n }\n return ret\n}\n\nYallist.prototype.sliceReverse = function (from, to) {\n to = to || this.length\n if (to < 0) {\n to += this.length\n }\n from = from || 0\n if (from < 0) {\n from += this.length\n }\n var ret = new Yallist()\n if (to < from || to < 0) {\n return ret\n }\n if (from < 0) {\n from = 0\n }\n if (to > this.length) {\n to = this.length\n }\n for (var i = this.length, walker = this.tail; walker !== null && i > to; i--) {\n walker = walker.prev\n }\n for (; walker !== null && i > from; i--, walker = walker.prev) {\n ret.push(walker.value)\n }\n return ret\n}\n\nYallist.prototype.splice = function (start, deleteCount, ...nodes) {\n if (start > this.length) {\n start = this.length - 1\n }\n if (start < 0) {\n start = this.length + start;\n }\n\n for (var i = 0, walker = this.head; walker !== null && i < start; i++) {\n walker = walker.next\n }\n\n var ret = []\n for (var i = 0; walker && i < deleteCount; i++) {\n ret.push(walker.value)\n walker = this.removeNode(walker)\n }\n if (walker === null) {\n walker = this.tail\n }\n\n if (walker !== this.head && walker !== this.tail) {\n walker = walker.prev\n }\n\n for (var i = 0; i < nodes.length; i++) {\n walker = insert(this, walker, nodes[i])\n }\n return ret;\n}\n\nYallist.prototype.reverse = function () {\n var head = this.head\n var tail = this.tail\n for (var walker = head; walker !== null; walker = walker.prev) {\n var p = walker.prev\n walker.prev = walker.next\n walker.next = p\n }\n this.head = tail\n this.tail = head\n return this\n}\n\nfunction insert (self, node, value) {\n var inserted = node === self.head ?\n new Node(value, null, node, self) :\n new Node(value, node, node.next, self)\n\n if (inserted.next === null) {\n self.tail = inserted\n }\n if (inserted.prev === null) {\n self.head = inserted\n }\n\n self.length++\n\n return inserted\n}\n\nfunction push (self, item) {\n self.tail = new Node(item, self.tail, null, self)\n if (!self.head) {\n self.head = self.tail\n }\n self.length++\n}\n\nfunction unshift (self, item) {\n self.head = new Node(item, null, self.head, self)\n if (!self.tail) {\n self.tail = self.head\n }\n self.length++\n}\n\nfunction Node (value, prev, next, list) {\n if (!(this instanceof Node)) {\n return new Node(value, prev, next, list)\n }\n\n this.list = list\n this.value = value\n\n if (prev) {\n prev.next = this\n this.prev = prev\n } else {\n this.prev = null\n }\n\n if (next) {\n next.prev = this\n this.next = next\n } else {\n this.next = null\n }\n}\n\ntry {\n // add if support for Symbol.iterator is present\n require('./iterator.js')(Yallist)\n} catch (er) {}\n","'use strict'\n\n// A linked list to keep track of recently-used-ness\nconst Yallist = require('yallist')\n\nconst MAX = Symbol('max')\nconst LENGTH = Symbol('length')\nconst LENGTH_CALCULATOR = Symbol('lengthCalculator')\nconst ALLOW_STALE = Symbol('allowStale')\nconst MAX_AGE = Symbol('maxAge')\nconst DISPOSE = Symbol('dispose')\nconst NO_DISPOSE_ON_SET = Symbol('noDisposeOnSet')\nconst LRU_LIST = Symbol('lruList')\nconst CACHE = Symbol('cache')\nconst UPDATE_AGE_ON_GET = Symbol('updateAgeOnGet')\n\nconst naiveLength = () => 1\n\n// lruList is a yallist where the head is the youngest\n// item, and the tail is the oldest. the list contains the Hit\n// objects as the entries.\n// Each Hit object has a reference to its Yallist.Node. This\n// never changes.\n//\n// cache is a Map (or PseudoMap) that matches the keys to\n// the Yallist.Node object.\nclass LRUCache {\n constructor (options) {\n if (typeof options === 'number')\n options = { max: options }\n\n if (!options)\n options = {}\n\n if (options.max && (typeof options.max !== 'number' || options.max < 0))\n throw new TypeError('max must be a non-negative number')\n // Kind of weird to have a default max of Infinity, but oh well.\n const max = this[MAX] = options.max || Infinity\n\n const lc = options.length || naiveLength\n this[LENGTH_CALCULATOR] = (typeof lc !== 'function') ? naiveLength : lc\n this[ALLOW_STALE] = options.stale || false\n if (options.maxAge && typeof options.maxAge !== 'number')\n throw new TypeError('maxAge must be a number')\n this[MAX_AGE] = options.maxAge || 0\n this[DISPOSE] = options.dispose\n this[NO_DISPOSE_ON_SET] = options.noDisposeOnSet || false\n this[UPDATE_AGE_ON_GET] = options.updateAgeOnGet || false\n this.reset()\n }\n\n // resize the cache when the max changes.\n set max (mL) {\n if (typeof mL !== 'number' || mL < 0)\n throw new TypeError('max must be a non-negative number')\n\n this[MAX] = mL || Infinity\n trim(this)\n }\n get max () {\n return this[MAX]\n }\n\n set allowStale (allowStale) {\n this[ALLOW_STALE] = !!allowStale\n }\n get allowStale () {\n return this[ALLOW_STALE]\n }\n\n set maxAge (mA) {\n if (typeof mA !== 'number')\n throw new TypeError('maxAge must be a non-negative number')\n\n this[MAX_AGE] = mA\n trim(this)\n }\n get maxAge () {\n return this[MAX_AGE]\n }\n\n // resize the cache when the lengthCalculator changes.\n set lengthCalculator (lC) {\n if (typeof lC !== 'function')\n lC = naiveLength\n\n if (lC !== this[LENGTH_CALCULATOR]) {\n this[LENGTH_CALCULATOR] = lC\n this[LENGTH] = 0\n this[LRU_LIST].forEach(hit => {\n hit.length = this[LENGTH_CALCULATOR](hit.value, hit.key)\n this[LENGTH] += hit.length\n })\n }\n trim(this)\n }\n get lengthCalculator () { return this[LENGTH_CALCULATOR] }\n\n get length () { return this[LENGTH] }\n get itemCount () { return this[LRU_LIST].length }\n\n rforEach (fn, thisp) {\n thisp = thisp || this\n for (let walker = this[LRU_LIST].tail; walker !== null;) {\n const prev = walker.prev\n forEachStep(this, fn, walker, thisp)\n walker = prev\n }\n }\n\n forEach (fn, thisp) {\n thisp = thisp || this\n for (let walker = this[LRU_LIST].head; walker !== null;) {\n const next = walker.next\n forEachStep(this, fn, walker, thisp)\n walker = next\n }\n }\n\n keys () {\n return this[LRU_LIST].toArray().map(k => k.key)\n }\n\n values () {\n return this[LRU_LIST].toArray().map(k => k.value)\n }\n\n reset () {\n if (this[DISPOSE] &&\n this[LRU_LIST] &&\n this[LRU_LIST].length) {\n this[LRU_LIST].forEach(hit => this[DISPOSE](hit.key, hit.value))\n }\n\n this[CACHE] = new Map() // hash of items by key\n this[LRU_LIST] = new Yallist() // list of items in order of use recency\n this[LENGTH] = 0 // length of items in the list\n }\n\n dump () {\n return this[LRU_LIST].map(hit =>\n isStale(this, hit) ? false : {\n k: hit.key,\n v: hit.value,\n e: hit.now + (hit.maxAge || 0)\n }).toArray().filter(h => h)\n }\n\n dumpLru () {\n return this[LRU_LIST]\n }\n\n set (key, value, maxAge) {\n maxAge = maxAge || this[MAX_AGE]\n\n if (maxAge && typeof maxAge !== 'number')\n throw new TypeError('maxAge must be a number')\n\n const now = maxAge ? Date.now() : 0\n const len = this[LENGTH_CALCULATOR](value, key)\n\n if (this[CACHE].has(key)) {\n if (len > this[MAX]) {\n del(this, this[CACHE].get(key))\n return false\n }\n\n const node = this[CACHE].get(key)\n const item = node.value\n\n // dispose of the old one before overwriting\n // split out into 2 ifs for better coverage tracking\n if (this[DISPOSE]) {\n if (!this[NO_DISPOSE_ON_SET])\n this[DISPOSE](key, item.value)\n }\n\n item.now = now\n item.maxAge = maxAge\n item.value = value\n this[LENGTH] += len - item.length\n item.length = len\n this.get(key)\n trim(this)\n return true\n }\n\n const hit = new Entry(key, value, len, now, maxAge)\n\n // oversized objects fall out of cache automatically.\n if (hit.length > this[MAX]) {\n if (this[DISPOSE])\n this[DISPOSE](key, value)\n\n return false\n }\n\n this[LENGTH] += hit.length\n this[LRU_LIST].unshift(hit)\n this[CACHE].set(key, this[LRU_LIST].head)\n trim(this)\n return true\n }\n\n has (key) {\n if (!this[CACHE].has(key)) return false\n const hit = this[CACHE].get(key).value\n return !isStale(this, hit)\n }\n\n get (key) {\n return get(this, key, true)\n }\n\n peek (key) {\n return get(this, key, false)\n }\n\n pop () {\n const node = this[LRU_LIST].tail\n if (!node)\n return null\n\n del(this, node)\n return node.value\n }\n\n del (key) {\n del(this, this[CACHE].get(key))\n }\n\n load (arr) {\n // reset the cache\n this.reset()\n\n const now = Date.now()\n // A previous serialized cache has the most recent items first\n for (let l = arr.length - 1; l >= 0; l--) {\n const hit = arr[l]\n const expiresAt = hit.e || 0\n if (expiresAt === 0)\n // the item was created without expiration in a non aged cache\n this.set(hit.k, hit.v)\n else {\n const maxAge = expiresAt - now\n // dont add already expired items\n if (maxAge > 0) {\n this.set(hit.k, hit.v, maxAge)\n }\n }\n }\n }\n\n prune () {\n this[CACHE].forEach((value, key) => get(this, key, false))\n }\n}\n\nconst get = (self, key, doUse) => {\n const node = self[CACHE].get(key)\n if (node) {\n const hit = node.value\n if (isStale(self, hit)) {\n del(self, node)\n if (!self[ALLOW_STALE])\n return undefined\n } else {\n if (doUse) {\n if (self[UPDATE_AGE_ON_GET])\n node.value.now = Date.now()\n self[LRU_LIST].unshiftNode(node)\n }\n }\n return hit.value\n }\n}\n\nconst isStale = (self, hit) => {\n if (!hit || (!hit.maxAge && !self[MAX_AGE]))\n return false\n\n const diff = Date.now() - hit.now\n return hit.maxAge ? diff > hit.maxAge\n : self[MAX_AGE] && (diff > self[MAX_AGE])\n}\n\nconst trim = self => {\n if (self[LENGTH] > self[MAX]) {\n for (let walker = self[LRU_LIST].tail;\n self[LENGTH] > self[MAX] && walker !== null;) {\n // We know that we're about to delete this one, and also\n // what the next least recently used key will be, so just\n // go ahead and set it now.\n const prev = walker.prev\n del(self, walker)\n walker = prev\n }\n }\n}\n\nconst del = (self, node) => {\n if (node) {\n const hit = node.value\n if (self[DISPOSE])\n self[DISPOSE](hit.key, hit.value)\n\n self[LENGTH] -= hit.length\n self[CACHE].delete(hit.key)\n self[LRU_LIST].removeNode(node)\n }\n}\n\nclass Entry {\n constructor (key, value, length, now, maxAge) {\n this.key = key\n this.value = value\n this.length = length\n this.now = now\n this.maxAge = maxAge || 0\n }\n}\n\nconst forEachStep = (self, fn, node, thisp) => {\n let hit = node.value\n if (isStale(self, hit)) {\n del(self, node)\n if (!self[ALLOW_STALE])\n hit = undefined\n }\n if (hit)\n fn.call(thisp, hit.value, hit.key, self)\n}\n\nmodule.exports = LRUCache\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar ContainerIterator = /** @class */ (function () {\n function ContainerIterator(iteratorType) {\n if (iteratorType === void 0) { iteratorType = ContainerIterator.NORMAL; }\n this.iteratorType = iteratorType;\n }\n ContainerIterator.NORMAL = false;\n ContainerIterator.REVERSE = true;\n return ContainerIterator;\n}());\nexport { ContainerIterator };\nvar Base = /** @class */ (function () {\n function Base() {\n /**\n * @description Container's size.\n * @protected\n */\n this.length = 0;\n }\n /**\n * @return The size of the container.\n */\n Base.prototype.size = function () {\n return this.length;\n };\n /**\n * @return Boolean about if the container is empty.\n */\n Base.prototype.empty = function () {\n return this.length === 0;\n };\n return Base;\n}());\nexport { Base };\nvar Container = /** @class */ (function (_super) {\n __extends(Container, _super);\n function Container() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n return Container;\n}(Base));\nexport { Container };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Base } from \"../ContainerBase/index\";\nvar Stack = /** @class */ (function (_super) {\n __extends(Stack, _super);\n function Stack(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n _this.stack = [];\n container.forEach(function (element) { return _this.push(element); });\n return _this;\n }\n Stack.prototype.clear = function () {\n this.length = 0;\n this.stack.length = 0;\n };\n /**\n * @description Insert element to stack's end.\n */\n Stack.prototype.push = function (element) {\n this.stack.push(element);\n this.length += 1;\n };\n /**\n * @description Removes the end element.\n */\n Stack.prototype.pop = function () {\n this.stack.pop();\n if (this.length > 0)\n this.length -= 1;\n };\n /**\n * @description Accesses the end element.\n */\n Stack.prototype.top = function () {\n return this.stack[this.length - 1];\n };\n return Stack;\n}(Base));\nexport default Stack;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Container } from \"../../ContainerBase/index\";\nvar SequentialContainer = /** @class */ (function (_super) {\n __extends(SequentialContainer, _super);\n function SequentialContainer() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n return SequentialContainer;\n}(Container));\nexport default SequentialContainer;\n","/**\n * @description Check if access is out of bounds.\n * @param pos The position want to access.\n * @param lower The lower bound.\n * @param upper The upper bound.\n * @return Boolean about if access is out of bounds.\n */\nexport function checkWithinAccessParams(pos, lower, upper) {\n if (pos < lower || pos > upper) {\n throw new RangeError();\n }\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { checkWithinAccessParams } from \"../../../utils/checkParams\";\nimport { ContainerIterator } from \"../../ContainerBase/index\";\nvar RandomIterator = /** @class */ (function (_super) {\n __extends(RandomIterator, _super);\n function RandomIterator(index, size, getElementByPos, setElementByPos, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this.node = index;\n _this.size = size;\n _this.getElementByPos = getElementByPos;\n _this.setElementByPos = setElementByPos;\n if (_this.iteratorType === ContainerIterator.NORMAL) {\n _this.pre = function () {\n if (this.node === 0) {\n throw new RangeError('Deque iterator access denied!');\n }\n this.node -= 1;\n return this;\n };\n _this.next = function () {\n if (this.node === this.size()) {\n throw new RangeError('Deque Iterator access denied!');\n }\n this.node += 1;\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this.node === this.size() - 1) {\n throw new RangeError('Deque iterator access denied!');\n }\n this.node += 1;\n return this;\n };\n _this.next = function () {\n if (this.node === -1) {\n throw new RangeError('Deque iterator access denied!');\n }\n this.node -= 1;\n return this;\n };\n }\n return _this;\n }\n Object.defineProperty(RandomIterator.prototype, \"pointer\", {\n get: function () {\n checkWithinAccessParams(this.node, 0, this.size() - 1);\n return this.getElementByPos(this.node);\n },\n set: function (newValue) {\n checkWithinAccessParams(this.node, 0, this.size() - 1);\n this.setElementByPos(this.node, newValue);\n },\n enumerable: false,\n configurable: true\n });\n RandomIterator.prototype.equals = function (obj) {\n return this.node === obj.node;\n };\n return RandomIterator;\n}(ContainerIterator));\nexport { RandomIterator };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nimport SequentialContainer from './Base/index';\nimport { checkWithinAccessParams } from \"../../utils/checkParams\";\nimport { ContainerIterator } from \"../ContainerBase/index\";\nimport { RandomIterator } from \"./Base/RandomIterator\";\nvar DequeIterator = /** @class */ (function (_super) {\n __extends(DequeIterator, _super);\n function DequeIterator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n DequeIterator.prototype.copy = function () {\n return new DequeIterator(this.node, this.size, this.getElementByPos, this.setElementByPos, this.iteratorType);\n };\n return DequeIterator;\n}(RandomIterator));\nexport { DequeIterator };\nvar Deque = /** @class */ (function (_super) {\n __extends(Deque, _super);\n function Deque(container, bucketSize) {\n if (container === void 0) { container = []; }\n if (bucketSize === void 0) { bucketSize = (1 << 12); }\n var _this = _super.call(this) || this;\n _this.first = 0;\n _this.curFirst = 0;\n _this.last = 0;\n _this.curLast = 0;\n _this.bucketNum = 0;\n _this.map = [];\n var _length;\n if ('size' in container) {\n if (typeof container.size === 'number') {\n _length = container.size;\n }\n else {\n _length = container.size();\n }\n }\n else if ('length' in container) {\n _length = container.length;\n }\n else {\n throw new RangeError('Can\\'t get container\\'s size!');\n }\n _this.bucketSize = bucketSize;\n _this.bucketNum = Math.max(Math.ceil(_length / _this.bucketSize), 1);\n for (var i = 0; i < _this.bucketNum; ++i) {\n _this.map.push(new Array(_this.bucketSize));\n }\n var needBucketNum = Math.ceil(_length / _this.bucketSize);\n _this.first = _this.last = (_this.bucketNum >> 1) - (needBucketNum >> 1);\n _this.curFirst = _this.curLast = (_this.bucketSize - _length % _this.bucketSize) >> 1;\n container.forEach(function (element) { return _this.pushBack(element); });\n _this.size = _this.size.bind(_this);\n _this.getElementByPos = _this.getElementByPos.bind(_this);\n _this.setElementByPos = _this.setElementByPos.bind(_this);\n return _this;\n }\n /**\n * @description Growth the Deque.\n * @private\n */\n Deque.prototype.reAllocate = function () {\n var newMap = [];\n var addBucketNum = Math.max(this.bucketNum >> 1, 1);\n for (var i = 0; i < addBucketNum; ++i) {\n newMap[i] = new Array(this.bucketSize);\n }\n for (var i = this.first; i < this.bucketNum; ++i) {\n newMap[newMap.length] = this.map[i];\n }\n for (var i = 0; i < this.last; ++i) {\n newMap[newMap.length] = this.map[i];\n }\n newMap[newMap.length] = __spreadArray([], __read(this.map[this.last]), false);\n this.first = addBucketNum;\n this.last = newMap.length - 1;\n for (var i = 0; i < addBucketNum; ++i) {\n newMap[newMap.length] = new Array(this.bucketSize);\n }\n this.map = newMap;\n this.bucketNum = newMap.length;\n };\n /**\n * @description Get the bucket position of the element and the pointer position by index.\n * @param pos The element's index.\n * @private\n */\n Deque.prototype.getElementIndex = function (pos) {\n var offset = this.curFirst + pos + 1;\n var offsetRemainder = offset % this.bucketSize;\n var curNodePointerIndex = offsetRemainder - 1;\n var curNodeBucketIndex = this.first + (offset - offsetRemainder) / this.bucketSize;\n if (offsetRemainder === 0)\n curNodeBucketIndex -= 1;\n curNodeBucketIndex %= this.bucketNum;\n if (curNodePointerIndex < 0)\n curNodePointerIndex += this.bucketSize;\n return { curNodeBucketIndex: curNodeBucketIndex, curNodePointerIndex: curNodePointerIndex };\n };\n Deque.prototype.clear = function () {\n this.map = [[]];\n this.bucketNum = 1;\n this.first = this.last = this.length = 0;\n this.curFirst = this.curLast = this.bucketSize >> 1;\n };\n Deque.prototype.front = function () {\n return this.map[this.first][this.curFirst];\n };\n Deque.prototype.back = function () {\n return this.map[this.last][this.curLast];\n };\n Deque.prototype.begin = function () {\n return new DequeIterator(0, this.size, this.getElementByPos, this.setElementByPos);\n };\n Deque.prototype.end = function () {\n return new DequeIterator(this.length, this.size, this.getElementByPos, this.setElementByPos);\n };\n Deque.prototype.rBegin = function () {\n return new DequeIterator(this.length - 1, this.size, this.getElementByPos, this.setElementByPos, ContainerIterator.REVERSE);\n };\n Deque.prototype.rEnd = function () {\n return new DequeIterator(-1, this.size, this.getElementByPos, this.setElementByPos, ContainerIterator.REVERSE);\n };\n Deque.prototype.pushBack = function (element) {\n if (this.length) {\n if (this.curLast < this.bucketSize - 1) {\n this.curLast += 1;\n }\n else if (this.last < this.bucketNum - 1) {\n this.last += 1;\n this.curLast = 0;\n }\n else {\n this.last = 0;\n this.curLast = 0;\n }\n if (this.last === this.first &&\n this.curLast === this.curFirst)\n this.reAllocate();\n }\n this.length += 1;\n this.map[this.last][this.curLast] = element;\n };\n Deque.prototype.popBack = function () {\n if (!this.length)\n return;\n this.map[this.last][this.curLast] = undefined;\n if (this.length !== 1) {\n if (this.curLast > 0) {\n this.curLast -= 1;\n }\n else if (this.last > 0) {\n this.last -= 1;\n this.curLast = this.bucketSize - 1;\n }\n else {\n this.last = this.bucketNum - 1;\n this.curLast = this.bucketSize - 1;\n }\n }\n this.length -= 1;\n };\n /**\n * @description Push the element to the front.\n * @param element The element you want to push.\n */\n Deque.prototype.pushFront = function (element) {\n if (this.length) {\n if (this.curFirst > 0) {\n this.curFirst -= 1;\n }\n else if (this.first > 0) {\n this.first -= 1;\n this.curFirst = this.bucketSize - 1;\n }\n else {\n this.first = this.bucketNum - 1;\n this.curFirst = this.bucketSize - 1;\n }\n if (this.first === this.last &&\n this.curFirst === this.curLast)\n this.reAllocate();\n }\n this.length += 1;\n this.map[this.first][this.curFirst] = element;\n };\n /**\n * @description Remove the first element.\n */\n Deque.prototype.popFront = function () {\n if (!this.length)\n return;\n this.map[this.first][this.curFirst] = undefined;\n if (this.length !== 1) {\n if (this.curFirst < this.bucketSize - 1) {\n this.curFirst += 1;\n }\n else if (this.first < this.bucketNum - 1) {\n this.first += 1;\n this.curFirst = 0;\n }\n else {\n this.first = 0;\n this.curFirst = 0;\n }\n }\n this.length -= 1;\n };\n Deque.prototype.forEach = function (callback) {\n for (var i = 0; i < this.length; ++i) {\n callback(this.getElementByPos(i), i);\n }\n };\n Deque.prototype.getElementByPos = function (pos) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n var _a = this.getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n return this.map[curNodeBucketIndex][curNodePointerIndex];\n };\n Deque.prototype.setElementByPos = function (pos, element) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n var _a = this.getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n this.map[curNodeBucketIndex][curNodePointerIndex] = element;\n };\n Deque.prototype.insert = function (pos, element, num) {\n if (num === void 0) { num = 1; }\n checkWithinAccessParams(pos, 0, this.length);\n if (pos === 0) {\n while (num--)\n this.pushFront(element);\n }\n else if (pos === this.length) {\n while (num--)\n this.pushBack(element);\n }\n else {\n var arr = [];\n for (var i = pos; i < this.length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos - 1);\n for (var i = 0; i < num; ++i)\n this.pushBack(element);\n for (var i = 0; i < arr.length; ++i)\n this.pushBack(arr[i]);\n }\n };\n /**\n * @description Remove all elements after the specified position (excluding the specified position).\n * @param pos The previous position of the first removed element.\n * @example deque.cut(1); // Then deque's size will be 2. deque -> [0, 1]\n */\n Deque.prototype.cut = function (pos) {\n if (pos < 0) {\n this.clear();\n return;\n }\n var _a = this.getElementIndex(pos), curNodeBucketIndex = _a.curNodeBucketIndex, curNodePointerIndex = _a.curNodePointerIndex;\n this.last = curNodeBucketIndex;\n this.curLast = curNodePointerIndex;\n this.length = pos + 1;\n };\n Deque.prototype.eraseElementByPos = function (pos) {\n var _this = this;\n checkWithinAccessParams(pos, 0, this.length - 1);\n if (pos === 0)\n this.popFront();\n else if (pos === this.length - 1)\n this.popBack();\n else {\n var arr = [];\n for (var i = pos + 1; i < this.length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n this.cut(pos);\n this.popBack();\n arr.forEach(function (element) { return _this.pushBack(element); });\n }\n };\n Deque.prototype.eraseElementByValue = function (value) {\n if (!this.length)\n return;\n var arr = [];\n for (var i = 0; i < this.length; ++i) {\n var element = this.getElementByPos(i);\n if (element !== value)\n arr.push(element);\n }\n var _length = arr.length;\n for (var i = 0; i < _length; ++i)\n this.setElementByPos(i, arr[i]);\n this.cut(_length - 1);\n };\n Deque.prototype.eraseElementByIterator = function (iter) {\n // @ts-ignore\n var node = iter.node;\n this.eraseElementByPos(node);\n iter = iter.next();\n return iter;\n };\n Deque.prototype.find = function (element) {\n for (var i = 0; i < this.length; ++i) {\n if (this.getElementByPos(i) === element) {\n return new DequeIterator(i, this.size, this.getElementByPos, this.setElementByPos);\n }\n }\n return this.end();\n };\n Deque.prototype.reverse = function () {\n var l = 0;\n var r = this.length - 1;\n while (l < r) {\n var tmp = this.getElementByPos(l);\n this.setElementByPos(l, this.getElementByPos(r));\n this.setElementByPos(r, tmp);\n l += 1;\n r -= 1;\n }\n };\n Deque.prototype.unique = function () {\n if (this.length <= 1)\n return;\n var index = 1;\n var pre = this.getElementByPos(0);\n for (var i = 1; i < this.length; ++i) {\n var cur = this.getElementByPos(i);\n if (cur !== pre) {\n pre = cur;\n this.setElementByPos(index++, cur);\n }\n }\n while (this.length > index)\n this.popBack();\n };\n Deque.prototype.sort = function (cmp) {\n var arr = [];\n for (var i = 0; i < this.length; ++i) {\n arr.push(this.getElementByPos(i));\n }\n arr.sort(cmp);\n for (var i = 0; i < this.length; ++i)\n this.setElementByPos(i, arr[i]);\n };\n /**\n * @description Remove as much useless space as possible.\n */\n Deque.prototype.shrinkToFit = function () {\n if (!this.length)\n return;\n var arr = [];\n this.forEach(function (element) { return arr.push(element); });\n this.bucketNum = Math.max(Math.ceil(this.length / this.bucketSize), 1);\n this.length = this.first = this.last = this.curFirst = this.curLast = 0;\n this.map = [];\n for (var i = 0; i < this.bucketNum; ++i) {\n this.map.push(new Array(this.bucketSize));\n }\n for (var i = 0; i < arr.length; ++i)\n this.pushBack(arr[i]);\n };\n Deque.prototype[Symbol.iterator] = function () {\n return function () {\n var i;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n i = 0;\n _a.label = 1;\n case 1:\n if (!(i < this.length)) return [3 /*break*/, 4];\n return [4 /*yield*/, this.getElementByPos(i)];\n case 2:\n _a.sent();\n _a.label = 3;\n case 3:\n ++i;\n return [3 /*break*/, 1];\n case 4: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return Deque;\n}(SequentialContainer));\nexport default Deque;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport Deque from '../SequentialContainer/Deque';\nimport { Base } from \"../ContainerBase/index\";\nvar Queue = /** @class */ (function (_super) {\n __extends(Queue, _super);\n function Queue(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n _this.queue = new Deque(container);\n _this.length = _this.queue.size();\n return _this;\n }\n Queue.prototype.clear = function () {\n this.queue.clear();\n this.length = 0;\n };\n /**\n * @description Inserts element to queue's end.\n */\n Queue.prototype.push = function (element) {\n this.queue.pushBack(element);\n this.length += 1;\n };\n /**\n * @description Removes the first element.\n */\n Queue.prototype.pop = function () {\n this.queue.popFront();\n if (this.length)\n this.length -= 1;\n };\n /**\n * @description Access the first element.\n */\n Queue.prototype.front = function () {\n return this.queue.front();\n };\n return Queue;\n}(Base));\nexport default Queue;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nimport { Base } from \"../ContainerBase/index\";\nvar PriorityQueue = /** @class */ (function (_super) {\n __extends(PriorityQueue, _super);\n /**\n * @description PriorityQueue's constructor.\n * @param container Initialize container, must have a forEach function.\n * @param cmp Compare function.\n * @param copy When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n */\n function PriorityQueue(container, cmp, copy) {\n var _a;\n if (container === void 0) { container = []; }\n if (cmp === void 0) { cmp = function (x, y) {\n if (x > y)\n return -1;\n if (x < y)\n return 1;\n return 0;\n }; }\n if (copy === void 0) { copy = true; }\n var _this = _super.call(this) || this;\n _this.cmp = cmp;\n if (Array.isArray(container)) {\n _this.priorityQueue = copy ? __spreadArray([], __read(container), false) : container;\n }\n else {\n _this.priorityQueue = [];\n container.forEach(function (element) { return _this.priorityQueue.push(element); });\n }\n _this.length = _this.priorityQueue.length;\n for (var parent_1 = (_this.length - 1) >> 1; parent_1 >= 0; --parent_1) {\n var curParent = parent_1;\n var curChild = (curParent << 1) | 1;\n while (curChild < _this.length) {\n var left = curChild;\n var right = left + 1;\n var minChild = left;\n if (right < _this.length &&\n _this.cmp(_this.priorityQueue[left], _this.priorityQueue[right]) > 0) {\n minChild = right;\n }\n if (_this.cmp(_this.priorityQueue[curParent], _this.priorityQueue[minChild]) <= 0)\n break;\n _a = __read([_this.priorityQueue[minChild], _this.priorityQueue[curParent]], 2), _this.priorityQueue[curParent] = _a[0], _this.priorityQueue[minChild] = _a[1];\n curParent = minChild;\n curChild = (curParent << 1) | 1;\n }\n }\n return _this;\n }\n /**\n * @description Adjusting parent's children to suit the nature of the heap.\n * @param parent Parent's index.\n * @private\n */\n PriorityQueue.prototype.adjust = function (parent) {\n var _a, _b;\n var left = (parent << 1) | 1;\n var right = (parent << 1) + 2;\n if (left < this.length &&\n this.cmp(this.priorityQueue[parent], this.priorityQueue[left]) > 0) {\n _a = __read([this.priorityQueue[left], this.priorityQueue[parent]], 2), this.priorityQueue[parent] = _a[0], this.priorityQueue[left] = _a[1];\n }\n if (right < this.length &&\n this.cmp(this.priorityQueue[parent], this.priorityQueue[right]) > 0) {\n _b = __read([this.priorityQueue[right], this.priorityQueue[parent]], 2), this.priorityQueue[parent] = _b[0], this.priorityQueue[right] = _b[1];\n }\n };\n PriorityQueue.prototype.clear = function () {\n this.length = 0;\n this.priorityQueue.length = 0;\n };\n /**\n * @description Push element into a container in order.\n * @param element The element you want to push.\n */\n PriorityQueue.prototype.push = function (element) {\n this.priorityQueue.push(element);\n this.length += 1;\n if (this.length === 1)\n return;\n var curNode = this.length - 1;\n while (curNode > 0) {\n var parent_2 = (curNode - 1) >> 1;\n if (this.cmp(this.priorityQueue[parent_2], element) <= 0)\n break;\n this.adjust(parent_2);\n curNode = parent_2;\n }\n };\n /**\n * @description Removes the top element.\n */\n PriorityQueue.prototype.pop = function () {\n if (!this.length)\n return;\n var last = this.priorityQueue[this.length - 1];\n this.length -= 1;\n var parent = 0;\n while (parent < this.length) {\n var left = (parent << 1) | 1;\n var right = (parent << 1) + 2;\n if (left >= this.length)\n break;\n var minChild = left;\n if (right < this.length &&\n this.cmp(this.priorityQueue[left], this.priorityQueue[right]) > 0) {\n minChild = right;\n }\n if (this.cmp(this.priorityQueue[minChild], last) >= 0)\n break;\n this.priorityQueue[parent] = this.priorityQueue[minChild];\n parent = minChild;\n }\n this.priorityQueue[parent] = last;\n this.priorityQueue.pop();\n };\n /**\n * @description Accesses the top element.\n */\n PriorityQueue.prototype.top = function () {\n return this.priorityQueue[0];\n };\n return PriorityQueue;\n}(Base));\nexport default PriorityQueue;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport SequentialContainer from './Base/index';\nimport { checkWithinAccessParams } from \"../../utils/checkParams\";\nimport { ContainerIterator } from \"../ContainerBase/index\";\nimport { RandomIterator } from \"./Base/RandomIterator\";\nvar VectorIterator = /** @class */ (function (_super) {\n __extends(VectorIterator, _super);\n function VectorIterator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n VectorIterator.prototype.copy = function () {\n return new VectorIterator(this.node, this.size, this.getElementByPos, this.setElementByPos, this.iteratorType);\n };\n return VectorIterator;\n}(RandomIterator));\nexport { VectorIterator };\nvar Vector = /** @class */ (function (_super) {\n __extends(Vector, _super);\n /**\n * @description Vector's constructor.\n * @param container Initialize container, must have a forEach function.\n * @param copy When the container is an array, you can choose to directly operate on the original object of\n * the array or perform a shallow copy. The default is shallow copy.\n */\n function Vector(container, copy) {\n if (container === void 0) { container = []; }\n if (copy === void 0) { copy = true; }\n var _this = _super.call(this) || this;\n if (Array.isArray(container)) {\n _this.vector = copy ? __spreadArray([], __read(container), false) : container;\n _this.length = container.length;\n }\n else {\n _this.vector = [];\n container.forEach(function (element) { return _this.pushBack(element); });\n }\n _this.size = _this.size.bind(_this);\n _this.getElementByPos = _this.getElementByPos.bind(_this);\n _this.setElementByPos = _this.setElementByPos.bind(_this);\n return _this;\n }\n Vector.prototype.clear = function () {\n this.length = 0;\n this.vector.length = 0;\n };\n Vector.prototype.begin = function () {\n return new VectorIterator(0, this.size, this.getElementByPos, this.setElementByPos);\n };\n Vector.prototype.end = function () {\n return new VectorIterator(this.length, this.size, this.getElementByPos, this.setElementByPos);\n };\n Vector.prototype.rBegin = function () {\n return new VectorIterator(this.length - 1, this.size, this.getElementByPos, this.setElementByPos, ContainerIterator.REVERSE);\n };\n Vector.prototype.rEnd = function () {\n return new VectorIterator(-1, this.size, this.getElementByPos, this.setElementByPos, ContainerIterator.REVERSE);\n };\n Vector.prototype.front = function () {\n return this.vector[0];\n };\n Vector.prototype.back = function () {\n return this.vector[this.length - 1];\n };\n Vector.prototype.forEach = function (callback) {\n for (var i = 0; i < this.length; ++i) {\n callback(this.vector[i], i);\n }\n };\n Vector.prototype.getElementByPos = function (pos) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n return this.vector[pos];\n };\n Vector.prototype.eraseElementByPos = function (pos) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n this.vector.splice(pos, 1);\n this.length -= 1;\n };\n Vector.prototype.eraseElementByValue = function (value) {\n var index = 0;\n for (var i = 0; i < this.length; ++i) {\n if (this.vector[i] !== value) {\n this.vector[index++] = this.vector[i];\n }\n }\n this.length = this.vector.length = index;\n };\n Vector.prototype.eraseElementByIterator = function (iter) {\n // @ts-ignore\n var node = iter.node;\n iter = iter.next();\n this.eraseElementByPos(node);\n return iter;\n };\n Vector.prototype.pushBack = function (element) {\n this.vector.push(element);\n this.length += 1;\n };\n Vector.prototype.popBack = function () {\n if (!this.length)\n return;\n this.vector.pop();\n this.length -= 1;\n };\n Vector.prototype.setElementByPos = function (pos, element) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n this.vector[pos] = element;\n };\n Vector.prototype.insert = function (pos, element, num) {\n var _a;\n if (num === void 0) { num = 1; }\n checkWithinAccessParams(pos, 0, this.length);\n (_a = this.vector).splice.apply(_a, __spreadArray([pos, 0], __read(new Array(num).fill(element)), false));\n this.length += num;\n };\n Vector.prototype.find = function (element) {\n for (var i = 0; i < this.length; ++i) {\n if (this.vector[i] === element) {\n return new VectorIterator(i, this.size, this.getElementByPos, this.getElementByPos);\n }\n }\n return this.end();\n };\n Vector.prototype.reverse = function () {\n this.vector.reverse();\n };\n Vector.prototype.unique = function () {\n var index = 1;\n for (var i = 1; i < this.length; ++i) {\n if (this.vector[i] !== this.vector[i - 1]) {\n this.vector[index++] = this.vector[i];\n }\n }\n this.length = this.vector.length = index;\n };\n Vector.prototype.sort = function (cmp) {\n this.vector.sort(cmp);\n };\n Vector.prototype[Symbol.iterator] = function () {\n return function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [5 /*yield**/, __values(this.vector)];\n case 1: return [2 /*return*/, _a.sent()];\n }\n });\n }.bind(this)();\n };\n return Vector;\n}(SequentialContainer));\nexport default Vector;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nimport SequentialContainer from './Base/index';\nimport { checkWithinAccessParams } from \"../../utils/checkParams\";\nimport { ContainerIterator } from \"../ContainerBase/index\";\nvar LinkNode = /** @class */ (function () {\n function LinkNode(element) {\n this.value = undefined;\n this.pre = undefined;\n this.next = undefined;\n this.value = element;\n }\n return LinkNode;\n}());\nexport { LinkNode };\nvar LinkListIterator = /** @class */ (function (_super) {\n __extends(LinkListIterator, _super);\n function LinkListIterator(node, header, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this.node = node;\n _this.header = header;\n if (_this.iteratorType === ContainerIterator.NORMAL) {\n _this.pre = function () {\n if (this.node.pre === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.pre;\n return this;\n };\n _this.next = function () {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.next;\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this.node.next === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.next;\n return this;\n };\n _this.next = function () {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.pre;\n return this;\n };\n }\n return _this;\n }\n Object.defineProperty(LinkListIterator.prototype, \"pointer\", {\n get: function () {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n return this.node.value;\n },\n set: function (newValue) {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node.value = newValue;\n },\n enumerable: false,\n configurable: true\n });\n LinkListIterator.prototype.equals = function (obj) {\n return this.node === obj.node;\n };\n LinkListIterator.prototype.copy = function () {\n return new LinkListIterator(this.node, this.header, this.iteratorType);\n };\n return LinkListIterator;\n}(ContainerIterator));\nexport { LinkListIterator };\nvar LinkList = /** @class */ (function (_super) {\n __extends(LinkList, _super);\n function LinkList(container) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this) || this;\n _this.header = new LinkNode();\n _this.head = undefined;\n _this.tail = undefined;\n container.forEach(function (element) { return _this.pushBack(element); });\n return _this;\n }\n LinkList.prototype.clear = function () {\n this.length = 0;\n this.head = this.tail = undefined;\n this.header.pre = this.header.next = undefined;\n };\n LinkList.prototype.begin = function () {\n return new LinkListIterator(this.head || this.header, this.header);\n };\n LinkList.prototype.end = function () {\n return new LinkListIterator(this.header, this.header);\n };\n LinkList.prototype.rBegin = function () {\n return new LinkListIterator(this.tail || this.header, this.header, ContainerIterator.REVERSE);\n };\n LinkList.prototype.rEnd = function () {\n return new LinkListIterator(this.header, this.header, ContainerIterator.REVERSE);\n };\n LinkList.prototype.front = function () {\n return this.head ? this.head.value : undefined;\n };\n LinkList.prototype.back = function () {\n return this.tail ? this.tail.value : undefined;\n };\n LinkList.prototype.forEach = function (callback) {\n if (!this.length)\n return;\n var curNode = this.head;\n var index = 0;\n while (curNode !== this.header) {\n callback(curNode.value, index++);\n curNode = curNode.next;\n }\n };\n LinkList.prototype.getElementByPos = function (pos) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n var curNode = this.head;\n while (pos--) {\n curNode = curNode.next;\n }\n return curNode.value;\n };\n LinkList.prototype.eraseElementByPos = function (pos) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n if (pos === 0)\n this.popFront();\n else if (pos === this.length - 1)\n this.popBack();\n else {\n var curNode = this.head;\n while (pos--) {\n curNode = curNode.next;\n }\n curNode = curNode;\n var pre = curNode.pre;\n var next = curNode.next;\n next.pre = pre;\n pre.next = next;\n this.length -= 1;\n }\n };\n LinkList.prototype.eraseElementByValue = function (value) {\n while (this.head && this.head.value === value)\n this.popFront();\n while (this.tail && this.tail.value === value)\n this.popBack();\n if (!this.head)\n return;\n var curNode = this.head;\n while (curNode !== this.header) {\n if (curNode.value === value) {\n var pre = curNode.pre;\n var next = curNode.next;\n if (next)\n next.pre = pre;\n if (pre)\n pre.next = next;\n this.length -= 1;\n }\n curNode = curNode.next;\n }\n };\n LinkList.prototype.eraseElementByIterator = function (iter) {\n // @ts-ignore\n var node = iter.node;\n if (node === this.header) {\n throw new RangeError('Invalid iterator');\n }\n iter = iter.next();\n if (this.head === node)\n this.popFront();\n else if (this.tail === node)\n this.popBack();\n else {\n var pre = node.pre;\n var next = node.next;\n if (next)\n next.pre = pre;\n if (pre)\n pre.next = next;\n this.length -= 1;\n }\n return iter;\n };\n LinkList.prototype.pushBack = function (element) {\n this.length += 1;\n var newTail = new LinkNode(element);\n if (!this.tail) {\n this.head = this.tail = newTail;\n this.header.next = this.head;\n this.head.pre = this.header;\n }\n else {\n this.tail.next = newTail;\n newTail.pre = this.tail;\n this.tail = newTail;\n }\n this.tail.next = this.header;\n this.header.pre = this.tail;\n };\n LinkList.prototype.popBack = function () {\n if (!this.tail)\n return;\n this.length -= 1;\n if (this.head === this.tail) {\n this.head = this.tail = undefined;\n this.header.next = undefined;\n }\n else {\n this.tail = this.tail.pre;\n if (this.tail)\n this.tail.next = undefined;\n }\n this.header.pre = this.tail;\n if (this.tail)\n this.tail.next = this.header;\n };\n LinkList.prototype.setElementByPos = function (pos, element) {\n checkWithinAccessParams(pos, 0, this.length - 1);\n var curNode = this.head;\n while (pos--) {\n curNode = curNode.next;\n }\n curNode.value = element;\n };\n LinkList.prototype.insert = function (pos, element, num) {\n if (num === void 0) { num = 1; }\n checkWithinAccessParams(pos, 0, this.length);\n if (num <= 0)\n return;\n if (pos === 0) {\n while (num--)\n this.pushFront(element);\n }\n else if (pos === this.length) {\n while (num--)\n this.pushBack(element);\n }\n else {\n var curNode = this.head;\n for (var i = 1; i < pos; ++i) {\n curNode = curNode.next;\n }\n var next = curNode.next;\n this.length += num;\n while (num--) {\n curNode.next = new LinkNode(element);\n curNode.next.pre = curNode;\n curNode = curNode.next;\n }\n curNode.next = next;\n if (next)\n next.pre = curNode;\n }\n };\n LinkList.prototype.find = function (element) {\n if (!this.head)\n return this.end();\n var curNode = this.head;\n while (curNode !== this.header) {\n if (curNode.value === element) {\n return new LinkListIterator(curNode, this.header);\n }\n curNode = curNode.next;\n }\n return this.end();\n };\n LinkList.prototype.reverse = function () {\n if (this.length <= 1)\n return;\n var pHead = this.head;\n var pTail = this.tail;\n var cnt = 0;\n while ((cnt << 1) < this.length) {\n var tmp = pHead.value;\n pHead.value = pTail.value;\n pTail.value = tmp;\n pHead = pHead.next;\n pTail = pTail.pre;\n cnt += 1;\n }\n };\n LinkList.prototype.unique = function () {\n if (this.length <= 1)\n return;\n var curNode = this.head;\n while (curNode !== this.header) {\n var tmpNode = curNode;\n while (tmpNode.next && tmpNode.value === tmpNode.next.value) {\n tmpNode = tmpNode.next;\n this.length -= 1;\n }\n curNode.next = tmpNode.next;\n if (curNode.next)\n curNode.next.pre = curNode;\n curNode = curNode.next;\n }\n };\n LinkList.prototype.sort = function (cmp) {\n if (this.length <= 1)\n return;\n var arr = [];\n this.forEach(function (element) { return arr.push(element); });\n arr.sort(cmp);\n var curNode = this.head;\n arr.forEach(function (element) {\n curNode.value = element;\n curNode = curNode.next;\n });\n };\n /**\n * @description Push an element to the front.\n * @param element The element you want to push.\n */\n LinkList.prototype.pushFront = function (element) {\n this.length += 1;\n var newHead = new LinkNode(element);\n if (!this.head) {\n this.head = this.tail = newHead;\n this.tail.next = this.header;\n this.header.pre = this.tail;\n }\n else {\n newHead.next = this.head;\n this.head.pre = newHead;\n this.head = newHead;\n }\n this.header.next = this.head;\n this.head.pre = this.header;\n };\n /**\n * @description Removes the first element.\n */\n LinkList.prototype.popFront = function () {\n if (!this.head)\n return;\n this.length -= 1;\n if (this.head === this.tail) {\n this.head = this.tail = undefined;\n this.header.pre = this.tail;\n }\n else {\n this.head = this.head.next;\n if (this.head)\n this.head.pre = this.header;\n }\n this.header.next = this.head;\n };\n /**\n * @description Merges two sorted lists.\n * @param list The other list you want to merge (must be sorted).\n */\n LinkList.prototype.merge = function (list) {\n var _this = this;\n if (!this.head) {\n list.forEach(function (element) { return _this.pushBack(element); });\n return;\n }\n var curNode = this.head;\n list.forEach(function (element) {\n while (curNode &&\n curNode !== _this.header &&\n curNode.value <= element) {\n curNode = curNode.next;\n }\n if (curNode === _this.header) {\n _this.pushBack(element);\n curNode = _this.tail;\n }\n else if (curNode === _this.head) {\n _this.pushFront(element);\n curNode = _this.head;\n }\n else {\n _this.length += 1;\n var pre = curNode.pre;\n pre.next = new LinkNode(element);\n pre.next.pre = pre;\n pre.next.next = curNode;\n curNode.pre = pre.next;\n }\n });\n };\n LinkList.prototype[Symbol.iterator] = function () {\n return function () {\n var curNode;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (!this.head)\n return [2 /*return*/];\n curNode = this.head;\n _a.label = 1;\n case 1:\n if (!(curNode !== this.header)) return [3 /*break*/, 3];\n return [4 /*yield*/, curNode.value];\n case 2:\n _a.sent();\n curNode = curNode.next;\n return [3 /*break*/, 1];\n case 3: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return LinkList;\n}(SequentialContainer));\nexport default LinkList;\n","var TreeNode = /** @class */ (function () {\n function TreeNode(key, value) {\n this.color = true;\n this.key = undefined;\n this.value = undefined;\n this.left = undefined;\n this.right = undefined;\n this.parent = undefined;\n this.key = key;\n this.value = value;\n }\n /**\n * @description Get the pre node.\n * @return TreeNode about the pre node.\n */\n TreeNode.prototype.pre = function () {\n var preNode = this;\n if (preNode.color === TreeNode.RED &&\n preNode.parent.parent === preNode) {\n preNode = preNode.right;\n }\n else if (preNode.left) {\n preNode = preNode.left;\n while (preNode.right) {\n preNode = preNode.right;\n }\n }\n else {\n var pre = preNode.parent;\n while (pre.left === preNode) {\n preNode = pre;\n pre = preNode.parent;\n }\n preNode = pre;\n }\n return preNode;\n };\n /**\n * @description Get the next node.\n * @return TreeNode about the next node.\n */\n TreeNode.prototype.next = function () {\n var nextNode = this;\n if (nextNode.right) {\n nextNode = nextNode.right;\n while (nextNode.left) {\n nextNode = nextNode.left;\n }\n }\n else {\n var pre = nextNode.parent;\n while (pre.right === nextNode) {\n nextNode = pre;\n pre = nextNode.parent;\n }\n if (nextNode.right !== pre) {\n nextNode = pre;\n }\n }\n return nextNode;\n };\n /**\n * @description Rotate left.\n * @return TreeNode about moved to original position after rotation.\n */\n TreeNode.prototype.rotateLeft = function () {\n var PP = this.parent;\n var V = this.right;\n var R = V.left;\n if (PP.parent === this)\n PP.parent = V;\n else if (PP.left === this)\n PP.left = V;\n else\n PP.right = V;\n V.parent = PP;\n V.left = this;\n this.parent = V;\n this.right = R;\n if (R)\n R.parent = this;\n return V;\n };\n /**\n * @description Rotate left.\n * @return TreeNode about moved to original position after rotation.\n */\n TreeNode.prototype.rotateRight = function () {\n var PP = this.parent;\n var F = this.left;\n var K = F.right;\n if (PP.parent === this)\n PP.parent = F;\n else if (PP.left === this)\n PP.left = F;\n else\n PP.right = F;\n F.parent = PP;\n F.right = this;\n this.parent = F;\n this.left = K;\n if (K)\n K.parent = this;\n return F;\n };\n /**\n * @description Remove this.\n */\n TreeNode.prototype.remove = function () {\n var parent = this.parent;\n if (this === parent.left) {\n parent.left = undefined;\n }\n else\n parent.right = undefined;\n };\n TreeNode.RED = true;\n TreeNode.BLACK = false;\n return TreeNode;\n}());\nexport default TreeNode;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport TreeNode from './TreeNode';\nimport { Container } from \"../../ContainerBase/index\";\nimport { checkWithinAccessParams } from \"../../../utils/checkParams\";\nvar TreeContainer = /** @class */ (function (_super) {\n __extends(TreeContainer, _super);\n function TreeContainer(cmp) {\n if (cmp === void 0) { cmp = function (x, y) {\n if (x < y)\n return -1;\n if (x > y)\n return 1;\n return 0;\n }; }\n var _this = _super.call(this) || this;\n _this.root = undefined;\n _this.header = new TreeNode();\n /**\n * @description InOrder traversal the tree.\n * @protected\n */\n _this.inOrderTraversal = function (curNode, callback) {\n if (curNode === undefined)\n return false;\n var ifReturn = _this.inOrderTraversal(curNode.left, callback);\n if (ifReturn)\n return true;\n if (callback(curNode))\n return true;\n return _this.inOrderTraversal(curNode.right, callback);\n };\n _this.cmp = cmp;\n return _this;\n }\n /**\n * @param curNode The starting node of the search.\n * @param key The key you want to search.\n * @return TreeNode which key is greater than or equals to the given key.\n * @protected\n */\n TreeContainer.prototype._lowerBound = function (curNode, key) {\n var resNode;\n while (curNode) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult < 0) {\n curNode = curNode.right;\n }\n else if (cmpResult > 0) {\n resNode = curNode;\n curNode = curNode.left;\n }\n else\n return curNode;\n }\n return resNode === undefined ? this.header : resNode;\n };\n /**\n * @param curNode The starting node of the search.\n * @param key The key you want to search.\n * @return TreeNode which key is greater than the given key.\n * @protected\n */\n TreeContainer.prototype._upperBound = function (curNode, key) {\n var resNode;\n while (curNode) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult <= 0) {\n curNode = curNode.right;\n }\n else if (cmpResult > 0) {\n resNode = curNode;\n curNode = curNode.left;\n }\n }\n return resNode === undefined ? this.header : resNode;\n };\n /**\n * @param curNode The starting node of the search.\n * @param key The key you want to search.\n * @return TreeNode which key is less than or equals to the given key.\n * @protected\n */\n TreeContainer.prototype._reverseLowerBound = function (curNode, key) {\n var resNode;\n while (curNode) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode.right;\n }\n else if (cmpResult > 0) {\n curNode = curNode.left;\n }\n else\n return curNode;\n }\n return resNode === undefined ? this.header : resNode;\n };\n /**\n * @param curNode The starting node of the search.\n * @param key The key you want to search.\n * @return TreeNode which key is less than the given key.\n * @protected\n */\n TreeContainer.prototype._reverseUpperBound = function (curNode, key) {\n var resNode;\n while (curNode) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult < 0) {\n resNode = curNode;\n curNode = curNode.right;\n }\n else if (cmpResult >= 0) {\n curNode = curNode.left;\n }\n }\n return resNode === undefined ? this.header : resNode;\n };\n /**\n * @description Make self balance after erase a node.\n * @param curNode The node want to remove.\n * @protected\n */\n TreeContainer.prototype.eraseNodeSelfBalance = function (curNode) {\n while (true) {\n var parentNode = curNode.parent;\n if (parentNode === this.header)\n return;\n if (curNode.color === TreeNode.RED) {\n curNode.color = TreeNode.BLACK;\n return;\n }\n if (curNode === parentNode.left) {\n var brother = parentNode.right;\n if (brother.color === TreeNode.RED) {\n brother.color = TreeNode.BLACK;\n parentNode.color = TreeNode.RED;\n if (parentNode === this.root) {\n this.root = parentNode.rotateLeft();\n }\n else\n parentNode.rotateLeft();\n }\n else if (brother.color === TreeNode.BLACK) {\n if (brother.right && brother.right.color === TreeNode.RED) {\n brother.color = parentNode.color;\n parentNode.color = TreeNode.BLACK;\n brother.right.color = TreeNode.BLACK;\n if (parentNode === this.root) {\n this.root = parentNode.rotateLeft();\n }\n else\n parentNode.rotateLeft();\n return;\n }\n else if (brother.left && brother.left.color === TreeNode.RED) {\n brother.color = TreeNode.RED;\n brother.left.color = TreeNode.BLACK;\n brother.rotateRight();\n }\n else {\n brother.color = TreeNode.RED;\n curNode = parentNode;\n }\n }\n }\n else {\n var brother = parentNode.left;\n if (brother.color === TreeNode.RED) {\n brother.color = TreeNode.BLACK;\n parentNode.color = TreeNode.RED;\n if (parentNode === this.root) {\n this.root = parentNode.rotateRight();\n }\n else\n parentNode.rotateRight();\n }\n else {\n if (brother.left && brother.left.color === TreeNode.RED) {\n brother.color = parentNode.color;\n parentNode.color = TreeNode.BLACK;\n brother.left.color = TreeNode.BLACK;\n if (parentNode === this.root) {\n this.root = parentNode.rotateRight();\n }\n else\n parentNode.rotateRight();\n return;\n }\n else if (brother.right && brother.right.color === TreeNode.RED) {\n brother.color = TreeNode.RED;\n brother.right.color = TreeNode.BLACK;\n brother.rotateLeft();\n }\n else {\n brother.color = TreeNode.RED;\n curNode = parentNode;\n }\n }\n }\n }\n };\n /**\n * @description Remove a node.\n * @param curNode The node you want to remove.\n * @protected\n */\n TreeContainer.prototype.eraseNode = function (curNode) {\n var _a, _b;\n if (this.length === 1) {\n this.clear();\n return;\n }\n var swapNode = curNode;\n while (swapNode.left || swapNode.right) {\n if (swapNode.right) {\n swapNode = swapNode.right;\n while (swapNode.left)\n swapNode = swapNode.left;\n }\n else if (swapNode.left) {\n swapNode = swapNode.left;\n }\n _a = __read([swapNode.key, curNode.key], 2), curNode.key = _a[0], swapNode.key = _a[1];\n _b = __read([swapNode.value, curNode.value], 2), curNode.value = _b[0], swapNode.value = _b[1];\n curNode = swapNode;\n }\n if (this.header.left === swapNode) {\n this.header.left = swapNode.parent;\n }\n else if (this.header.right === swapNode) {\n this.header.right = swapNode.parent;\n }\n this.eraseNodeSelfBalance(swapNode);\n swapNode.remove();\n this.length -= 1;\n this.root.color = TreeNode.BLACK;\n };\n /**\n * @description Make self balance after insert a node.\n * @param curNode The node want to insert.\n * @protected\n */\n TreeContainer.prototype.insertNodeSelfBalance = function (curNode) {\n while (true) {\n var parentNode = curNode.parent;\n if (parentNode.color === TreeNode.BLACK)\n return;\n var grandParent = parentNode.parent;\n if (parentNode === grandParent.left) {\n var uncle = grandParent.right;\n if (uncle && uncle.color === TreeNode.RED) {\n uncle.color = parentNode.color = TreeNode.BLACK;\n if (grandParent === this.root)\n return;\n grandParent.color = TreeNode.RED;\n curNode = grandParent;\n continue;\n }\n else if (curNode === parentNode.right) {\n curNode.color = TreeNode.BLACK;\n if (curNode.left)\n curNode.left.parent = parentNode;\n if (curNode.right)\n curNode.right.parent = grandParent;\n parentNode.right = curNode.left;\n grandParent.left = curNode.right;\n curNode.left = parentNode;\n curNode.right = grandParent;\n if (grandParent === this.root) {\n this.root = curNode;\n this.header.parent = curNode;\n }\n else {\n var GP = grandParent.parent;\n if (GP.left === grandParent) {\n GP.left = curNode;\n }\n else\n GP.right = curNode;\n }\n curNode.parent = grandParent.parent;\n parentNode.parent = curNode;\n grandParent.parent = curNode;\n }\n else {\n parentNode.color = TreeNode.BLACK;\n if (grandParent === this.root) {\n this.root = grandParent.rotateRight();\n }\n else\n grandParent.rotateRight();\n }\n grandParent.color = TreeNode.RED;\n }\n else {\n var uncle = grandParent.left;\n if (uncle && uncle.color === TreeNode.RED) {\n uncle.color = parentNode.color = TreeNode.BLACK;\n if (grandParent === this.root)\n return;\n grandParent.color = TreeNode.RED;\n curNode = grandParent;\n continue;\n }\n else if (curNode === parentNode.left) {\n curNode.color = TreeNode.BLACK;\n if (curNode.left)\n curNode.left.parent = grandParent;\n if (curNode.right)\n curNode.right.parent = parentNode;\n grandParent.right = curNode.left;\n parentNode.left = curNode.right;\n curNode.left = grandParent;\n curNode.right = parentNode;\n if (grandParent === this.root) {\n this.root = curNode;\n this.header.parent = curNode;\n }\n else {\n var GP = grandParent.parent;\n if (GP.left === grandParent) {\n GP.left = curNode;\n }\n else\n GP.right = curNode;\n }\n curNode.parent = grandParent.parent;\n parentNode.parent = curNode;\n grandParent.parent = curNode;\n }\n else {\n parentNode.color = TreeNode.BLACK;\n if (grandParent === this.root) {\n this.root = grandParent.rotateLeft();\n }\n else\n grandParent.rotateLeft();\n }\n grandParent.color = TreeNode.RED;\n }\n return;\n }\n };\n /**\n * @description Find node which key is equals to the given key.\n * @param curNode The starting node of the search.\n * @param key The key you want to search.\n * @protected\n */\n TreeContainer.prototype.findElementNode = function (curNode, key) {\n while (curNode) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult < 0) {\n curNode = curNode.right;\n }\n else if (cmpResult > 0) {\n curNode = curNode.left;\n }\n else\n return curNode;\n }\n return curNode;\n };\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key The key want to insert.\n * @param value The value want to set.\n * @param hint You can give an iterator hint to improve insertion efficiency.\n * @protected\n */\n TreeContainer.prototype.set = function (key, value, hint) {\n if (this.root === undefined) {\n this.length += 1;\n this.root = new TreeNode(key, value);\n this.root.color = TreeNode.BLACK;\n this.root.parent = this.header;\n this.header.parent = this.root;\n this.header.left = this.root;\n this.header.right = this.root;\n return;\n }\n var curNode;\n var minNode = this.header.left;\n var compareToMin = this.cmp(minNode.key, key);\n if (compareToMin === 0) {\n minNode.value = value;\n return;\n }\n else if (compareToMin > 0) {\n minNode.left = new TreeNode(key, value);\n minNode.left.parent = minNode;\n curNode = minNode.left;\n this.header.left = curNode;\n }\n else {\n var maxNode = this.header.right;\n var compareToMax = this.cmp(maxNode.key, key);\n if (compareToMax === 0) {\n maxNode.value = value;\n return;\n }\n else if (compareToMax < 0) {\n maxNode.right = new TreeNode(key, value);\n maxNode.right.parent = maxNode;\n curNode = maxNode.right;\n this.header.right = curNode;\n }\n else {\n if (hint !== undefined) {\n // @ts-ignore\n var iterNode = hint.node;\n if (iterNode !== this.header) {\n var iterCmpRes = this.cmp(iterNode.key, key);\n if (iterCmpRes === 0) {\n iterNode.value = value;\n return;\n }\n else if (iterCmpRes > 0) {\n var preNode = iterNode.pre();\n var preCmpRes = this.cmp(preNode.key, key);\n if (preCmpRes === 0) {\n preNode.value = value;\n return;\n }\n else if (preCmpRes < 0) {\n curNode = new TreeNode(key, value);\n if (preNode.right === undefined) {\n preNode.right = curNode;\n curNode.parent = preNode;\n }\n else {\n iterNode.left = curNode;\n curNode.parent = iterNode;\n }\n }\n }\n }\n }\n if (curNode === undefined) {\n curNode = this.root;\n while (true) {\n var cmpResult = this.cmp(curNode.key, key);\n if (cmpResult > 0) {\n if (curNode.left === undefined) {\n curNode.left = new TreeNode(key, value);\n curNode.left.parent = curNode;\n curNode = curNode.left;\n break;\n }\n curNode = curNode.left;\n }\n else if (cmpResult < 0) {\n if (curNode.right === undefined) {\n curNode.right = new TreeNode(key, value);\n curNode.right.parent = curNode;\n curNode = curNode.right;\n break;\n }\n curNode = curNode.right;\n }\n else {\n curNode.value = value;\n return;\n }\n }\n }\n }\n }\n this.length += 1;\n this.insertNodeSelfBalance(curNode);\n };\n TreeContainer.prototype.clear = function () {\n this.length = 0;\n this.root = undefined;\n this.header.parent = undefined;\n this.header.left = this.header.right = undefined;\n };\n /**\n * @description Update node's key by iterator.\n * @param iter The iterator you want to change.\n * @param key The key you want to update.\n * @return Boolean about if the modification is successful.\n */\n TreeContainer.prototype.updateKeyByIterator = function (iter, key) {\n // @ts-ignore\n var node = iter.node;\n if (node === this.header) {\n throw new TypeError('Invalid iterator!');\n }\n if (this.length === 1) {\n node.key = key;\n return true;\n }\n if (node === this.header.left) {\n if (this.cmp(node.next().key, key) > 0) {\n node.key = key;\n return true;\n }\n return false;\n }\n if (node === this.header.right) {\n if (this.cmp(node.pre().key, key) < 0) {\n node.key = key;\n return true;\n }\n return false;\n }\n var preKey = node.pre().key;\n if (this.cmp(preKey, key) >= 0)\n return false;\n var nextKey = node.next().key;\n if (this.cmp(nextKey, key) <= 0)\n return false;\n node.key = key;\n return true;\n };\n TreeContainer.prototype.eraseElementByPos = function (pos) {\n var _this = this;\n checkWithinAccessParams(pos, 0, this.length - 1);\n var index = 0;\n this.inOrderTraversal(this.root, function (curNode) {\n if (pos === index) {\n _this.eraseNode(curNode);\n return true;\n }\n index += 1;\n return false;\n });\n };\n /**\n * @description Remove the element of the specified key.\n * @param key The key you want to remove.\n */\n TreeContainer.prototype.eraseElementByKey = function (key) {\n if (!this.length)\n return;\n var curNode = this.findElementNode(this.root, key);\n if (curNode === undefined)\n return;\n this.eraseNode(curNode);\n };\n TreeContainer.prototype.eraseElementByIterator = function (iter) {\n // @ts-ignore\n var node = iter.node;\n if (node === this.header) {\n throw new RangeError('Invalid iterator');\n }\n if (node.right === undefined) {\n iter = iter.next();\n }\n this.eraseNode(node);\n return iter;\n };\n /**\n * @description Get the height of the tree.\n * @return Number about the height of the RB-tree.\n */\n TreeContainer.prototype.getHeight = function () {\n if (!this.length)\n return 0;\n var traversal = function (curNode) {\n if (!curNode)\n return 0;\n return Math.max(traversal(curNode.left), traversal(curNode.right)) + 1;\n };\n return traversal(this.root);\n };\n return TreeContainer;\n}(Container));\nexport default TreeContainer;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { ContainerIterator } from \"../../ContainerBase/index\";\nvar TreeIterator = /** @class */ (function (_super) {\n __extends(TreeIterator, _super);\n function TreeIterator(node, header, iteratorType) {\n var _this = _super.call(this, iteratorType) || this;\n _this.node = node;\n _this.header = header;\n if (_this.iteratorType === ContainerIterator.NORMAL) {\n _this.pre = function () {\n if (this.node === this.header.left) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.pre();\n return this;\n };\n _this.next = function () {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.next();\n return this;\n };\n }\n else {\n _this.pre = function () {\n if (this.node === this.header.right) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.next();\n return this;\n };\n _this.next = function () {\n if (this.node === this.header) {\n throw new RangeError('LinkList iterator access denied!');\n }\n this.node = this.node.pre();\n return this;\n };\n }\n return _this;\n }\n TreeIterator.prototype.equals = function (obj) {\n return this.node === obj.node;\n };\n return TreeIterator;\n}(ContainerIterator));\nexport default TreeIterator;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport TreeContainer from './Base/index';\nimport { ContainerIterator } from \"../ContainerBase/index\";\nimport { checkWithinAccessParams } from \"../../utils/checkParams\";\nimport TreeIterator from './Base/TreeIterator';\nvar OrderedSetIterator = /** @class */ (function (_super) {\n __extends(OrderedSetIterator, _super);\n function OrderedSetIterator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Object.defineProperty(OrderedSetIterator.prototype, \"pointer\", {\n get: function () {\n if (this.node === this.header) {\n throw new RangeError('OrderedSet iterator access denied!');\n }\n return this.node.key;\n },\n enumerable: false,\n configurable: true\n });\n OrderedSetIterator.prototype.copy = function () {\n return new OrderedSetIterator(this.node, this.header, this.iteratorType);\n };\n return OrderedSetIterator;\n}(TreeIterator));\nexport { OrderedSetIterator };\nvar OrderedSet = /** @class */ (function (_super) {\n __extends(OrderedSet, _super);\n function OrderedSet(container, cmp) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, cmp) || this;\n _this.iterationFunc = function (curNode) {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (curNode === undefined)\n return [2 /*return*/];\n return [5 /*yield**/, __values(this.iterationFunc(curNode.left))];\n case 1:\n _a.sent();\n return [4 /*yield*/, curNode.key];\n case 2:\n _a.sent();\n return [5 /*yield**/, __values(this.iterationFunc(curNode.right))];\n case 3:\n _a.sent();\n return [2 /*return*/];\n }\n });\n };\n container.forEach(function (element) { return _this.insert(element); });\n _this.iterationFunc = _this.iterationFunc.bind(_this);\n return _this;\n }\n OrderedSet.prototype.begin = function () {\n return new OrderedSetIterator(this.header.left || this.header, this.header);\n };\n OrderedSet.prototype.end = function () {\n return new OrderedSetIterator(this.header, this.header);\n };\n OrderedSet.prototype.rBegin = function () {\n return new OrderedSetIterator(this.header.right || this.header, this.header, ContainerIterator.REVERSE);\n };\n OrderedSet.prototype.rEnd = function () {\n return new OrderedSetIterator(this.header, this.header, ContainerIterator.REVERSE);\n };\n OrderedSet.prototype.front = function () {\n return this.header.left ? this.header.left.key : undefined;\n };\n OrderedSet.prototype.back = function () {\n return this.header.right ? this.header.right.key : undefined;\n };\n OrderedSet.prototype.forEach = function (callback) {\n var e_1, _a;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var element = _c.value;\n callback(element, index++);\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n };\n OrderedSet.prototype.getElementByPos = function (pos) {\n var e_2, _a;\n checkWithinAccessParams(pos, 0, this.length - 1);\n var res;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var element = _c.value;\n if (index === pos) {\n res = element;\n }\n index += 1;\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_2) throw e_2.error; }\n }\n return res;\n };\n /**\n * @description Insert element to set.\n * @param key The key want to insert.\n * @param hint You can give an iterator hint to improve insertion efficiency.\n */\n OrderedSet.prototype.insert = function (key, hint) {\n this.set(key, undefined, hint);\n };\n OrderedSet.prototype.find = function (element) {\n var curNode = this.findElementNode(this.root, element);\n if (curNode !== undefined) {\n return new OrderedSetIterator(curNode, this.header);\n }\n return this.end();\n };\n OrderedSet.prototype.lowerBound = function (key) {\n var resNode = this._lowerBound(this.root, key);\n return new OrderedSetIterator(resNode, this.header);\n };\n OrderedSet.prototype.upperBound = function (key) {\n var resNode = this._upperBound(this.root, key);\n return new OrderedSetIterator(resNode, this.header);\n };\n OrderedSet.prototype.reverseLowerBound = function (key) {\n var resNode = this._reverseLowerBound(this.root, key);\n return new OrderedSetIterator(resNode, this.header);\n };\n OrderedSet.prototype.reverseUpperBound = function (key) {\n var resNode = this._reverseUpperBound(this.root, key);\n return new OrderedSetIterator(resNode, this.header);\n };\n OrderedSet.prototype.union = function (other) {\n var _this = this;\n other.forEach(function (element) { return _this.insert(element); });\n };\n OrderedSet.prototype[Symbol.iterator] = function () {\n return this.iterationFunc(this.root);\n };\n return OrderedSet;\n}(TreeContainer));\nexport default OrderedSet;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport { ContainerIterator } from \"../ContainerBase/index\";\nimport { checkWithinAccessParams } from \"../../utils/checkParams\";\nimport TreeContainer from './Base/index';\nimport TreeIterator from './Base/TreeIterator';\nvar OrderedMapIterator = /** @class */ (function (_super) {\n __extends(OrderedMapIterator, _super);\n function OrderedMapIterator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Object.defineProperty(OrderedMapIterator.prototype, \"pointer\", {\n get: function () {\n var _this = this;\n if (this.node === this.header) {\n throw new RangeError('OrderedMap iterator access denied');\n }\n return new Proxy([], {\n get: function (_, props) {\n if (props === '0')\n return _this.node.key;\n else if (props === '1')\n return _this.node.value;\n },\n set: function (_, props, newValue) {\n if (props !== '1') {\n throw new TypeError('props must be 1');\n }\n _this.node.value = newValue;\n return true;\n }\n });\n },\n enumerable: false,\n configurable: true\n });\n OrderedMapIterator.prototype.copy = function () {\n return new OrderedMapIterator(this.node, this.header, this.iteratorType);\n };\n return OrderedMapIterator;\n}(TreeIterator));\nexport { OrderedMapIterator };\nvar OrderedMap = /** @class */ (function (_super) {\n __extends(OrderedMap, _super);\n function OrderedMap(container, cmp) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, cmp) || this;\n _this.iterationFunc = function (curNode) {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (curNode === undefined)\n return [2 /*return*/];\n return [5 /*yield**/, __values(this.iterationFunc(curNode.left))];\n case 1:\n _a.sent();\n return [4 /*yield*/, [curNode.key, curNode.value]];\n case 2:\n _a.sent();\n return [5 /*yield**/, __values(this.iterationFunc(curNode.right))];\n case 3:\n _a.sent();\n return [2 /*return*/];\n }\n });\n };\n _this.iterationFunc = _this.iterationFunc.bind(_this);\n container.forEach(function (_a) {\n var _b = __read(_a, 2), key = _b[0], value = _b[1];\n return _this.setElement(key, value);\n });\n return _this;\n }\n OrderedMap.prototype.begin = function () {\n return new OrderedMapIterator(this.header.left || this.header, this.header);\n };\n OrderedMap.prototype.end = function () {\n return new OrderedMapIterator(this.header, this.header);\n };\n OrderedMap.prototype.rBegin = function () {\n return new OrderedMapIterator(this.header.right || this.header, this.header, ContainerIterator.REVERSE);\n };\n OrderedMap.prototype.rEnd = function () {\n return new OrderedMapIterator(this.header, this.header, ContainerIterator.REVERSE);\n };\n OrderedMap.prototype.front = function () {\n if (!this.length)\n return undefined;\n var minNode = this.header.left;\n return [minNode.key, minNode.value];\n };\n OrderedMap.prototype.back = function () {\n if (!this.length)\n return undefined;\n var maxNode = this.header.right;\n return [maxNode.key, maxNode.value];\n };\n OrderedMap.prototype.forEach = function (callback) {\n var e_1, _a;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var pair = _c.value;\n callback(pair, index++);\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n };\n OrderedMap.prototype.lowerBound = function (key) {\n var resNode = this._lowerBound(this.root, key);\n return new OrderedMapIterator(resNode, this.header);\n };\n OrderedMap.prototype.upperBound = function (key) {\n var resNode = this._upperBound(this.root, key);\n return new OrderedMapIterator(resNode, this.header);\n };\n OrderedMap.prototype.reverseLowerBound = function (key) {\n var resNode = this._reverseLowerBound(this.root, key);\n return new OrderedMapIterator(resNode, this.header);\n };\n OrderedMap.prototype.reverseUpperBound = function (key) {\n var resNode = this._reverseUpperBound(this.root, key);\n return new OrderedMapIterator(resNode, this.header);\n };\n /**\n * @description Insert a key-value pair or set value by the given key.\n * @param key The key want to insert.\n * @param value The value want to set.\n * @param hint You can give an iterator hint to improve insertion efficiency.\n */\n OrderedMap.prototype.setElement = function (key, value, hint) {\n this.set(key, value, hint);\n };\n OrderedMap.prototype.find = function (key) {\n var curNode = this.findElementNode(this.root, key);\n if (curNode !== undefined) {\n return new OrderedMapIterator(curNode, this.header);\n }\n return this.end();\n };\n /**\n * @description Get the value of the element of the specified key.\n */\n OrderedMap.prototype.getElementByKey = function (key) {\n var curNode = this.findElementNode(this.root, key);\n return curNode ? curNode.value : undefined;\n };\n OrderedMap.prototype.getElementByPos = function (pos) {\n var e_2, _a;\n checkWithinAccessParams(pos, 0, this.length - 1);\n var res;\n var index = 0;\n try {\n for (var _b = __values(this), _c = _b.next(); !_c.done; _c = _b.next()) {\n var pair = _c.value;\n if (index === pos) {\n res = pair;\n break;\n }\n index += 1;\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_2) throw e_2.error; }\n }\n return res;\n };\n OrderedMap.prototype.union = function (other) {\n var _this = this;\n other.forEach(function (_a) {\n var _b = __read(_a, 2), key = _b[0], value = _b[1];\n return _this.setElement(key, value);\n });\n };\n OrderedMap.prototype[Symbol.iterator] = function () {\n return this.iterationFunc(this.root);\n };\n return OrderedMap;\n}(TreeContainer));\nexport default OrderedMap;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Base } from \"../../ContainerBase/index\";\nvar HashContainer = /** @class */ (function (_super) {\n __extends(HashContainer, _super);\n function HashContainer(initBucketNum, hashFunc) {\n if (initBucketNum === void 0) { initBucketNum = 16; }\n if (hashFunc === void 0) { hashFunc = function (x) {\n var str;\n if (typeof x !== 'string') {\n str = JSON.stringify(x);\n }\n else\n str = x;\n var hashCode = 0;\n var strLength = str.length;\n for (var i = 0; i < strLength; i++) {\n var ch = str.charCodeAt(i);\n hashCode = ((hashCode << 5) - hashCode) + ch;\n hashCode |= 0;\n }\n return hashCode >>> 0;\n }; }\n var _this = _super.call(this) || this;\n if (initBucketNum < 16 || (initBucketNum & (initBucketNum - 1)) !== 0) {\n throw new RangeError('InitBucketNum range error');\n }\n _this.bucketNum = _this.initBucketNum = initBucketNum;\n _this.hashFunc = hashFunc;\n return _this;\n }\n HashContainer.prototype.clear = function () {\n this.length = 0;\n this.bucketNum = this.initBucketNum;\n this.hashTable = [];\n };\n HashContainer.sigma = 0.75;\n HashContainer.treeifyThreshold = 8;\n HashContainer.untreeifyThreshold = 6;\n HashContainer.minTreeifySize = 64;\n HashContainer.maxBucketNum = (1 << 30);\n return HashContainer;\n}(Base));\nexport default HashContainer;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport HashContainer from './Base/index';\nimport Vector from '../SequentialContainer/Vector';\nimport OrderedSet from '../TreeContainer/OrderedSet';\nvar HashSet = /** @class */ (function (_super) {\n __extends(HashSet, _super);\n function HashSet(container, initBucketNum, hashFunc) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, initBucketNum, hashFunc) || this;\n _this.hashTable = [];\n container.forEach(function (element) { return _this.insert(element); });\n return _this;\n }\n HashSet.prototype.reAllocate = function () {\n var _this = this;\n if (this.bucketNum >= HashContainer.maxBucketNum)\n return;\n var newHashTable = [];\n var originalBucketNum = this.bucketNum;\n this.bucketNum <<= 1;\n var keys = Object.keys(this.hashTable);\n var keyNums = keys.length;\n var _loop_1 = function (i) {\n var index = parseInt(keys[i]);\n var container = this_1.hashTable[index];\n var size = container.size();\n if (size === 0)\n return \"continue\";\n if (size === 1) {\n var element = container.front();\n newHashTable[this_1.hashFunc(element) & (this_1.bucketNum - 1)] = new Vector([element], false);\n return \"continue\";\n }\n var lowList = [];\n var highList = [];\n container.forEach(function (element) {\n var hashCode = _this.hashFunc(element);\n if ((hashCode & originalBucketNum) === 0) {\n lowList.push(element);\n }\n else\n highList.push(element);\n });\n if (container instanceof OrderedSet) {\n if (lowList.length > HashContainer.untreeifyThreshold) {\n newHashTable[index] = new OrderedSet(lowList);\n }\n else if (lowList.length) {\n newHashTable[index] = new Vector(lowList, false);\n }\n if (highList.length > HashContainer.untreeifyThreshold) {\n newHashTable[index + originalBucketNum] = new OrderedSet(highList);\n }\n else if (highList.length) {\n newHashTable[index + originalBucketNum] = new Vector(highList, false);\n }\n }\n else {\n if (lowList.length >= HashContainer.treeifyThreshold) {\n newHashTable[index] = new OrderedSet(lowList);\n }\n else if (lowList.length) {\n newHashTable[index] = new Vector(lowList, false);\n }\n if (highList.length >= HashContainer.treeifyThreshold) {\n newHashTable[index + originalBucketNum] = new OrderedSet(highList);\n }\n else if (highList.length) {\n newHashTable[index + originalBucketNum] = new Vector(highList, false);\n }\n }\n };\n var this_1 = this;\n for (var i = 0; i < keyNums; ++i) {\n _loop_1(i);\n }\n this.hashTable = newHashTable;\n };\n HashSet.prototype.forEach = function (callback) {\n var containers = Object.values(this.hashTable);\n var containersNum = containers.length;\n var index = 0;\n for (var i = 0; i < containersNum; ++i) {\n containers[i].forEach(function (element) { return callback(element, index++); });\n }\n };\n /**\n * @description Insert element to hash set.\n * @param element The element you want to insert.\n */\n HashSet.prototype.insert = function (element) {\n var index = this.hashFunc(element) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container) {\n this.hashTable[index] = new Vector([element], false);\n this.length += 1;\n }\n else {\n var preSize = container.size();\n if (container instanceof Vector) {\n if (!container.find(element)\n .equals(container.end()))\n return;\n container.pushBack(element);\n if (preSize + 1 >= HashContainer.treeifyThreshold) {\n if (this.bucketNum <= HashContainer.minTreeifySize) {\n this.length += 1;\n this.reAllocate();\n return;\n }\n this.hashTable[index] = new OrderedSet(container);\n }\n this.length += 1;\n }\n else {\n container.insert(element);\n var curSize = container.size();\n this.length += curSize - preSize;\n }\n }\n if (this.length > this.bucketNum * HashContainer.sigma) {\n this.reAllocate();\n }\n };\n HashSet.prototype.eraseElementByKey = function (key) {\n var index = this.hashFunc(key) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container)\n return;\n var preSize = container.size();\n if (preSize === 0)\n return;\n if (container instanceof Vector) {\n container.eraseElementByValue(key);\n var curSize = container.size();\n this.length += curSize - preSize;\n }\n else {\n container.eraseElementByKey(key);\n var curSize = container.size();\n this.length += curSize - preSize;\n if (curSize <= HashContainer.untreeifyThreshold) {\n this.hashTable[index] = new Vector(container);\n }\n }\n };\n HashSet.prototype.find = function (element) {\n var index = this.hashFunc(element) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container)\n return false;\n return !container.find(element)\n .equals(container.end());\n };\n HashSet.prototype[Symbol.iterator] = function () {\n return function () {\n var containers, containersNum, i, container, container_1, container_1_1, element, e_1_1;\n var e_1, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n containers = Object.values(this.hashTable);\n containersNum = containers.length;\n i = 0;\n _b.label = 1;\n case 1:\n if (!(i < containersNum)) return [3 /*break*/, 10];\n container = containers[i];\n _b.label = 2;\n case 2:\n _b.trys.push([2, 7, 8, 9]);\n container_1 = (e_1 = void 0, __values(container)), container_1_1 = container_1.next();\n _b.label = 3;\n case 3:\n if (!!container_1_1.done) return [3 /*break*/, 6];\n element = container_1_1.value;\n return [4 /*yield*/, element];\n case 4:\n _b.sent();\n _b.label = 5;\n case 5:\n container_1_1 = container_1.next();\n return [3 /*break*/, 3];\n case 6: return [3 /*break*/, 9];\n case 7:\n e_1_1 = _b.sent();\n e_1 = { error: e_1_1 };\n return [3 /*break*/, 9];\n case 8:\n try {\n if (container_1_1 && !container_1_1.done && (_a = container_1.return)) _a.call(container_1);\n }\n finally { if (e_1) throw e_1.error; }\n return [7 /*endfinally*/];\n case 9:\n ++i;\n return [3 /*break*/, 1];\n case 10: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return HashSet;\n}(HashContainer));\nexport default HashSet;\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport HashContainer from './Base/index';\nimport Vector from '../SequentialContainer/Vector';\nimport OrderedMap from '../TreeContainer/OrderedMap';\nvar HashMap = /** @class */ (function (_super) {\n __extends(HashMap, _super);\n function HashMap(container, initBucketNum, hashFunc) {\n if (container === void 0) { container = []; }\n var _this = _super.call(this, initBucketNum, hashFunc) || this;\n _this.hashTable = [];\n container.forEach(function (element) { return _this.setElement(element[0], element[1]); });\n return _this;\n }\n HashMap.prototype.reAllocate = function () {\n var _this = this;\n if (this.bucketNum >= HashContainer.maxBucketNum)\n return;\n var newHashTable = [];\n var originalBucketNum = this.bucketNum;\n this.bucketNum <<= 1;\n var keys = Object.keys(this.hashTable);\n var keyNums = keys.length;\n var _loop_1 = function (i) {\n var index = parseInt(keys[i]);\n var container = this_1.hashTable[index];\n var size = container.size();\n if (size === 0)\n return \"continue\";\n if (size === 1) {\n var element = container.front();\n newHashTable[this_1.hashFunc(element[0]) & (this_1.bucketNum - 1)] = new Vector([element], false);\n return \"continue\";\n }\n var lowList = [];\n var highList = [];\n container.forEach(function (element) {\n var hashCode = _this.hashFunc(element[0]);\n if ((hashCode & originalBucketNum) === 0) {\n lowList.push(element);\n }\n else\n highList.push(element);\n });\n if (container instanceof OrderedMap) {\n if (lowList.length > HashContainer.untreeifyThreshold) {\n newHashTable[index] = new OrderedMap(lowList);\n }\n else if (lowList.length) {\n newHashTable[index] = new Vector(lowList, false);\n }\n if (highList.length > HashContainer.untreeifyThreshold) {\n newHashTable[index + originalBucketNum] = new OrderedMap(highList);\n }\n else if (highList.length) {\n newHashTable[index + originalBucketNum] = new Vector(highList, false);\n }\n }\n else {\n if (lowList.length >= HashContainer.treeifyThreshold) {\n newHashTable[index] = new OrderedMap(lowList);\n }\n else if (lowList.length) {\n newHashTable[index] = new Vector(lowList, false);\n }\n if (highList.length >= HashContainer.treeifyThreshold) {\n newHashTable[index + originalBucketNum] = new OrderedMap(highList);\n }\n else if (highList.length) {\n newHashTable[index + originalBucketNum] = new Vector(highList, false);\n }\n }\n };\n var this_1 = this;\n for (var i = 0; i < keyNums; ++i) {\n _loop_1(i);\n }\n this.hashTable = newHashTable;\n };\n HashMap.prototype.forEach = function (callback) {\n var containers = Object.values(this.hashTable);\n var containersNum = containers.length;\n var index = 0;\n for (var i = 0; i < containersNum; ++i) {\n containers[i].forEach(function (element) { return callback(element, index++); });\n }\n };\n /**\n * @description Insert a new key-value pair to hash map or set value by key.\n * @param key The key you want to insert.\n * @param value The value you want to insert.\n * @example HashMap.setElement(1, 2); // insert a key-value pair [1, 2]\n */\n HashMap.prototype.setElement = function (key, value) {\n var e_1, _a;\n var index = this.hashFunc(key) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container) {\n this.length += 1;\n this.hashTable[index] = new Vector([[key, value]], false);\n }\n else {\n var preSize = container.size();\n if (container instanceof Vector) {\n try {\n for (var container_1 = __values(container), container_1_1 = container_1.next(); !container_1_1.done; container_1_1 = container_1.next()) {\n var pair = container_1_1.value;\n if (pair[0] === key) {\n pair[1] = value;\n return;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (container_1_1 && !container_1_1.done && (_a = container_1.return)) _a.call(container_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n container.pushBack([key, value]);\n if (preSize + 1 >= HashMap.treeifyThreshold) {\n if (this.bucketNum <= HashMap.minTreeifySize) {\n this.length += 1;\n this.reAllocate();\n return;\n }\n this.hashTable[index] = new OrderedMap(this.hashTable[index]);\n }\n this.length += 1;\n }\n else {\n container.setElement(key, value);\n var curSize = container.size();\n this.length += curSize - preSize;\n }\n }\n if (this.length > this.bucketNum * HashMap.sigma) {\n this.reAllocate();\n }\n };\n /**\n * @description Get the value of the element which has the specified key.\n * @param key The key you want to get.\n */\n HashMap.prototype.getElementByKey = function (key) {\n var e_2, _a;\n var index = this.hashFunc(key) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container)\n return undefined;\n if (container instanceof OrderedMap) {\n return container.getElementByKey(key);\n }\n else {\n try {\n for (var container_2 = __values(container), container_2_1 = container_2.next(); !container_2_1.done; container_2_1 = container_2.next()) {\n var pair = container_2_1.value;\n if (pair[0] === key)\n return pair[1];\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (container_2_1 && !container_2_1.done && (_a = container_2.return)) _a.call(container_2);\n }\n finally { if (e_2) throw e_2.error; }\n }\n return undefined;\n }\n };\n HashMap.prototype.eraseElementByKey = function (key) {\n var e_3, _a;\n var index = this.hashFunc(key) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container)\n return;\n if (container instanceof Vector) {\n var pos = 0;\n try {\n for (var container_3 = __values(container), container_3_1 = container_3.next(); !container_3_1.done; container_3_1 = container_3.next()) {\n var pair = container_3_1.value;\n if (pair[0] === key) {\n container.eraseElementByPos(pos);\n this.length -= 1;\n return;\n }\n pos += 1;\n }\n }\n catch (e_3_1) { e_3 = { error: e_3_1 }; }\n finally {\n try {\n if (container_3_1 && !container_3_1.done && (_a = container_3.return)) _a.call(container_3);\n }\n finally { if (e_3) throw e_3.error; }\n }\n }\n else {\n var preSize = container.size();\n container.eraseElementByKey(key);\n var curSize = container.size();\n this.length += curSize - preSize;\n if (curSize <= HashContainer.untreeifyThreshold) {\n this.hashTable[index] = new Vector(container);\n }\n }\n };\n HashMap.prototype.find = function (key) {\n var e_4, _a;\n var index = this.hashFunc(key) & (this.bucketNum - 1);\n var container = this.hashTable[index];\n if (!container)\n return false;\n if (container instanceof OrderedMap) {\n return !container.find(key)\n .equals(container.end());\n }\n try {\n for (var container_4 = __values(container), container_4_1 = container_4.next(); !container_4_1.done; container_4_1 = container_4.next()) {\n var pair = container_4_1.value;\n if (pair[0] === key)\n return true;\n }\n }\n catch (e_4_1) { e_4 = { error: e_4_1 }; }\n finally {\n try {\n if (container_4_1 && !container_4_1.done && (_a = container_4.return)) _a.call(container_4);\n }\n finally { if (e_4) throw e_4.error; }\n }\n return false;\n };\n HashMap.prototype[Symbol.iterator] = function () {\n return function () {\n var containers, containersNum, i, container, container_5, container_5_1, element, e_5_1;\n var e_5, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n containers = Object.values(this.hashTable);\n containersNum = containers.length;\n i = 0;\n _b.label = 1;\n case 1:\n if (!(i < containersNum)) return [3 /*break*/, 10];\n container = containers[i];\n _b.label = 2;\n case 2:\n _b.trys.push([2, 7, 8, 9]);\n container_5 = (e_5 = void 0, __values(container)), container_5_1 = container_5.next();\n _b.label = 3;\n case 3:\n if (!!container_5_1.done) return [3 /*break*/, 6];\n element = container_5_1.value;\n return [4 /*yield*/, element];\n case 4:\n _b.sent();\n _b.label = 5;\n case 5:\n container_5_1 = container_5.next();\n return [3 /*break*/, 3];\n case 6: return [3 /*break*/, 9];\n case 7:\n e_5_1 = _b.sent();\n e_5 = { error: e_5_1 };\n return [3 /*break*/, 9];\n case 8:\n try {\n if (container_5_1 && !container_5_1.done && (_a = container_5.return)) _a.call(container_5);\n }\n finally { if (e_5) throw e_5.error; }\n return [7 /*endfinally*/];\n case 9:\n ++i;\n return [3 /*break*/, 1];\n case 10: return [2 /*return*/];\n }\n });\n }.bind(this)();\n };\n return HashMap;\n}(HashContainer));\nexport default HashMap;\n","export { default as Stack } from \"./container/OtherContainer/Stack\";\nexport { default as Queue } from \"./container/OtherContainer/Queue\";\nexport { default as PriorityQueue } from \"./container/OtherContainer/PriorityQueue\";\nexport { default as Vector, VectorIterator } from \"./container/SequentialContainer/Vector\";\nexport { default as LinkList, LinkListIterator } from \"./container/SequentialContainer/LinkList\";\nexport { default as Deque, DequeIterator } from \"./container/SequentialContainer/Deque\";\nexport { default as OrderedSet, OrderedSetIterator } from \"./container/TreeContainer/OrderedSet\";\nexport { default as OrderedMap, OrderedMapIterator } from \"./container/TreeContainer/OrderedMap\";\nexport { default as HashSet } from \"./container/HashContainer/HashSet\";\nexport { default as HashMap } from \"./container/HashContainer/HashMap\";\nexport { Container, ContainerIterator } from \"./container/ContainerBase/index\";\nexport { default as SequentialContainer } from \"./container/SequentialContainer/Base/index\";\nexport { default as TreeContainer } from \"./container/TreeContainer/Base/index\";\nexport { default as HashContainer } from \"./container/HashContainer/Base/index\";\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.slice(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","'use strict';\n\nmodule.exports = (flag, argv = process.argv) => {\n\tconst prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--');\n\tconst position = argv.indexOf(prefix + flag);\n\tconst terminatorPosition = argv.indexOf('--');\n\treturn position !== -1 && (terminatorPosition === -1 || position < terminatorPosition);\n};\n","'use strict';\nconst os = require('os');\nconst tty = require('tty');\nconst hasFlag = require('has-flag');\n\nconst {env} = process;\n\nlet forceColor;\nif (hasFlag('no-color') ||\n\thasFlag('no-colors') ||\n\thasFlag('color=false') ||\n\thasFlag('color=never')) {\n\tforceColor = 0;\n} else if (hasFlag('color') ||\n\thasFlag('colors') ||\n\thasFlag('color=true') ||\n\thasFlag('color=always')) {\n\tforceColor = 1;\n}\n\nif ('FORCE_COLOR' in env) {\n\tif (env.FORCE_COLOR === 'true') {\n\t\tforceColor = 1;\n\t} else if (env.FORCE_COLOR === 'false') {\n\t\tforceColor = 0;\n\t} else {\n\t\tforceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3);\n\t}\n}\n\nfunction translateLevel(level) {\n\tif (level === 0) {\n\t\treturn false;\n\t}\n\n\treturn {\n\t\tlevel,\n\t\thasBasic: true,\n\t\thas256: level >= 2,\n\t\thas16m: level >= 3\n\t};\n}\n\nfunction supportsColor(haveStream, streamIsTTY) {\n\tif (forceColor === 0) {\n\t\treturn 0;\n\t}\n\n\tif (hasFlag('color=16m') ||\n\t\thasFlag('color=full') ||\n\t\thasFlag('color=truecolor')) {\n\t\treturn 3;\n\t}\n\n\tif (hasFlag('color=256')) {\n\t\treturn 2;\n\t}\n\n\tif (haveStream && !streamIsTTY && forceColor === undefined) {\n\t\treturn 0;\n\t}\n\n\tconst min = forceColor || 0;\n\n\tif (env.TERM === 'dumb') {\n\t\treturn min;\n\t}\n\n\tif (process.platform === 'win32') {\n\t\t// Windows 10 build 10586 is the first Windows release that supports 256 colors.\n\t\t// Windows 10 build 14931 is the first release that supports 16m/TrueColor.\n\t\tconst osRelease = os.release().split('.');\n\t\tif (\n\t\t\tNumber(osRelease[0]) >= 10 &&\n\t\t\tNumber(osRelease[2]) >= 10586\n\t\t) {\n\t\t\treturn Number(osRelease[2]) >= 14931 ? 3 : 2;\n\t\t}\n\n\t\treturn 1;\n\t}\n\n\tif ('CI' in env) {\n\t\tif (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') {\n\t\t\treturn 1;\n\t\t}\n\n\t\treturn min;\n\t}\n\n\tif ('TEAMCITY_VERSION' in env) {\n\t\treturn /^(9\\.(0*[1-9]\\d*)\\.|\\d{2,}\\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;\n\t}\n\n\tif (env.COLORTERM === 'truecolor') {\n\t\treturn 3;\n\t}\n\n\tif ('TERM_PROGRAM' in env) {\n\t\tconst version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);\n\n\t\tswitch (env.TERM_PROGRAM) {\n\t\t\tcase 'iTerm.app':\n\t\t\t\treturn version >= 3 ? 3 : 2;\n\t\t\tcase 'Apple_Terminal':\n\t\t\t\treturn 2;\n\t\t\t// No default\n\t\t}\n\t}\n\n\tif (/-256(color)?$/i.test(env.TERM)) {\n\t\treturn 2;\n\t}\n\n\tif (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {\n\t\treturn 1;\n\t}\n\n\tif ('COLORTERM' in env) {\n\t\treturn 1;\n\t}\n\n\treturn min;\n}\n\nfunction getSupportLevel(stream) {\n\tconst level = supportsColor(stream, stream && stream.isTTY);\n\treturn translateLevel(level);\n}\n\nmodule.exports = {\n\tsupportsColor: getSupportLevel,\n\tstdout: translateLevel(supportsColor(true, tty.isatty(1))),\n\tstderr: translateLevel(supportsColor(true, tty.isatty(2)))\n};\n","/**\n * Module dependencies.\n */\n\nconst tty = require('tty');\nconst util = require('util');\n\n/**\n * This is the Node.js implementation of `debug()`.\n */\n\nexports.init = init;\nexports.log = log;\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.destroy = util.deprecate(\n\t() => {},\n\t'Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.'\n);\n\n/**\n * Colors.\n */\n\nexports.colors = [6, 2, 3, 4, 5, 1];\n\ntry {\n\t// Optional dependency (as in, doesn't need to be installed, NOT like optionalDependencies in package.json)\n\t// eslint-disable-next-line import/no-extraneous-dependencies\n\tconst supportsColor = require('supports-color');\n\n\tif (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) {\n\t\texports.colors = [\n\t\t\t20,\n\t\t\t21,\n\t\t\t26,\n\t\t\t27,\n\t\t\t32,\n\t\t\t33,\n\t\t\t38,\n\t\t\t39,\n\t\t\t40,\n\t\t\t41,\n\t\t\t42,\n\t\t\t43,\n\t\t\t44,\n\t\t\t45,\n\t\t\t56,\n\t\t\t57,\n\t\t\t62,\n\t\t\t63,\n\t\t\t68,\n\t\t\t69,\n\t\t\t74,\n\t\t\t75,\n\t\t\t76,\n\t\t\t77,\n\t\t\t78,\n\t\t\t79,\n\t\t\t80,\n\t\t\t81,\n\t\t\t92,\n\t\t\t93,\n\t\t\t98,\n\t\t\t99,\n\t\t\t112,\n\t\t\t113,\n\t\t\t128,\n\t\t\t129,\n\t\t\t134,\n\t\t\t135,\n\t\t\t148,\n\t\t\t149,\n\t\t\t160,\n\t\t\t161,\n\t\t\t162,\n\t\t\t163,\n\t\t\t164,\n\t\t\t165,\n\t\t\t166,\n\t\t\t167,\n\t\t\t168,\n\t\t\t169,\n\t\t\t170,\n\t\t\t171,\n\t\t\t172,\n\t\t\t173,\n\t\t\t178,\n\t\t\t179,\n\t\t\t184,\n\t\t\t185,\n\t\t\t196,\n\t\t\t197,\n\t\t\t198,\n\t\t\t199,\n\t\t\t200,\n\t\t\t201,\n\t\t\t202,\n\t\t\t203,\n\t\t\t204,\n\t\t\t205,\n\t\t\t206,\n\t\t\t207,\n\t\t\t208,\n\t\t\t209,\n\t\t\t214,\n\t\t\t215,\n\t\t\t220,\n\t\t\t221\n\t\t];\n\t}\n} catch (error) {\n\t// Swallow - we only care if `supports-color` is available; it doesn't have to be.\n}\n\n/**\n * Build up the default `inspectOpts` object from the environment variables.\n *\n * $ DEBUG_COLORS=no DEBUG_DEPTH=10 DEBUG_SHOW_HIDDEN=enabled node script.js\n */\n\nexports.inspectOpts = Object.keys(process.env).filter(key => {\n\treturn /^debug_/i.test(key);\n}).reduce((obj, key) => {\n\t// Camel-case\n\tconst prop = key\n\t\t.substring(6)\n\t\t.toLowerCase()\n\t\t.replace(/_([a-z])/g, (_, k) => {\n\t\t\treturn k.toUpperCase();\n\t\t});\n\n\t// Coerce string value into JS value\n\tlet val = process.env[key];\n\tif (/^(yes|on|true|enabled)$/i.test(val)) {\n\t\tval = true;\n\t} else if (/^(no|off|false|disabled)$/i.test(val)) {\n\t\tval = false;\n\t} else if (val === 'null') {\n\t\tval = null;\n\t} else {\n\t\tval = Number(val);\n\t}\n\n\tobj[prop] = val;\n\treturn obj;\n}, {});\n\n/**\n * Is stdout a TTY? Colored output is enabled when `true`.\n */\n\nfunction useColors() {\n\treturn 'colors' in exports.inspectOpts ?\n\t\tBoolean(exports.inspectOpts.colors) :\n\t\ttty.isatty(process.stderr.fd);\n}\n\n/**\n * Adds ANSI color escape codes if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\tconst {namespace: name, useColors} = this;\n\n\tif (useColors) {\n\t\tconst c = this.color;\n\t\tconst colorCode = '\\u001B[3' + (c < 8 ? c : '8;5;' + c);\n\t\tconst prefix = ` ${colorCode};1m${name} \\u001B[0m`;\n\n\t\targs[0] = prefix + args[0].split('\\n').join('\\n' + prefix);\n\t\targs.push(colorCode + 'm+' + module.exports.humanize(this.diff) + '\\u001B[0m');\n\t} else {\n\t\targs[0] = getDate() + name + ' ' + args[0];\n\t}\n}\n\nfunction getDate() {\n\tif (exports.inspectOpts.hideDate) {\n\t\treturn '';\n\t}\n\treturn new Date().toISOString() + ' ';\n}\n\n/**\n * Invokes `util.formatWithOptions()` with the specified arguments and writes to stderr.\n */\n\nfunction log(...args) {\n\treturn process.stderr.write(util.formatWithOptions(exports.inspectOpts, ...args) + '\\n');\n}\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\tif (namespaces) {\n\t\tprocess.env.DEBUG = namespaces;\n\t} else {\n\t\t// If you set a process.env field to null or undefined, it gets cast to the\n\t\t// string 'null' or 'undefined'. Just delete instead.\n\t\tdelete process.env.DEBUG;\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\n\nfunction load() {\n\treturn process.env.DEBUG;\n}\n\n/**\n * Init logic for `debug` instances.\n *\n * Create a new `inspectOpts` object in case `useColors` is set\n * differently for a particular `debug` instance.\n */\n\nfunction init(debug) {\n\tdebug.inspectOpts = {};\n\n\tconst keys = Object.keys(exports.inspectOpts);\n\tfor (let i = 0; i < keys.length; i++) {\n\t\tdebug.inspectOpts[keys[i]] = exports.inspectOpts[keys[i]];\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %o to `util.inspect()`, all on a single line.\n */\n\nformatters.o = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts)\n\t\t.split('\\n')\n\t\t.map(str => str.trim())\n\t\t.join(' ');\n};\n\n/**\n * Map %O to `util.inspect()`, allowing multiple lines if needed.\n */\n\nformatters.O = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts);\n};\n","/**\n * Detect Electron renderer / nwjs process, which is node, but we should\n * treat as a browser.\n */\n\nif (typeof process === 'undefined' || process.type === 'renderer' || process.browser === true || process.__nwjs) {\n\tmodule.exports = require('./browser.js');\n} else {\n\tmodule.exports = require('./node.js');\n}\n","// Copyright Takatoshi Kondo 2021\n//\n// Distributed under the MIT License\n\n'use strict'\n\nconst SortedSet = require('js-sdsl').OrderedSet\nconst debugTrace = require('debug')('number-allocator:trace')\nconst debugError = require('debug')('number-allocator:error')\n/**\n * Interval constructor\n * @constructor\n * @param {Number} low - The lowest value of the interval\n * @param {Number} high - The highest value of the interval\n */\nfunction Interval (low, high) {\n this.low = low\n this.high = high\n}\n\nInterval.prototype.equals = function (other) {\n return this.low === other.low && this.high === other.high\n}\n\nInterval.prototype.compare = function (other) {\n if (this.low < other.low && this.high < other.low) return -1\n if (other.low < this.low && other.high < this.low) return 1\n return 0\n}\n\n/**\n * NumberAllocator constructor.\n * The all numbers are set to vacant status.\n * Time Complexity O(1)\n * @constructor\n * @param {Number} min - The maximum number of allocatable. The number must be integer.\n * @param {Number} maxh - The minimum number of allocatable. The number must be integer.\n */\nfunction NumberAllocator (min, max) {\n if (!(this instanceof NumberAllocator)) {\n return new NumberAllocator(min, max)\n }\n\n this.min = min\n this.max = max\n\n this.ss = new SortedSet(\n [],\n (lhs, rhs) => {\n return lhs.compare(rhs)\n }\n )\n debugTrace('Create')\n this.clear()\n}\n\n/**\n * Get the first vacant number. The status of the number is not updated.\n * Time Complexity O(1)\n * @return {Number} - The first vacant number. If all numbers are occupied, return null.\n * When alloc() is called then the same value will be allocated.\n */\nNumberAllocator.prototype.firstVacant = function () {\n if (this.ss.size() === 0) return null\n return this.ss.front().low\n}\n\n/**\n * Allocate the first vacant number. The number become occupied status.\n * Time Complexity O(1)\n * @return {Number} - The first vacant number. If all numbers are occupied, return null.\n */\nNumberAllocator.prototype.alloc = function () {\n if (this.ss.size() === 0) {\n debugTrace('alloc():empty')\n return null\n }\n const it = this.ss.begin()\n const low = it.pointer.low\n const high = it.pointer.high\n const num = low\n if (num + 1 <= high) {\n // x|----|\n this.ss.updateKeyByIterator(it, new Interval(low + 1, high))\n } else {\n this.ss.eraseElementByPos(0)\n }\n debugTrace('alloc():' + num)\n return num\n}\n\n/**\n * Use the number. The number become occupied status.\n * If the number has already been occupied, then return false.\n * Time Complexity O(logN) : N is the number of intervals (not numbers)\n * @param {Number} num - The number to request use.\n * @return {Boolean} - If `num` was not occupied, then return true, otherwise return false.\n */\nNumberAllocator.prototype.use = function (num) {\n const key = new Interval(num, num)\n const it = this.ss.lowerBound(key)\n if (!it.equals(this.ss.end())) {\n const low = it.pointer.low\n const high = it.pointer.high\n if (it.pointer.equals(key)) {\n // |x|\n this.ss.eraseElementByIterator(it)\n debugTrace('use():' + num)\n return true\n }\n\n // x |-----|\n if (low > num) return false\n\n // |x----|\n if (low === num) {\n // x|----|\n this.ss.updateKeyByIterator(it, new Interval(low + 1, high))\n debugTrace('use():' + num)\n return true\n }\n\n // |----x|\n if (high === num) {\n // |----|x\n this.ss.updateKeyByIterator(it, new Interval(low, high - 1))\n debugTrace('use():' + num)\n return true\n }\n\n // |--x--|\n // x|--|\n this.ss.updateKeyByIterator(it, new Interval(num + 1, high))\n // |--|x|--|\n this.ss.insert(new Interval(low, num - 1))\n debugTrace('use():' + num)\n return true\n }\n\n debugTrace('use():failed')\n return false\n}\n\n/**\n * Deallocate the number. The number become vacant status.\n * Time Complexity O(logN) : N is the number of intervals (not numbers)\n * @param {Number} num - The number to deallocate. The number must be occupied status.\n * In other words, the number must be allocated by alloc() or occupied be use().\n */\nNumberAllocator.prototype.free = function (num) {\n if (num < this.min || num > this.max) {\n debugError('free():' + num + ' is out of range')\n return\n }\n const key = new Interval(num, num)\n const it = this.ss.upperBound(key)\n if (it.equals(this.ss.end())) {\n // ....v\n if (it.equals(this.ss.begin())) {\n // Insert new interval\n this.ss.insert(key)\n return\n }\n it.pre()\n const low = it.pointer.high\n const high = it.pointer.high\n if (high + 1 === num) {\n // Concat to left\n this.ss.updateKeyByIterator(it, new Interval(low, num))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n } else {\n if (it.equals(this.ss.begin())) {\n // v....\n if (num + 1 === it.pointer.low) {\n // Concat to right\n const low = it.pointer.high - 1\n const high = it.pointer.high\n this.ss.updateKeyByIterator(it, new Interval(low, high))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n } else {\n // ..v..\n const rLow = it.pointer.low\n const rHigh = it.pointer.high\n it.pre()\n const lLow = it.pointer.low\n const lHigh = it.pointer.high\n if (lHigh + 1 === num) {\n if (num + 1 === rLow) {\n // Concat to left and right\n this.ss.eraseElementByIterator(it)\n const high = it.pointer.high\n this.ss.updateKeyByIterator(it, new Interval(lLow, high))\n } else {\n // Concat to left\n this.ss.updateKeyByIterator(it, new Interval(lLow, num))\n }\n } else {\n if (num + 1 === rLow) {\n // Concat to right\n this.ss.eraseElementByIterator(it.next())\n this.ss.insert(new Interval(num, rHigh))\n } else {\n // Insert new interval\n this.ss.insert(key)\n }\n }\n }\n }\n debugTrace('free():' + num)\n}\n\n/**\n * Clear all occupied numbers.\n * The all numbers are set to vacant status.\n * Time Complexity O(1)\n */\nNumberAllocator.prototype.clear = function () {\n debugTrace('clear()')\n this.ss.clear()\n this.ss.insert(new Interval(this.min, this.max))\n}\n\n/**\n * Get the number of intervals. Interval is internal structure of this library.\n * This function is for debugging.\n * Time Complexity O(1)\n * @return {Number} - The number of intervals.\n */\nNumberAllocator.prototype.intervalCount = function () {\n return this.ss.size()\n}\n\n/**\n * Dump the internal structor of the library.\n * This function is for debugging.\n * Time Complexity O(N) : N is the number of intervals (not numbers)\n */\nNumberAllocator.prototype.dump = function () {\n console.log('length:' + this.ss.size())\n for (const element of this.ss) {\n console.log(element)\n }\n}\n\nmodule.exports = NumberAllocator\n","// Copyright Takatoshi Kondo 2021\n//\n// Distributed under the MIT License\n\nconst NumberAllocator = require('./lib/number-allocator.js')\n\nmodule.exports.NumberAllocator = NumberAllocator\n","'use strict'\n\n/**\n * Module dependencies\n */\nconst LruMap = require('lru-cache')\nconst NumberAllocator = require('number-allocator').NumberAllocator\n\n/**\n * Topic Alias sending manager\n * This holds both topic to alias and alias to topic map\n * @param {Number} [max] - topic alias maximum entries\n */\nfunction TopicAliasSend (max) {\n if (!(this instanceof TopicAliasSend)) {\n return new TopicAliasSend(max)\n }\n\n if (max > 0) {\n this.aliasToTopic = new LruMap({ max: max })\n this.topicToAlias = {}\n this.numberAllocator = new NumberAllocator(1, max)\n this.max = max\n this.length = 0\n }\n}\n\n/**\n * Insert or update topic - alias entry.\n * @param {String} [topic] - topic\n * @param {Number} [alias] - topic alias\n * @returns {Boolean} - if success return true otherwise false\n */\nTopicAliasSend.prototype.put = function (topic, alias) {\n if (alias === 0 || alias > this.max) {\n return false\n }\n const entry = this.aliasToTopic.get(alias)\n if (entry) {\n delete this.topicToAlias[entry]\n }\n this.aliasToTopic.set(alias, topic)\n this.topicToAlias[topic] = alias\n this.numberAllocator.use(alias)\n this.length = this.aliasToTopic.length\n return true\n}\n\n/**\n * Get topic by alias\n * @param {Number} [alias] - topic alias\n * @returns {String} - if mapped topic exists return topic, otherwise return undefined\n */\nTopicAliasSend.prototype.getTopicByAlias = function (alias) {\n return this.aliasToTopic.get(alias)\n}\n\n/**\n * Get topic by alias\n * @param {String} [topic] - topic\n * @returns {Number} - if mapped topic exists return topic alias, otherwise return undefined\n */\nTopicAliasSend.prototype.getAliasByTopic = function (topic) {\n const alias = this.topicToAlias[topic]\n if (typeof alias !== 'undefined') {\n this.aliasToTopic.get(alias) // LRU update\n }\n return alias\n}\n\n/**\n * Clear all entries\n */\nTopicAliasSend.prototype.clear = function () {\n this.aliasToTopic.reset()\n this.topicToAlias = {}\n this.numberAllocator.clear()\n this.length = 0\n}\n\n/**\n * Get Least Recently Used (LRU) topic alias\n * @returns {Number} - if vacant alias exists then return it, otherwise then return LRU alias\n */\nTopicAliasSend.prototype.getLruAlias = function () {\n const alias = this.numberAllocator.firstVacant()\n if (alias) return alias\n return this.aliasToTopic.keys()[this.aliasToTopic.length - 1]\n}\n\nmodule.exports = TopicAliasSend\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst symbol = Symbol.for('BufferList')\n\nfunction BufferList (buf) {\n if (!(this instanceof BufferList)) {\n return new BufferList(buf)\n }\n\n BufferList._init.call(this, buf)\n}\n\nBufferList._init = function _init (buf) {\n Object.defineProperty(this, symbol, { value: true })\n\n this._bufs = []\n this.length = 0\n\n if (buf) {\n this.append(buf)\n }\n}\n\nBufferList.prototype._new = function _new (buf) {\n return new BufferList(buf)\n}\n\nBufferList.prototype._offset = function _offset (offset) {\n if (offset === 0) {\n return [0, 0]\n }\n\n let tot = 0\n\n for (let i = 0; i < this._bufs.length; i++) {\n const _t = tot + this._bufs[i].length\n if (offset < _t || i === this._bufs.length - 1) {\n return [i, offset - tot]\n }\n tot = _t\n }\n}\n\nBufferList.prototype._reverseOffset = function (blOffset) {\n const bufferId = blOffset[0]\n let offset = blOffset[1]\n\n for (let i = 0; i < bufferId; i++) {\n offset += this._bufs[i].length\n }\n\n return offset\n}\n\nBufferList.prototype.get = function get (index) {\n if (index > this.length || index < 0) {\n return undefined\n }\n\n const offset = this._offset(index)\n\n return this._bufs[offset[0]][offset[1]]\n}\n\nBufferList.prototype.slice = function slice (start, end) {\n if (typeof start === 'number' && start < 0) {\n start += this.length\n }\n\n if (typeof end === 'number' && end < 0) {\n end += this.length\n }\n\n return this.copy(null, 0, start, end)\n}\n\nBufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {\n if (typeof srcStart !== 'number' || srcStart < 0) {\n srcStart = 0\n }\n\n if (typeof srcEnd !== 'number' || srcEnd > this.length) {\n srcEnd = this.length\n }\n\n if (srcStart >= this.length) {\n return dst || Buffer.alloc(0)\n }\n\n if (srcEnd <= 0) {\n return dst || Buffer.alloc(0)\n }\n\n const copy = !!dst\n const off = this._offset(srcStart)\n const len = srcEnd - srcStart\n let bytes = len\n let bufoff = (copy && dstStart) || 0\n let start = off[1]\n\n // copy/slice everything\n if (srcStart === 0 && srcEnd === this.length) {\n if (!copy) {\n // slice, but full concat if multiple buffers\n return this._bufs.length === 1\n ? this._bufs[0]\n : Buffer.concat(this._bufs, this.length)\n }\n\n // copy, need to copy individual buffers\n for (let i = 0; i < this._bufs.length; i++) {\n this._bufs[i].copy(dst, bufoff)\n bufoff += this._bufs[i].length\n }\n\n return dst\n }\n\n // easy, cheap case where it's a subset of one of the buffers\n if (bytes <= this._bufs[off[0]].length - start) {\n return copy\n ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)\n : this._bufs[off[0]].slice(start, start + bytes)\n }\n\n if (!copy) {\n // a slice, we need something to copy in to\n dst = Buffer.allocUnsafe(len)\n }\n\n for (let i = off[0]; i < this._bufs.length; i++) {\n const l = this._bufs[i].length - start\n\n if (bytes > l) {\n this._bufs[i].copy(dst, bufoff, start)\n bufoff += l\n } else {\n this._bufs[i].copy(dst, bufoff, start, start + bytes)\n bufoff += l\n break\n }\n\n bytes -= l\n\n if (start) {\n start = 0\n }\n }\n\n // safeguard so that we don't return uninitialized memory\n if (dst.length > bufoff) return dst.slice(0, bufoff)\n\n return dst\n}\n\nBufferList.prototype.shallowSlice = function shallowSlice (start, end) {\n start = start || 0\n end = typeof end !== 'number' ? this.length : end\n\n if (start < 0) {\n start += this.length\n }\n\n if (end < 0) {\n end += this.length\n }\n\n if (start === end) {\n return this._new()\n }\n\n const startOffset = this._offset(start)\n const endOffset = this._offset(end)\n const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)\n\n if (endOffset[1] === 0) {\n buffers.pop()\n } else {\n buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])\n }\n\n if (startOffset[1] !== 0) {\n buffers[0] = buffers[0].slice(startOffset[1])\n }\n\n return this._new(buffers)\n}\n\nBufferList.prototype.toString = function toString (encoding, start, end) {\n return this.slice(start, end).toString(encoding)\n}\n\nBufferList.prototype.consume = function consume (bytes) {\n // first, normalize the argument, in accordance with how Buffer does it\n bytes = Math.trunc(bytes)\n // do nothing if not a positive number\n if (Number.isNaN(bytes) || bytes <= 0) return this\n\n while (this._bufs.length) {\n if (bytes >= this._bufs[0].length) {\n bytes -= this._bufs[0].length\n this.length -= this._bufs[0].length\n this._bufs.shift()\n } else {\n this._bufs[0] = this._bufs[0].slice(bytes)\n this.length -= bytes\n break\n }\n }\n\n return this\n}\n\nBufferList.prototype.duplicate = function duplicate () {\n const copy = this._new()\n\n for (let i = 0; i < this._bufs.length; i++) {\n copy.append(this._bufs[i])\n }\n\n return copy\n}\n\nBufferList.prototype.append = function append (buf) {\n if (buf == null) {\n return this\n }\n\n if (buf.buffer) {\n // append a view of the underlying ArrayBuffer\n this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))\n } else if (Array.isArray(buf)) {\n for (let i = 0; i < buf.length; i++) {\n this.append(buf[i])\n }\n } else if (this._isBufferList(buf)) {\n // unwrap argument into individual BufferLists\n for (let i = 0; i < buf._bufs.length; i++) {\n this.append(buf._bufs[i])\n }\n } else {\n // coerce number arguments to strings, since Buffer(number) does\n // uninitialized memory allocation\n if (typeof buf === 'number') {\n buf = buf.toString()\n }\n\n this._appendBuffer(Buffer.from(buf))\n }\n\n return this\n}\n\nBufferList.prototype._appendBuffer = function appendBuffer (buf) {\n this._bufs.push(buf)\n this.length += buf.length\n}\n\nBufferList.prototype.indexOf = function (search, offset, encoding) {\n if (encoding === undefined && typeof offset === 'string') {\n encoding = offset\n offset = undefined\n }\n\n if (typeof search === 'function' || Array.isArray(search)) {\n throw new TypeError('The \"value\" argument must be one of type string, Buffer, BufferList, or Uint8Array.')\n } else if (typeof search === 'number') {\n search = Buffer.from([search])\n } else if (typeof search === 'string') {\n search = Buffer.from(search, encoding)\n } else if (this._isBufferList(search)) {\n search = search.slice()\n } else if (Array.isArray(search.buffer)) {\n search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)\n } else if (!Buffer.isBuffer(search)) {\n search = Buffer.from(search)\n }\n\n offset = Number(offset || 0)\n\n if (isNaN(offset)) {\n offset = 0\n }\n\n if (offset < 0) {\n offset = this.length + offset\n }\n\n if (offset < 0) {\n offset = 0\n }\n\n if (search.length === 0) {\n return offset > this.length ? this.length : offset\n }\n\n const blOffset = this._offset(offset)\n let blIndex = blOffset[0] // index of which internal buffer we're working on\n let buffOffset = blOffset[1] // offset of the internal buffer we're working on\n\n // scan over each buffer\n for (; blIndex < this._bufs.length; blIndex++) {\n const buff = this._bufs[blIndex]\n\n while (buffOffset < buff.length) {\n const availableWindow = buff.length - buffOffset\n\n if (availableWindow >= search.length) {\n const nativeSearchResult = buff.indexOf(search, buffOffset)\n\n if (nativeSearchResult !== -1) {\n return this._reverseOffset([blIndex, nativeSearchResult])\n }\n\n buffOffset = buff.length - search.length + 1 // end of native search window\n } else {\n const revOffset = this._reverseOffset([blIndex, buffOffset])\n\n if (this._match(revOffset, search)) {\n return revOffset\n }\n\n buffOffset++\n }\n }\n\n buffOffset = 0\n }\n\n return -1\n}\n\nBufferList.prototype._match = function (offset, search) {\n if (this.length - offset < search.length) {\n return false\n }\n\n for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {\n if (this.get(offset + searchOffset) !== search[searchOffset]) {\n return false\n }\n }\n return true\n}\n\n;(function () {\n const methods = {\n readDoubleBE: 8,\n readDoubleLE: 8,\n readFloatBE: 4,\n readFloatLE: 4,\n readInt32BE: 4,\n readInt32LE: 4,\n readUInt32BE: 4,\n readUInt32LE: 4,\n readInt16BE: 2,\n readInt16LE: 2,\n readUInt16BE: 2,\n readUInt16LE: 2,\n readInt8: 1,\n readUInt8: 1,\n readIntBE: null,\n readIntLE: null,\n readUIntBE: null,\n readUIntLE: null\n }\n\n for (const m in methods) {\n (function (m) {\n if (methods[m] === null) {\n BufferList.prototype[m] = function (offset, byteLength) {\n return this.slice(offset, offset + byteLength)[m](0, byteLength)\n }\n } else {\n BufferList.prototype[m] = function (offset = 0) {\n return this.slice(offset, offset + methods[m])[m](0)\n }\n }\n }(m))\n }\n}())\n\n// Used internally by the class and also as an indicator of this object being\n// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser\n// environment because there could be multiple different copies of the\n// BufferList class and some `BufferList`s might be `BufferList`s.\nBufferList.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferList || BufferList.isBufferList(b)\n}\n\nBufferList.isBufferList = function isBufferList (b) {\n return b != null && b[symbol]\n}\n\nmodule.exports = BufferList\n","'use strict'\n\nconst DuplexStream = require('readable-stream').Duplex\nconst inherits = require('inherits')\nconst BufferList = require('./BufferList')\n\nfunction BufferListStream (callback) {\n if (!(this instanceof BufferListStream)) {\n return new BufferListStream(callback)\n }\n\n if (typeof callback === 'function') {\n this._callback = callback\n\n const piper = function piper (err) {\n if (this._callback) {\n this._callback(err)\n this._callback = null\n }\n }.bind(this)\n\n this.on('pipe', function onPipe (src) {\n src.on('error', piper)\n })\n this.on('unpipe', function onUnpipe (src) {\n src.removeListener('error', piper)\n })\n\n callback = null\n }\n\n BufferList._init.call(this, callback)\n DuplexStream.call(this)\n}\n\ninherits(BufferListStream, DuplexStream)\nObject.assign(BufferListStream.prototype, BufferList.prototype)\n\nBufferListStream.prototype._new = function _new (callback) {\n return new BufferListStream(callback)\n}\n\nBufferListStream.prototype._write = function _write (buf, encoding, callback) {\n this._appendBuffer(buf)\n\n if (typeof callback === 'function') {\n callback()\n }\n}\n\nBufferListStream.prototype._read = function _read (size) {\n if (!this.length) {\n return this.push(null)\n }\n\n size = Math.min(size, this.length)\n this.push(this.slice(0, size))\n this.consume(size)\n}\n\nBufferListStream.prototype.end = function end (chunk) {\n DuplexStream.prototype.end.call(this, chunk)\n\n if (this._callback) {\n this._callback(null, this.slice())\n this._callback = null\n }\n}\n\nBufferListStream.prototype._destroy = function _destroy (err, cb) {\n this._bufs.length = 0\n this.length = 0\n cb(err)\n}\n\nBufferListStream.prototype._isBufferList = function _isBufferList (b) {\n return b instanceof BufferListStream || b instanceof BufferList || BufferListStream.isBufferList(b)\n}\n\nBufferListStream.isBufferList = BufferList.isBufferList\n\nmodule.exports = BufferListStream\nmodule.exports.BufferListStream = BufferListStream\nmodule.exports.BufferList = BufferList\n","class Packet {\n constructor () {\n this.cmd = null\n this.retain = false\n this.qos = 0\n this.dup = false\n this.length = -1\n this.topic = null\n this.payload = null\n }\n}\n\nmodule.exports = Packet\n","/* Protocol - protocol constants */\nconst protocol = module.exports\n\n/* Command code => mnemonic */\nprotocol.types = {\n 0: 'reserved',\n 1: 'connect',\n 2: 'connack',\n 3: 'publish',\n 4: 'puback',\n 5: 'pubrec',\n 6: 'pubrel',\n 7: 'pubcomp',\n 8: 'subscribe',\n 9: 'suback',\n 10: 'unsubscribe',\n 11: 'unsuback',\n 12: 'pingreq',\n 13: 'pingresp',\n 14: 'disconnect',\n 15: 'auth'\n}\n\n/* Mnemonic => Command code */\nprotocol.codes = {}\nfor (const k in protocol.types) {\n const v = protocol.types[k]\n protocol.codes[v] = k\n}\n\n/* Header */\nprotocol.CMD_SHIFT = 4\nprotocol.CMD_MASK = 0xF0\nprotocol.DUP_MASK = 0x08\nprotocol.QOS_MASK = 0x03\nprotocol.QOS_SHIFT = 1\nprotocol.RETAIN_MASK = 0x01\n\n/* Length */\nprotocol.VARBYTEINT_MASK = 0x7F\nprotocol.VARBYTEINT_FIN_MASK = 0x80\nprotocol.VARBYTEINT_MAX = 268435455\n\n/* Connack */\nprotocol.SESSIONPRESENT_MASK = 0x01\nprotocol.SESSIONPRESENT_HEADER = Buffer.from([protocol.SESSIONPRESENT_MASK])\nprotocol.CONNACK_HEADER = Buffer.from([protocol.codes.connack << protocol.CMD_SHIFT])\n\n/* Connect */\nprotocol.USERNAME_MASK = 0x80\nprotocol.PASSWORD_MASK = 0x40\nprotocol.WILL_RETAIN_MASK = 0x20\nprotocol.WILL_QOS_MASK = 0x18\nprotocol.WILL_QOS_SHIFT = 3\nprotocol.WILL_FLAG_MASK = 0x04\nprotocol.CLEAN_SESSION_MASK = 0x02\nprotocol.CONNECT_HEADER = Buffer.from([protocol.codes.connect << protocol.CMD_SHIFT])\n\n/* Properties */\nprotocol.properties = {\n sessionExpiryInterval: 17,\n willDelayInterval: 24,\n receiveMaximum: 33,\n maximumPacketSize: 39,\n topicAliasMaximum: 34,\n requestResponseInformation: 25,\n requestProblemInformation: 23,\n userProperties: 38,\n authenticationMethod: 21,\n authenticationData: 22,\n payloadFormatIndicator: 1,\n messageExpiryInterval: 2,\n contentType: 3,\n responseTopic: 8,\n correlationData: 9,\n maximumQoS: 36,\n retainAvailable: 37,\n assignedClientIdentifier: 18,\n reasonString: 31,\n wildcardSubscriptionAvailable: 40,\n subscriptionIdentifiersAvailable: 41,\n sharedSubscriptionAvailable: 42,\n serverKeepAlive: 19,\n responseInformation: 26,\n serverReference: 28,\n topicAlias: 35,\n subscriptionIdentifier: 11\n}\nprotocol.propertiesCodes = {}\nfor (const prop in protocol.properties) {\n const id = protocol.properties[prop]\n protocol.propertiesCodes[id] = prop\n}\nprotocol.propertiesTypes = {\n sessionExpiryInterval: 'int32',\n willDelayInterval: 'int32',\n receiveMaximum: 'int16',\n maximumPacketSize: 'int32',\n topicAliasMaximum: 'int16',\n requestResponseInformation: 'byte',\n requestProblemInformation: 'byte',\n userProperties: 'pair',\n authenticationMethod: 'string',\n authenticationData: 'binary',\n payloadFormatIndicator: 'byte',\n messageExpiryInterval: 'int32',\n contentType: 'string',\n responseTopic: 'string',\n correlationData: 'binary',\n maximumQoS: 'int8',\n retainAvailable: 'byte',\n assignedClientIdentifier: 'string',\n reasonString: 'string',\n wildcardSubscriptionAvailable: 'byte',\n subscriptionIdentifiersAvailable: 'byte',\n sharedSubscriptionAvailable: 'byte',\n serverKeepAlive: 'int16',\n responseInformation: 'string',\n serverReference: 'string',\n topicAlias: 'int16',\n subscriptionIdentifier: 'var'\n}\n\nfunction genHeader (type) {\n return [0, 1, 2].map(qos => {\n return [0, 1].map(dup => {\n return [0, 1].map(retain => {\n const buf = Buffer.alloc(1)\n buf.writeUInt8(\n protocol.codes[type] << protocol.CMD_SHIFT |\n (dup ? protocol.DUP_MASK : 0) |\n qos << protocol.QOS_SHIFT | retain, 0, true)\n return buf\n })\n })\n })\n}\n\n/* Publish */\nprotocol.PUBLISH_HEADER = genHeader('publish')\n\n/* Subscribe */\nprotocol.SUBSCRIBE_HEADER = genHeader('subscribe')\nprotocol.SUBSCRIBE_OPTIONS_QOS_MASK = 0x03\nprotocol.SUBSCRIBE_OPTIONS_NL_MASK = 0x01\nprotocol.SUBSCRIBE_OPTIONS_NL_SHIFT = 2\nprotocol.SUBSCRIBE_OPTIONS_RAP_MASK = 0x01\nprotocol.SUBSCRIBE_OPTIONS_RAP_SHIFT = 3\nprotocol.SUBSCRIBE_OPTIONS_RH_MASK = 0x03\nprotocol.SUBSCRIBE_OPTIONS_RH_SHIFT = 4\nprotocol.SUBSCRIBE_OPTIONS_RH = [0x00, 0x10, 0x20]\nprotocol.SUBSCRIBE_OPTIONS_NL = 0x04\nprotocol.SUBSCRIBE_OPTIONS_RAP = 0x08\nprotocol.SUBSCRIBE_OPTIONS_QOS = [0x00, 0x01, 0x02]\n\n/* Unsubscribe */\nprotocol.UNSUBSCRIBE_HEADER = genHeader('unsubscribe')\n\n/* Confirmations */\nprotocol.ACKS = {\n unsuback: genHeader('unsuback'),\n puback: genHeader('puback'),\n pubcomp: genHeader('pubcomp'),\n pubrel: genHeader('pubrel'),\n pubrec: genHeader('pubrec')\n}\n\nprotocol.SUBACK_HEADER = Buffer.from([protocol.codes.suback << protocol.CMD_SHIFT])\n\n/* Protocol versions */\nprotocol.VERSION3 = Buffer.from([3])\nprotocol.VERSION4 = Buffer.from([4])\nprotocol.VERSION5 = Buffer.from([5])\nprotocol.VERSION131 = Buffer.from([131])\nprotocol.VERSION132 = Buffer.from([132])\n\n/* QoS */\nprotocol.QOS = [0, 1, 2].map(qos => {\n return Buffer.from([qos])\n})\n\n/* Empty packets */\nprotocol.EMPTY = {\n pingreq: Buffer.from([protocol.codes.pingreq << 4, 0]),\n pingresp: Buffer.from([protocol.codes.pingresp << 4, 0]),\n disconnect: Buffer.from([protocol.codes.disconnect << 4, 0])\n}\n","const bl = require('bl')\nconst EventEmitter = require('events')\nconst Packet = require('./packet')\nconst constants = require('./constants')\nconst debug = require('debug')('mqtt-packet:parser')\n\nclass Parser extends EventEmitter {\n constructor () {\n super()\n this.parser = this.constructor.parser\n }\n\n static parser (opt) {\n if (!(this instanceof Parser)) return (new Parser()).parser(opt)\n\n this.settings = opt || {}\n\n this._states = [\n '_parseHeader',\n '_parseLength',\n '_parsePayload',\n '_newPacket'\n ]\n\n this._resetState()\n return this\n }\n\n _resetState () {\n debug('_resetState: resetting packet, error, _list, and _stateCounter')\n this.packet = new Packet()\n this.error = null\n this._list = bl()\n this._stateCounter = 0\n }\n\n parse (buf) {\n if (this.error) this._resetState()\n\n this._list.append(buf)\n debug('parse: current state: %s', this._states[this._stateCounter])\n while ((this.packet.length !== -1 || this._list.length > 0) &&\n this[this._states[this._stateCounter]]() &&\n !this.error) {\n this._stateCounter++\n debug('parse: state complete. _stateCounter is now: %d', this._stateCounter)\n debug('parse: packet.length: %d, buffer list length: %d', this.packet.length, this._list.length)\n if (this._stateCounter >= this._states.length) this._stateCounter = 0\n }\n debug('parse: exited while loop. packet: %d, buffer list length: %d', this.packet.length, this._list.length)\n return this._list.length\n }\n\n _parseHeader () {\n // There is at least one byte in the buffer\n const zero = this._list.readUInt8(0)\n this.packet.cmd = constants.types[zero >> constants.CMD_SHIFT]\n this.packet.retain = (zero & constants.RETAIN_MASK) !== 0\n this.packet.qos = (zero >> constants.QOS_SHIFT) & constants.QOS_MASK\n this.packet.dup = (zero & constants.DUP_MASK) !== 0\n debug('_parseHeader: packet: %o', this.packet)\n\n this._list.consume(1)\n\n return true\n }\n\n _parseLength () {\n // There is at least one byte in the list\n const result = this._parseVarByteNum(true)\n\n if (result) {\n this.packet.length = result.value\n this._list.consume(result.bytes)\n }\n debug('_parseLength %d', result.value)\n return !!result\n }\n\n _parsePayload () {\n debug('_parsePayload: payload %O', this._list)\n let result = false\n\n // Do we have a payload? Do we have enough data to complete the payload?\n // PINGs have no payload\n if (this.packet.length === 0 || this._list.length >= this.packet.length) {\n this._pos = 0\n\n switch (this.packet.cmd) {\n case 'connect':\n this._parseConnect()\n break\n case 'connack':\n this._parseConnack()\n break\n case 'publish':\n this._parsePublish()\n break\n case 'puback':\n case 'pubrec':\n case 'pubrel':\n case 'pubcomp':\n this._parseConfirmation()\n break\n case 'subscribe':\n this._parseSubscribe()\n break\n case 'suback':\n this._parseSuback()\n break\n case 'unsubscribe':\n this._parseUnsubscribe()\n break\n case 'unsuback':\n this._parseUnsuback()\n break\n case 'pingreq':\n case 'pingresp':\n // These are empty, nothing to do\n break\n case 'disconnect':\n this._parseDisconnect()\n break\n case 'auth':\n this._parseAuth()\n break\n default:\n this._emitError(new Error('Not supported'))\n }\n\n result = true\n }\n debug('_parsePayload complete result: %s', result)\n return result\n }\n\n _parseConnect () {\n debug('_parseConnect')\n let topic // Will topic\n let payload // Will payload\n let password // Password\n let username // Username\n const flags = {}\n const packet = this.packet\n\n // Parse protocolId\n const protocolId = this._parseString()\n\n if (protocolId === null) return this._emitError(new Error('Cannot parse protocolId'))\n if (protocolId !== 'MQTT' && protocolId !== 'MQIsdp') {\n return this._emitError(new Error('Invalid protocolId'))\n }\n\n packet.protocolId = protocolId\n\n // Parse constants version number\n if (this._pos >= this._list.length) return this._emitError(new Error('Packet too short'))\n\n packet.protocolVersion = this._list.readUInt8(this._pos)\n\n if (packet.protocolVersion >= 128) {\n packet.bridgeMode = true\n packet.protocolVersion = packet.protocolVersion - 128\n }\n\n if (packet.protocolVersion !== 3 && packet.protocolVersion !== 4 && packet.protocolVersion !== 5) {\n return this._emitError(new Error('Invalid protocol version'))\n }\n\n this._pos++\n\n if (this._pos >= this._list.length) {\n return this._emitError(new Error('Packet too short'))\n }\n\n // Parse connect flags\n flags.username = (this._list.readUInt8(this._pos) & constants.USERNAME_MASK)\n flags.password = (this._list.readUInt8(this._pos) & constants.PASSWORD_MASK)\n flags.will = (this._list.readUInt8(this._pos) & constants.WILL_FLAG_MASK)\n\n if (flags.will) {\n packet.will = {}\n packet.will.retain = (this._list.readUInt8(this._pos) & constants.WILL_RETAIN_MASK) !== 0\n packet.will.qos = (this._list.readUInt8(this._pos) &\n constants.WILL_QOS_MASK) >> constants.WILL_QOS_SHIFT\n }\n\n packet.clean = (this._list.readUInt8(this._pos) & constants.CLEAN_SESSION_MASK) !== 0\n this._pos++\n\n // Parse keepalive\n packet.keepalive = this._parseNum()\n if (packet.keepalive === -1) return this._emitError(new Error('Packet too short'))\n\n // parse properties\n if (packet.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n // Parse clientId\n const clientId = this._parseString()\n if (clientId === null) return this._emitError(new Error('Packet too short'))\n packet.clientId = clientId\n debug('_parseConnect: packet.clientId: %s', packet.clientId)\n\n if (flags.will) {\n if (packet.protocolVersion === 5) {\n const willProperties = this._parseProperties()\n if (Object.getOwnPropertyNames(willProperties).length) {\n packet.will.properties = willProperties\n }\n }\n // Parse will topic\n topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse will topic'))\n packet.will.topic = topic\n debug('_parseConnect: packet.will.topic: %s', packet.will.topic)\n\n // Parse will payload\n payload = this._parseBuffer()\n if (payload === null) return this._emitError(new Error('Cannot parse will payload'))\n packet.will.payload = payload\n debug('_parseConnect: packet.will.paylaod: %s', packet.will.payload)\n }\n\n // Parse username\n if (flags.username) {\n username = this._parseString()\n if (username === null) return this._emitError(new Error('Cannot parse username'))\n packet.username = username\n debug('_parseConnect: packet.username: %s', packet.username)\n }\n\n // Parse password\n if (flags.password) {\n password = this._parseBuffer()\n if (password === null) return this._emitError(new Error('Cannot parse password'))\n packet.password = password\n }\n // need for right parse auth packet and self set up\n this.settings = packet\n debug('_parseConnect: complete')\n return packet\n }\n\n _parseConnack () {\n debug('_parseConnack')\n const packet = this.packet\n\n if (this._list.length < 1) return null\n packet.sessionPresent = !!(this._list.readUInt8(this._pos++) & constants.SESSIONPRESENT_MASK)\n\n if (this.settings.protocolVersion === 5) {\n if (this._list.length >= 2) {\n packet.reasonCode = this._list.readUInt8(this._pos++)\n } else {\n packet.reasonCode = 0\n }\n } else {\n if (this._list.length < 2) return null\n packet.returnCode = this._list.readUInt8(this._pos++)\n }\n\n if (packet.returnCode === -1 || packet.reasonCode === -1) return this._emitError(new Error('Cannot parse return code'))\n // mqtt 5 properties\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n debug('_parseConnack: complete')\n }\n\n _parsePublish () {\n debug('_parsePublish')\n const packet = this.packet\n packet.topic = this._parseString()\n\n if (packet.topic === null) return this._emitError(new Error('Cannot parse topic'))\n\n // Parse messageId\n if (packet.qos > 0) if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n packet.payload = this._list.slice(this._pos, packet.length)\n debug('_parsePublish: payload from buffer list: %o', packet.payload)\n }\n\n _parseSubscribe () {\n debug('_parseSubscribe')\n const packet = this.packet\n let topic\n let options\n let qos\n let rh\n let rap\n let nl\n let subscription\n\n if (packet.qos !== 1) {\n return this._emitError(new Error('Wrong subscribe header'))\n }\n\n packet.subscriptions = []\n\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n while (this._pos < packet.length) {\n // Parse topic\n topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse topic'))\n if (this._pos >= packet.length) return this._emitError(new Error('Malformed Subscribe Payload'))\n\n options = this._parseByte()\n qos = options & constants.SUBSCRIBE_OPTIONS_QOS_MASK\n nl = ((options >> constants.SUBSCRIBE_OPTIONS_NL_SHIFT) & constants.SUBSCRIBE_OPTIONS_NL_MASK) !== 0\n rap = ((options >> constants.SUBSCRIBE_OPTIONS_RAP_SHIFT) & constants.SUBSCRIBE_OPTIONS_RAP_MASK) !== 0\n rh = (options >> constants.SUBSCRIBE_OPTIONS_RH_SHIFT) & constants.SUBSCRIBE_OPTIONS_RH_MASK\n\n subscription = { topic, qos }\n\n // mqtt 5 options\n if (this.settings.protocolVersion === 5) {\n subscription.nl = nl\n subscription.rap = rap\n subscription.rh = rh\n } else if (this.settings.bridgeMode) {\n subscription.rh = 0\n subscription.rap = true\n subscription.nl = true\n }\n\n // Push pair to subscriptions\n debug('_parseSubscribe: push subscription `%s` to subscription', subscription)\n packet.subscriptions.push(subscription)\n }\n }\n\n _parseSuback () {\n debug('_parseSuback')\n const packet = this.packet\n this.packet.granted = []\n\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n // Parse granted QoSes\n while (this._pos < this.packet.length) {\n this.packet.granted.push(this._list.readUInt8(this._pos++))\n }\n }\n\n _parseUnsubscribe () {\n debug('_parseUnsubscribe')\n const packet = this.packet\n\n packet.unsubscriptions = []\n\n // Parse messageId\n if (!this._parseMessageId()) { return }\n\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n while (this._pos < packet.length) {\n // Parse topic\n const topic = this._parseString()\n if (topic === null) return this._emitError(new Error('Cannot parse topic'))\n\n // Push topic to unsubscriptions\n debug('_parseUnsubscribe: push topic `%s` to unsubscriptions', topic)\n packet.unsubscriptions.push(topic)\n }\n }\n\n _parseUnsuback () {\n debug('_parseUnsuback')\n const packet = this.packet\n if (!this._parseMessageId()) return this._emitError(new Error('Cannot parse messageId'))\n // Properties mqtt 5\n if (this.settings.protocolVersion === 5) {\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n // Parse granted QoSes\n packet.granted = []\n while (this._pos < this.packet.length) {\n this.packet.granted.push(this._list.readUInt8(this._pos++))\n }\n }\n }\n\n // parse packets like puback, pubrec, pubrel, pubcomp\n _parseConfirmation () {\n debug('_parseConfirmation: packet.cmd: `%s`', this.packet.cmd)\n const packet = this.packet\n\n this._parseMessageId()\n\n if (this.settings.protocolVersion === 5) {\n if (packet.length > 2) {\n // response code\n packet.reasonCode = this._parseByte()\n debug('_parseConfirmation: packet.reasonCode `%d`', packet.reasonCode)\n } else {\n packet.reasonCode = 0\n }\n\n if (packet.length > 3) {\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n }\n\n return true\n }\n\n // parse disconnect packet\n _parseDisconnect () {\n const packet = this.packet\n debug('_parseDisconnect')\n\n if (this.settings.protocolVersion === 5) {\n // response code\n if (this._list.length > 0) {\n packet.reasonCode = this._parseByte()\n } else {\n packet.reasonCode = 0\n }\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n }\n\n debug('_parseDisconnect result: true')\n return true\n }\n\n // parse auth packet\n _parseAuth () {\n debug('_parseAuth')\n const packet = this.packet\n\n if (this.settings.protocolVersion !== 5) {\n return this._emitError(new Error('Not supported auth packet for this version MQTT'))\n }\n\n // response code\n packet.reasonCode = this._parseByte()\n // properies mqtt 5\n const properties = this._parseProperties()\n if (Object.getOwnPropertyNames(properties).length) {\n packet.properties = properties\n }\n\n debug('_parseAuth: result: true')\n return true\n }\n\n _parseMessageId () {\n const packet = this.packet\n\n packet.messageId = this._parseNum()\n\n if (packet.messageId === null) {\n this._emitError(new Error('Cannot parse messageId'))\n return false\n }\n\n debug('_parseMessageId: packet.messageId %d', packet.messageId)\n return true\n }\n\n _parseString (maybeBuffer) {\n const length = this._parseNum()\n const end = length + this._pos\n\n if (length === -1 || end > this._list.length || end > this.packet.length) return null\n\n const result = this._list.toString('utf8', this._pos, end)\n this._pos += length\n debug('_parseString: result: %s', result)\n return result\n }\n\n _parseStringPair () {\n debug('_parseStringPair')\n return {\n name: this._parseString(),\n value: this._parseString()\n }\n }\n\n _parseBuffer () {\n const length = this._parseNum()\n const end = length + this._pos\n\n if (length === -1 || end > this._list.length || end > this.packet.length) return null\n\n const result = this._list.slice(this._pos, end)\n\n this._pos += length\n debug('_parseBuffer: result: %o', result)\n return result\n }\n\n _parseNum () {\n if (this._list.length - this._pos < 2) return -1\n\n const result = this._list.readUInt16BE(this._pos)\n this._pos += 2\n debug('_parseNum: result: %s', result)\n return result\n }\n\n _parse4ByteNum () {\n if (this._list.length - this._pos < 4) return -1\n\n const result = this._list.readUInt32BE(this._pos)\n this._pos += 4\n debug('_parse4ByteNum: result: %s', result)\n return result\n }\n\n _parseVarByteNum (fullInfoFlag) {\n debug('_parseVarByteNum')\n const maxBytes = 4\n let bytes = 0\n let mul = 1\n let value = 0\n let result = false\n let current\n const padding = this._pos ? this._pos : 0\n\n while (bytes < maxBytes && (padding + bytes) < this._list.length) {\n current = this._list.readUInt8(padding + bytes++)\n value += mul * (current & constants.VARBYTEINT_MASK)\n mul *= 0x80\n\n if ((current & constants.VARBYTEINT_FIN_MASK) === 0) {\n result = true\n break\n }\n if (this._list.length <= bytes) {\n break\n }\n }\n\n if (!result && bytes === maxBytes && this._list.length >= bytes) {\n this._emitError(new Error('Invalid variable byte integer'))\n }\n\n if (padding) {\n this._pos += bytes\n }\n\n result = result\n ? fullInfoFlag ? {\n bytes,\n value\n } : value\n : false\n\n debug('_parseVarByteNum: result: %o', result)\n return result\n }\n\n _parseByte () {\n let result\n if (this._pos < this._list.length) {\n result = this._list.readUInt8(this._pos)\n this._pos++\n }\n debug('_parseByte: result: %o', result)\n return result\n }\n\n _parseByType (type) {\n debug('_parseByType: type: %s', type)\n switch (type) {\n case 'byte': {\n return this._parseByte() !== 0\n }\n case 'int8': {\n return this._parseByte()\n }\n case 'int16': {\n return this._parseNum()\n }\n case 'int32': {\n return this._parse4ByteNum()\n }\n case 'var': {\n return this._parseVarByteNum()\n }\n case 'string': {\n return this._parseString()\n }\n case 'pair': {\n return this._parseStringPair()\n }\n case 'binary': {\n return this._parseBuffer()\n }\n }\n }\n\n _parseProperties () {\n debug('_parseProperties')\n const length = this._parseVarByteNum()\n const start = this._pos\n const end = start + length\n const result = {}\n while (this._pos < end) {\n const type = this._parseByte()\n if (!type) {\n this._emitError(new Error('Cannot parse property code type'))\n return false\n }\n const name = constants.propertiesCodes[type]\n if (!name) {\n this._emitError(new Error('Unknown property'))\n return false\n }\n // user properties process\n if (name === 'userProperties') {\n if (!result[name]) {\n result[name] = Object.create(null)\n }\n const currentUserProperty = this._parseByType(constants.propertiesTypes[name])\n if (result[name][currentUserProperty.name]) {\n if (Array.isArray(result[name][currentUserProperty.name])) {\n result[name][currentUserProperty.name].push(currentUserProperty.value)\n } else {\n const currentValue = result[name][currentUserProperty.name]\n result[name][currentUserProperty.name] = [currentValue]\n result[name][currentUserProperty.name].push(currentUserProperty.value)\n }\n } else {\n result[name][currentUserProperty.name] = currentUserProperty.value\n }\n continue\n }\n if (result[name]) {\n if (Array.isArray(result[name])) {\n result[name].push(this._parseByType(constants.propertiesTypes[name]))\n } else {\n result[name] = [result[name]]\n result[name].push(this._parseByType(constants.propertiesTypes[name]))\n }\n } else {\n result[name] = this._parseByType(constants.propertiesTypes[name])\n }\n }\n return result\n }\n\n _newPacket () {\n debug('_newPacket')\n if (this.packet) {\n this._list.consume(this.packet.length)\n debug('_newPacket: parser emit packet: packet.cmd: %s, packet.payload: %s, packet.length: %d', this.packet.cmd, this.packet.payload, this.packet.length)\n this.emit('packet', this.packet)\n }\n debug('_newPacket: new packet')\n this.packet = new Packet()\n\n this._pos = 0\n\n return true\n }\n\n _emitError (err) {\n debug('_emitError')\n this.error = err\n this.emit('error', err)\n }\n}\n\nmodule.exports = Parser\n","const max = 65536\nconst cache = {}\n\n// in node 6 Buffer.subarray returns a Uint8Array instead of a Buffer\n// later versions return a Buffer\n// alternative is Buffer.slice but that creates a new buffer\n// creating new buffers takes time\n// SubOk is only false on node < 8\nconst SubOk = Buffer.isBuffer(Buffer.from([1, 2]).subarray(0, 1))\n\nfunction generateBuffer (i) {\n const buffer = Buffer.allocUnsafe(2)\n buffer.writeUInt8(i >> 8, 0)\n buffer.writeUInt8(i & 0x00FF, 0 + 1)\n\n return buffer\n}\n\nfunction generateCache () {\n for (let i = 0; i < max; i++) {\n cache[i] = generateBuffer(i)\n }\n}\n\nfunction genBufVariableByteInt (num) {\n const maxLength = 4 // max 4 bytes\n let digit = 0\n let pos = 0\n const buffer = Buffer.allocUnsafe(maxLength)\n\n do {\n digit = num % 128 | 0\n num = num / 128 | 0\n if (num > 0) digit = digit | 0x80\n\n buffer.writeUInt8(digit, pos++)\n } while (num > 0 && pos < maxLength)\n\n if (num > 0) {\n pos = 0\n }\n\n return SubOk ? buffer.subarray(0, pos) : buffer.slice(0, pos)\n}\n\nfunction generate4ByteBuffer (num) {\n const buffer = Buffer.allocUnsafe(4)\n buffer.writeUInt32BE(num, 0)\n return buffer\n}\n\nmodule.exports = {\n cache,\n generateCache,\n generateNumber: generateBuffer,\n genBufVariableByteInt,\n generate4ByteBuffer\n}\n","'use strict';\n\nif (typeof process === 'undefined' ||\n !process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = { nextTick: nextTick };\n} else {\n module.exports = process\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n","const protocol = require('./constants')\nconst empty = Buffer.allocUnsafe(0)\nconst zeroBuf = Buffer.from([0])\nconst numbers = require('./numbers')\nconst nextTick = require('process-nextick-args').nextTick\nconst debug = require('debug')('mqtt-packet:writeToStream')\n\nconst numCache = numbers.cache\nconst generateNumber = numbers.generateNumber\nconst generateCache = numbers.generateCache\nconst genBufVariableByteInt = numbers.genBufVariableByteInt\nconst generate4ByteBuffer = numbers.generate4ByteBuffer\nlet writeNumber = writeNumberCached\nlet toGenerate = true\n\nfunction generate (packet, stream, opts) {\n debug('generate called')\n if (stream.cork) {\n stream.cork()\n nextTick(uncork, stream)\n }\n\n if (toGenerate) {\n toGenerate = false\n generateCache()\n }\n debug('generate: packet.cmd: %s', packet.cmd)\n switch (packet.cmd) {\n case 'connect':\n return connect(packet, stream, opts)\n case 'connack':\n return connack(packet, stream, opts)\n case 'publish':\n return publish(packet, stream, opts)\n case 'puback':\n case 'pubrec':\n case 'pubrel':\n case 'pubcomp':\n return confirmation(packet, stream, opts)\n case 'subscribe':\n return subscribe(packet, stream, opts)\n case 'suback':\n return suback(packet, stream, opts)\n case 'unsubscribe':\n return unsubscribe(packet, stream, opts)\n case 'unsuback':\n return unsuback(packet, stream, opts)\n case 'pingreq':\n case 'pingresp':\n return emptyPacket(packet, stream, opts)\n case 'disconnect':\n return disconnect(packet, stream, opts)\n case 'auth':\n return auth(packet, stream, opts)\n default:\n stream.emit('error', new Error('Unknown command'))\n return false\n }\n}\n/**\n * Controls numbers cache.\n * Set to \"false\" to allocate buffers on-the-flight instead of pre-generated cache\n */\nObject.defineProperty(generate, 'cacheNumbers', {\n get () {\n return writeNumber === writeNumberCached\n },\n set (value) {\n if (value) {\n if (!numCache || Object.keys(numCache).length === 0) toGenerate = true\n writeNumber = writeNumberCached\n } else {\n toGenerate = false\n writeNumber = writeNumberGenerated\n }\n }\n})\n\nfunction uncork (stream) {\n stream.uncork()\n}\n\nfunction connect (packet, stream, opts) {\n const settings = packet || {}\n const protocolId = settings.protocolId || 'MQTT'\n let protocolVersion = settings.protocolVersion || 4\n const will = settings.will\n let clean = settings.clean\n const keepalive = settings.keepalive || 0\n const clientId = settings.clientId || ''\n const username = settings.username\n const password = settings.password\n /* mqtt5 new oprions */\n const properties = settings.properties\n\n if (clean === undefined) clean = true\n\n let length = 0\n\n // Must be a string and non-falsy\n if (!protocolId ||\n (typeof protocolId !== 'string' && !Buffer.isBuffer(protocolId))) {\n stream.emit('error', new Error('Invalid protocolId'))\n return false\n } else length += protocolId.length + 2\n\n // Must be 3 or 4 or 5\n if (protocolVersion !== 3 && protocolVersion !== 4 && protocolVersion !== 5) {\n stream.emit('error', new Error('Invalid protocol version'))\n return false\n } else length += 1\n\n // ClientId might be omitted in 3.1.1 and 5, but only if cleanSession is set to 1\n if ((typeof clientId === 'string' || Buffer.isBuffer(clientId)) &&\n (clientId || protocolVersion >= 4) && (clientId || clean)) {\n length += Buffer.byteLength(clientId) + 2\n } else {\n if (protocolVersion < 4) {\n stream.emit('error', new Error('clientId must be supplied before 3.1.1'))\n return false\n }\n if ((clean * 1) === 0) {\n stream.emit('error', new Error('clientId must be given if cleanSession set to 0'))\n return false\n }\n }\n\n // Must be a two byte number\n if (typeof keepalive !== 'number' ||\n keepalive < 0 ||\n keepalive > 65535 ||\n keepalive % 1 !== 0) {\n stream.emit('error', new Error('Invalid keepalive'))\n return false\n } else length += 2\n\n // Connect flags\n length += 1\n\n // Properties\n if (protocolVersion === 5) {\n var propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // If will exists...\n if (will) {\n // It must be an object\n if (typeof will !== 'object') {\n stream.emit('error', new Error('Invalid will'))\n return false\n }\n // It must have topic typeof string\n if (!will.topic || typeof will.topic !== 'string') {\n stream.emit('error', new Error('Invalid will topic'))\n return false\n } else {\n length += Buffer.byteLength(will.topic) + 2\n }\n\n // Payload\n length += 2 // payload length\n if (will.payload) {\n if (will.payload.length >= 0) {\n if (typeof will.payload === 'string') {\n length += Buffer.byteLength(will.payload)\n } else {\n length += will.payload.length\n }\n } else {\n stream.emit('error', new Error('Invalid will payload'))\n return false\n }\n }\n // will properties\n var willProperties = {}\n if (protocolVersion === 5) {\n willProperties = getProperties(stream, will.properties)\n if (!willProperties) { return false }\n length += willProperties.length\n }\n }\n\n // Username\n let providedUsername = false\n if (username != null) {\n if (isStringOrBuffer(username)) {\n providedUsername = true\n length += Buffer.byteLength(username) + 2\n } else {\n stream.emit('error', new Error('Invalid username'))\n return false\n }\n }\n\n // Password\n if (password != null) {\n if (!providedUsername) {\n stream.emit('error', new Error('Username is required to use password'))\n return false\n }\n\n if (isStringOrBuffer(password)) {\n length += byteLength(password) + 2\n } else {\n stream.emit('error', new Error('Invalid password'))\n return false\n }\n }\n\n // Generate header\n stream.write(protocol.CONNECT_HEADER)\n\n // Generate length\n writeVarByteInt(stream, length)\n\n // Generate protocol ID\n writeStringOrBuffer(stream, protocolId)\n\n if (settings.bridgeMode) {\n protocolVersion += 128\n }\n\n stream.write(\n protocolVersion === 131\n ? protocol.VERSION131\n : protocolVersion === 132\n ? protocol.VERSION132\n : protocolVersion === 4\n ? protocol.VERSION4\n : protocolVersion === 5\n ? protocol.VERSION5\n : protocol.VERSION3\n )\n\n // Connect flags\n let flags = 0\n flags |= (username != null) ? protocol.USERNAME_MASK : 0\n flags |= (password != null) ? protocol.PASSWORD_MASK : 0\n flags |= (will && will.retain) ? protocol.WILL_RETAIN_MASK : 0\n flags |= (will && will.qos) ? will.qos << protocol.WILL_QOS_SHIFT : 0\n flags |= will ? protocol.WILL_FLAG_MASK : 0\n flags |= clean ? protocol.CLEAN_SESSION_MASK : 0\n\n stream.write(Buffer.from([flags]))\n\n // Keepalive\n writeNumber(stream, keepalive)\n\n // Properties\n if (protocolVersion === 5) {\n propertiesData.write()\n }\n\n // Client ID\n writeStringOrBuffer(stream, clientId)\n\n // Will\n if (will) {\n if (protocolVersion === 5) {\n willProperties.write()\n }\n writeString(stream, will.topic)\n writeStringOrBuffer(stream, will.payload)\n }\n\n // Username and password\n if (username != null) {\n writeStringOrBuffer(stream, username)\n }\n if (password != null) {\n writeStringOrBuffer(stream, password)\n }\n // This is a small packet that happens only once on a stream\n // We assume the stream is always free to receive more data after this\n return true\n}\n\nfunction connack (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const rc = version === 5 ? settings.reasonCode : settings.returnCode\n const properties = settings.properties\n let length = 2 // length of rc and sessionHeader\n\n // Check return code\n if (typeof rc !== 'number') {\n stream.emit('error', new Error('Invalid return code'))\n return false\n }\n // mqtt5 properties\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n stream.write(protocol.CONNACK_HEADER)\n // length\n writeVarByteInt(stream, length)\n stream.write(settings.sessionPresent ? protocol.SESSIONPRESENT_HEADER : zeroBuf)\n\n stream.write(Buffer.from([rc]))\n if (propertiesData != null) {\n propertiesData.write()\n }\n return true\n}\n\nfunction publish (packet, stream, opts) {\n debug('publish: packet: %o', packet)\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const qos = settings.qos || 0\n const retain = settings.retain ? protocol.RETAIN_MASK : 0\n const topic = settings.topic\n const payload = settings.payload || empty\n const id = settings.messageId\n const properties = settings.properties\n\n let length = 0\n\n // Topic must be a non-empty string or Buffer\n if (typeof topic === 'string') length += Buffer.byteLength(topic) + 2\n else if (Buffer.isBuffer(topic)) length += topic.length + 2\n else {\n stream.emit('error', new Error('Invalid topic'))\n return false\n }\n\n // Get the payload length\n if (!Buffer.isBuffer(payload)) length += Buffer.byteLength(payload)\n else length += payload.length\n\n // Message ID must a number if qos > 0\n if (qos && typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n } else if (qos) length += 2\n\n // mqtt5 properties\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.PUBLISH_HEADER[qos][settings.dup ? 1 : 0][retain ? 1 : 0])\n\n // Remaining length\n writeVarByteInt(stream, length)\n\n // Topic\n writeNumber(stream, byteLength(topic))\n stream.write(topic)\n\n // Message ID\n if (qos > 0) writeNumber(stream, id)\n\n // Properties\n if (propertiesData != null) {\n propertiesData.write()\n }\n\n // Payload\n debug('publish: payload: %o', payload)\n return stream.write(payload)\n}\n\n/* Puback, pubrec, pubrel and pubcomp */\nfunction confirmation (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const type = settings.cmd || 'puback'\n const id = settings.messageId\n const dup = (settings.dup && type === 'pubrel') ? protocol.DUP_MASK : 0\n let qos = 0\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 3 : 2\n\n if (type === 'pubrel') qos = 1\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n // Confirm should not add empty property length with no properties (rfc 3.4.2.2.1)\n if (typeof properties === 'object') {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n }\n\n // Header\n stream.write(protocol.ACKS[type][qos][dup][0])\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // reason code in header\n if (version === 5) {\n stream.write(Buffer.from([reasonCode]))\n }\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n return true\n}\n\nfunction subscribe (packet, stream, opts) {\n debug('subscribe: packet: ')\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const id = settings.messageId\n const subs = settings.subscriptions\n const properties = settings.properties\n\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n } else length += 2\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Check subscriptions\n if (typeof subs === 'object' && subs.length) {\n for (let i = 0; i < subs.length; i += 1) {\n const itopic = subs[i].topic\n const iqos = subs[i].qos\n\n if (typeof itopic !== 'string') {\n stream.emit('error', new Error('Invalid subscriptions - invalid topic'))\n return false\n }\n if (typeof iqos !== 'number') {\n stream.emit('error', new Error('Invalid subscriptions - invalid qos'))\n return false\n }\n\n if (version === 5) {\n const nl = subs[i].nl || false\n if (typeof nl !== 'boolean') {\n stream.emit('error', new Error('Invalid subscriptions - invalid No Local'))\n return false\n }\n const rap = subs[i].rap || false\n if (typeof rap !== 'boolean') {\n stream.emit('error', new Error('Invalid subscriptions - invalid Retain as Published'))\n return false\n }\n const rh = subs[i].rh || 0\n if (typeof rh !== 'number' || rh > 2) {\n stream.emit('error', new Error('Invalid subscriptions - invalid Retain Handling'))\n return false\n }\n }\n\n length += Buffer.byteLength(itopic) + 2 + 1\n }\n } else {\n stream.emit('error', new Error('Invalid subscriptions'))\n return false\n }\n\n // Generate header\n debug('subscribe: writing to stream: %o', protocol.SUBSCRIBE_HEADER)\n stream.write(protocol.SUBSCRIBE_HEADER[1][dup ? 1 : 0][0])\n\n // Generate length\n writeVarByteInt(stream, length)\n\n // Generate message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n let result = true\n\n // Generate subs\n for (const sub of subs) {\n const jtopic = sub.topic\n const jqos = sub.qos\n const jnl = +sub.nl\n const jrap = +sub.rap\n const jrh = sub.rh\n let joptions\n\n // Write topic string\n writeString(stream, jtopic)\n\n // options process\n joptions = protocol.SUBSCRIBE_OPTIONS_QOS[jqos]\n if (version === 5) {\n joptions |= jnl ? protocol.SUBSCRIBE_OPTIONS_NL : 0\n joptions |= jrap ? protocol.SUBSCRIBE_OPTIONS_RAP : 0\n joptions |= jrh ? protocol.SUBSCRIBE_OPTIONS_RH[jrh] : 0\n }\n // Write options\n result = stream.write(Buffer.from([joptions]))\n }\n\n return result\n}\n\nfunction suback (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const granted = settings.granted\n const properties = settings.properties\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n } else length += 2\n\n // Check granted qos vector\n if (typeof granted === 'object' && granted.length) {\n for (let i = 0; i < granted.length; i += 1) {\n if (typeof granted[i] !== 'number') {\n stream.emit('error', new Error('Invalid qos vector'))\n return false\n }\n length += 1\n }\n } else {\n stream.emit('error', new Error('Invalid qos vector'))\n return false\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // header\n stream.write(protocol.SUBACK_HEADER)\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n return stream.write(Buffer.from(granted))\n}\n\nfunction unsubscribe (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const unsubs = settings.unsubscriptions\n const properties = settings.properties\n\n let length = 0\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n } else {\n length += 2\n }\n // Check unsubs\n if (typeof unsubs === 'object' && unsubs.length) {\n for (let i = 0; i < unsubs.length; i += 1) {\n if (typeof unsubs[i] !== 'string') {\n stream.emit('error', new Error('Invalid unsubscriptions'))\n return false\n }\n length += Buffer.byteLength(unsubs[i]) + 2\n }\n } else {\n stream.emit('error', new Error('Invalid unsubscriptions'))\n return false\n }\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getProperties(stream, properties)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.UNSUBSCRIBE_HEADER[1][dup ? 1 : 0][0])\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n // Unsubs\n let result = true\n for (let j = 0; j < unsubs.length; j++) {\n result = writeString(stream, unsubs[j])\n }\n\n return result\n}\n\nfunction unsuback (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const id = settings.messageId\n const dup = settings.dup ? protocol.DUP_MASK : 0\n const granted = settings.granted\n const properties = settings.properties\n const type = settings.cmd\n const qos = 0\n\n let length = 2\n\n // Check message ID\n if (typeof id !== 'number') {\n stream.emit('error', new Error('Invalid messageId'))\n return false\n }\n\n // Check granted\n if (version === 5) {\n if (typeof granted === 'object' && granted.length) {\n for (let i = 0; i < granted.length; i += 1) {\n if (typeof granted[i] !== 'number') {\n stream.emit('error', new Error('Invalid qos vector'))\n return false\n }\n length += 1\n }\n } else {\n stream.emit('error', new Error('Invalid qos vector'))\n return false\n }\n }\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(protocol.ACKS[type][qos][dup][0])\n\n // Length\n writeVarByteInt(stream, length)\n\n // Message ID\n writeNumber(stream, id)\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n // payload\n if (version === 5) {\n stream.write(Buffer.from(granted))\n }\n return true\n}\n\nfunction emptyPacket (packet, stream, opts) {\n return stream.write(protocol.EMPTY[packet.cmd])\n}\n\nfunction disconnect (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 1 : 0\n\n // properies mqtt 5\n let propertiesData = null\n if (version === 5) {\n propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n }\n\n // Header\n stream.write(Buffer.from([protocol.codes.disconnect << 4]))\n\n // Length\n writeVarByteInt(stream, length)\n\n // reason code in header\n if (version === 5) {\n stream.write(Buffer.from([reasonCode]))\n }\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n\n return true\n}\n\nfunction auth (packet, stream, opts) {\n const version = opts ? opts.protocolVersion : 4\n const settings = packet || {}\n const reasonCode = settings.reasonCode\n const properties = settings.properties\n let length = version === 5 ? 1 : 0\n\n if (version !== 5) stream.emit('error', new Error('Invalid mqtt version for auth packet'))\n\n // properies mqtt 5\n const propertiesData = getPropertiesByMaximumPacketSize(stream, properties, opts, length)\n if (!propertiesData) { return false }\n length += propertiesData.length\n\n // Header\n stream.write(Buffer.from([protocol.codes.auth << 4]))\n\n // Length\n writeVarByteInt(stream, length)\n\n // reason code in header\n stream.write(Buffer.from([reasonCode]))\n\n // properies mqtt 5\n if (propertiesData !== null) {\n propertiesData.write()\n }\n return true\n}\n\n/**\n * writeVarByteInt - write an MQTT style variable byte integer to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <Number> length - length (>0)\n * @returns <Number> number of bytes written\n *\n * @api private\n */\n\nconst varByteIntCache = {}\nfunction writeVarByteInt (stream, num) {\n if (num > protocol.VARBYTEINT_MAX) {\n stream.emit('error', new Error(`Invalid variable byte integer: ${num}`))\n return false\n }\n\n let buffer = varByteIntCache[num]\n\n if (!buffer) {\n buffer = genBufVariableByteInt(num)\n if (num < 16384) varByteIntCache[num] = buffer\n }\n debug('writeVarByteInt: writing to stream: %o', buffer)\n return stream.write(buffer)\n}\n\n/**\n * writeString - write a utf8 string to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> string - string to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\n\nfunction writeString (stream, string) {\n const strlen = Buffer.byteLength(string)\n writeNumber(stream, strlen)\n\n debug('writeString: %s', string)\n return stream.write(string, 'utf8')\n}\n\n/**\n * writeStringPair - write a utf8 string pairs to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <String> name - string name to write\n * @param <String> value - string value to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\nfunction writeStringPair (stream, name, value) {\n writeString(stream, name)\n writeString(stream, value)\n}\n\n/**\n * writeNumber - write a two byte number to the buffer\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> number - number to write\n * @return <Number> number of bytes written\n *\n * @api private\n */\nfunction writeNumberCached (stream, number) {\n debug('writeNumberCached: number: %d', number)\n debug('writeNumberCached: %o', numCache[number])\n return stream.write(numCache[number])\n}\nfunction writeNumberGenerated (stream, number) {\n const generatedNumber = generateNumber(number)\n debug('writeNumberGenerated: %o', generatedNumber)\n return stream.write(generatedNumber)\n}\nfunction write4ByteNumber (stream, number) {\n const generated4ByteBuffer = generate4ByteBuffer(number)\n debug('write4ByteNumber: %o', generated4ByteBuffer)\n return stream.write(generated4ByteBuffer)\n}\n/**\n * writeStringOrBuffer - write a String or Buffer with the its length prefix\n *\n * @param <Buffer> buffer - destination\n * @param <Number> pos - offset\n * @param <String> toWrite - String or Buffer\n * @return <Number> number of bytes written\n */\nfunction writeStringOrBuffer (stream, toWrite) {\n if (typeof toWrite === 'string') {\n writeString(stream, toWrite)\n } else if (toWrite) {\n writeNumber(stream, toWrite.length)\n stream.write(toWrite)\n } else writeNumber(stream, 0)\n}\n\nfunction getProperties (stream, properties) {\n /* connect properties */\n if (typeof properties !== 'object' || properties.length != null) {\n return {\n length: 1,\n write () {\n writeProperties(stream, {}, 0)\n }\n }\n }\n let propertiesLength = 0\n function getLengthProperty (name, value) {\n const type = protocol.propertiesTypes[name]\n let length = 0\n switch (type) {\n case 'byte': {\n if (typeof value !== 'boolean') {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 1\n break\n }\n case 'int8': {\n if (typeof value !== 'number' || value < 0 || value > 0xff) {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 1\n break\n }\n case 'binary': {\n if (value && value === null) {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + Buffer.byteLength(value) + 2\n break\n }\n case 'int16': {\n if (typeof value !== 'number' || value < 0 || value > 0xffff) {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 2\n break\n }\n case 'int32': {\n if (typeof value !== 'number' || value < 0 || value > 0xffffffff) {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 4\n break\n }\n case 'var': {\n // var byte integer is max 24 bits packed in 32 bits\n if (typeof value !== 'number' || value < 0 || value > 0x0fffffff) {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + Buffer.byteLength(genBufVariableByteInt(value))\n break\n }\n case 'string': {\n if (typeof value !== 'string') {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += 1 + 2 + Buffer.byteLength(value.toString())\n break\n }\n case 'pair': {\n if (typeof value !== 'object') {\n stream.emit('error', new Error(`Invalid ${name}: ${value}`))\n return false\n }\n length += Object.getOwnPropertyNames(value).reduce((result, name) => {\n const currentValue = value[name]\n if (Array.isArray(currentValue)) {\n result += currentValue.reduce((currentLength, value) => {\n currentLength += 1 + 2 + Buffer.byteLength(name.toString()) + 2 + Buffer.byteLength(value.toString())\n return currentLength\n }, 0)\n } else {\n result += 1 + 2 + Buffer.byteLength(name.toString()) + 2 + Buffer.byteLength(value[name].toString())\n }\n return result\n }, 0)\n break\n }\n default: {\n stream.emit('error', new Error(`Invalid property ${name}: ${value}`))\n return false\n }\n }\n return length\n }\n if (properties) {\n for (const propName in properties) {\n let propLength = 0\n let propValueLength = 0\n const propValue = properties[propName]\n if (Array.isArray(propValue)) {\n for (let valueIndex = 0; valueIndex < propValue.length; valueIndex++) {\n propValueLength = getLengthProperty(propName, propValue[valueIndex])\n if (!propValueLength) { return false }\n propLength += propValueLength\n }\n } else {\n propValueLength = getLengthProperty(propName, propValue)\n if (!propValueLength) { return false }\n propLength = propValueLength\n }\n if (!propLength) return false\n propertiesLength += propLength\n }\n }\n const propertiesLengthLength = Buffer.byteLength(genBufVariableByteInt(propertiesLength))\n\n return {\n length: propertiesLengthLength + propertiesLength,\n write () {\n writeProperties(stream, properties, propertiesLength)\n }\n }\n}\n\nfunction getPropertiesByMaximumPacketSize (stream, properties, opts, length) {\n const mayEmptyProps = ['reasonString', 'userProperties']\n const maximumPacketSize = opts && opts.properties && opts.properties.maximumPacketSize ? opts.properties.maximumPacketSize : 0\n\n let propertiesData = getProperties(stream, properties)\n if (maximumPacketSize) {\n while (length + propertiesData.length > maximumPacketSize) {\n const currentMayEmptyProp = mayEmptyProps.shift()\n if (currentMayEmptyProp && properties[currentMayEmptyProp]) {\n delete properties[currentMayEmptyProp]\n propertiesData = getProperties(stream, properties)\n } else {\n return false\n }\n }\n }\n return propertiesData\n}\n\nfunction writeProperty (stream, propName, value) {\n const type = protocol.propertiesTypes[propName]\n switch (type) {\n case 'byte': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n stream.write(Buffer.from([+value]))\n break\n }\n case 'int8': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n stream.write(Buffer.from([value]))\n break\n }\n case 'binary': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringOrBuffer(stream, value)\n break\n }\n case 'int16': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeNumber(stream, value)\n break\n }\n case 'int32': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n write4ByteNumber(stream, value)\n break\n }\n case 'var': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeVarByteInt(stream, value)\n break\n }\n case 'string': {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeString(stream, value)\n break\n }\n case 'pair': {\n Object.getOwnPropertyNames(value).forEach(name => {\n const currentValue = value[name]\n if (Array.isArray(currentValue)) {\n currentValue.forEach(value => {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringPair(stream, name.toString(), value.toString())\n })\n } else {\n stream.write(Buffer.from([protocol.properties[propName]]))\n writeStringPair(stream, name.toString(), currentValue.toString())\n }\n })\n break\n }\n default: {\n stream.emit('error', new Error(`Invalid property ${propName} value: ${value}`))\n return false\n }\n }\n}\n\nfunction writeProperties (stream, properties, propertiesLength) {\n /* write properties to stream */\n writeVarByteInt(stream, propertiesLength)\n for (const propName in properties) {\n if (Object.prototype.hasOwnProperty.call(properties, propName) && properties[propName] !== null) {\n const value = properties[propName]\n if (Array.isArray(value)) {\n for (let valueIndex = 0; valueIndex < value.length; valueIndex++) {\n writeProperty(stream, propName, value[valueIndex])\n }\n } else {\n writeProperty(stream, propName, value)\n }\n }\n }\n}\n\nfunction byteLength (bufOrString) {\n if (!bufOrString) return 0\n else if (bufOrString instanceof Buffer) return bufOrString.length\n else return Buffer.byteLength(bufOrString)\n}\n\nfunction isStringOrBuffer (field) {\n return typeof field === 'string' || field instanceof Buffer\n}\n\nmodule.exports = generate\n","const writeToStream = require('./writeToStream')\nconst EventEmitter = require('events')\n\nfunction generate (packet, opts) {\n const stream = new Accumulator()\n writeToStream(packet, stream, opts)\n return stream.concat()\n}\n\nclass Accumulator extends EventEmitter {\n constructor () {\n super()\n this._array = new Array(20)\n this._i = 0\n }\n\n write (chunk) {\n this._array[this._i++] = chunk\n return true\n }\n\n concat () {\n let length = 0\n const lengths = new Array(this._array.length)\n const list = this._array\n let pos = 0\n let i\n\n for (i = 0; i < list.length && list[i] !== undefined; i++) {\n if (typeof list[i] !== 'string') lengths[i] = list[i].length\n else lengths[i] = Buffer.byteLength(list[i])\n\n length += lengths[i]\n }\n\n const result = Buffer.allocUnsafe(length)\n\n for (i = 0; i < list.length && list[i] !== undefined; i++) {\n if (typeof list[i] !== 'string') {\n list[i].copy(result, pos)\n pos += lengths[i]\n } else {\n result.write(list[i], pos)\n pos += lengths[i]\n }\n }\n\n return result\n }\n}\n\nmodule.exports = generate\n","exports.parser = require('./parser').parser\nexports.generate = require('./generate')\nexports.writeToStream = require('./writeToStream')\n","'use strict'\n\n/**\n * DefaultMessageAllocator constructor\n * @constructor\n */\nfunction DefaultMessageIdProvider () {\n if (!(this instanceof DefaultMessageIdProvider)) {\n return new DefaultMessageIdProvider()\n }\n\n /**\n * MessageIDs starting with 1\n * ensure that nextId is min. 1, see https://github.com/mqttjs/MQTT.js/issues/810\n */\n this.nextId = Math.max(1, Math.floor(Math.random() * 65535))\n}\n\n/**\n * allocate\n *\n * Get the next messageId.\n * @return unsigned int\n */\nDefaultMessageIdProvider.prototype.allocate = function () {\n // id becomes current state of this.nextId and increments afterwards\n const id = this.nextId++\n // Ensure 16 bit unsigned int (max 65535, nextId got one higher)\n if (this.nextId === 65536) {\n this.nextId = 1\n }\n return id\n}\n\n/**\n * getLastAllocated\n * Get the last allocated messageId.\n * @return unsigned int\n */\nDefaultMessageIdProvider.prototype.getLastAllocated = function () {\n return (this.nextId === 1) ? 65535 : (this.nextId - 1)\n}\n\n/**\n * register\n * Register messageId. If success return true, otherwise return false.\n * @param { unsigned int } - messageId to register,\n * @return boolean\n */\nDefaultMessageIdProvider.prototype.register = function (messageId) {\n return true\n}\n\n/**\n * deallocate\n * Deallocate messageId.\n * @param { unsigned int } - messageId to deallocate,\n */\nDefaultMessageIdProvider.prototype.deallocate = function (messageId) {\n}\n\n/**\n * clear\n * Deallocate all messageIds.\n */\nDefaultMessageIdProvider.prototype.clear = function () {\n}\n\nmodule.exports = DefaultMessageIdProvider\n","'use strict'\n\nfunction ReInterval (callback, interval, args) {\n var self = this;\n\n this._callback = callback;\n this._args = args;\n\n this._interval = setInterval(callback, interval, this._args);\n\n this.reschedule = function (interval) {\n // if no interval entered, use the interval passed in on creation\n if (!interval)\n interval = self._interval;\n\n if (self._interval)\n clearInterval(self._interval);\n self._interval = setInterval(self._callback, interval, self._args);\n };\n\n this.clear = function () {\n if (self._interval) {\n clearInterval(self._interval);\n self._interval = undefined;\n }\n };\n \n this.destroy = function () {\n if (self._interval) {\n clearInterval(self._interval);\n }\n self._callback = undefined;\n self._interval = undefined;\n self._args = undefined;\n };\n}\n\nfunction reInterval () {\n if (typeof arguments[0] !== 'function')\n throw new Error('callback needed');\n if (typeof arguments[1] !== 'number')\n throw new Error('interval needed');\n\n var args;\n\n if (arguments.length > 0) {\n args = new Array(arguments.length - 2);\n\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 2];\n }\n }\n\n return new ReInterval(arguments[0], arguments[1], args);\n}\n\nmodule.exports = reInterval;\n","'use strict'\nmodule.exports = rfdc\n\nfunction copyBuffer (cur) {\n if (cur instanceof Buffer) {\n return Buffer.from(cur)\n }\n\n return new cur.constructor(cur.buffer.slice(), cur.byteOffset, cur.length)\n}\n\nfunction rfdc (opts) {\n opts = opts || {}\n\n if (opts.circles) return rfdcCircles(opts)\n return opts.proto ? cloneProto : clone\n\n function cloneArray (a, fn) {\n var keys = Object.keys(a)\n var a2 = new Array(keys.length)\n for (var i = 0; i < keys.length; i++) {\n var k = keys[i]\n var cur = a[k]\n if (typeof cur !== 'object' || cur === null) {\n a2[k] = cur\n } else if (cur instanceof Date) {\n a2[k] = new Date(cur)\n } else if (ArrayBuffer.isView(cur)) {\n a2[k] = copyBuffer(cur)\n } else {\n a2[k] = fn(cur)\n }\n }\n return a2\n }\n\n function clone (o) {\n if (typeof o !== 'object' || o === null) return o\n if (o instanceof Date) return new Date(o)\n if (Array.isArray(o)) return cloneArray(o, clone)\n if (o instanceof Map) return new Map(cloneArray(Array.from(o), clone))\n if (o instanceof Set) return new Set(cloneArray(Array.from(o), clone))\n var o2 = {}\n for (var k in o) {\n if (Object.hasOwnProperty.call(o, k) === false) continue\n var cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur instanceof Date) {\n o2[k] = new Date(cur)\n } else if (cur instanceof Map) {\n o2[k] = new Map(cloneArray(Array.from(cur), clone))\n } else if (cur instanceof Set) {\n o2[k] = new Set(cloneArray(Array.from(cur), clone))\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n o2[k] = clone(cur)\n }\n }\n return o2\n }\n\n function cloneProto (o) {\n if (typeof o !== 'object' || o === null) return o\n if (o instanceof Date) return new Date(o)\n if (Array.isArray(o)) return cloneArray(o, cloneProto)\n if (o instanceof Map) return new Map(cloneArray(Array.from(o), cloneProto))\n if (o instanceof Set) return new Set(cloneArray(Array.from(o), cloneProto))\n var o2 = {}\n for (var k in o) {\n var cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur instanceof Date) {\n o2[k] = new Date(cur)\n } else if (cur instanceof Map) {\n o2[k] = new Map(cloneArray(Array.from(cur), cloneProto))\n } else if (cur instanceof Set) {\n o2[k] = new Set(cloneArray(Array.from(cur), cloneProto))\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n o2[k] = cloneProto(cur)\n }\n }\n return o2\n }\n}\n\nfunction rfdcCircles (opts) {\n var refs = []\n var refsNew = []\n\n return opts.proto ? cloneProto : clone\n\n function cloneArray (a, fn) {\n var keys = Object.keys(a)\n var a2 = new Array(keys.length)\n for (var i = 0; i < keys.length; i++) {\n var k = keys[i]\n var cur = a[k]\n if (typeof cur !== 'object' || cur === null) {\n a2[k] = cur\n } else if (cur instanceof Date) {\n a2[k] = new Date(cur)\n } else if (ArrayBuffer.isView(cur)) {\n a2[k] = copyBuffer(cur)\n } else {\n var index = refs.indexOf(cur)\n if (index !== -1) {\n a2[k] = refsNew[index]\n } else {\n a2[k] = fn(cur)\n }\n }\n }\n return a2\n }\n\n function clone (o) {\n if (typeof o !== 'object' || o === null) return o\n if (o instanceof Date) return new Date(o)\n if (Array.isArray(o)) return cloneArray(o, clone)\n if (o instanceof Map) return new Map(cloneArray(Array.from(o), clone))\n if (o instanceof Set) return new Set(cloneArray(Array.from(o), clone))\n var o2 = {}\n refs.push(o)\n refsNew.push(o2)\n for (var k in o) {\n if (Object.hasOwnProperty.call(o, k) === false) continue\n var cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur instanceof Date) {\n o2[k] = new Date(cur)\n } else if (cur instanceof Map) {\n o2[k] = new Map(cloneArray(Array.from(cur), clone))\n } else if (cur instanceof Set) {\n o2[k] = new Set(cloneArray(Array.from(cur), clone))\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n var i = refs.indexOf(cur)\n if (i !== -1) {\n o2[k] = refsNew[i]\n } else {\n o2[k] = clone(cur)\n }\n }\n }\n refs.pop()\n refsNew.pop()\n return o2\n }\n\n function cloneProto (o) {\n if (typeof o !== 'object' || o === null) return o\n if (o instanceof Date) return new Date(o)\n if (Array.isArray(o)) return cloneArray(o, cloneProto)\n if (o instanceof Map) return new Map(cloneArray(Array.from(o), cloneProto))\n if (o instanceof Set) return new Set(cloneArray(Array.from(o), cloneProto))\n var o2 = {}\n refs.push(o)\n refsNew.push(o2)\n for (var k in o) {\n var cur = o[k]\n if (typeof cur !== 'object' || cur === null) {\n o2[k] = cur\n } else if (cur instanceof Date) {\n o2[k] = new Date(cur)\n } else if (cur instanceof Map) {\n o2[k] = new Map(cloneArray(Array.from(cur), cloneProto))\n } else if (cur instanceof Set) {\n o2[k] = new Set(cloneArray(Array.from(cur), cloneProto))\n } else if (ArrayBuffer.isView(cur)) {\n o2[k] = copyBuffer(cur)\n } else {\n var i = refs.indexOf(cur)\n if (i !== -1) {\n o2[k] = refsNew[i]\n } else {\n o2[k] = cloneProto(cur)\n }\n }\n }\n refs.pop()\n refsNew.pop()\n return o2\n }\n}\n","'use strict'\n\nmodule.exports = require('./index.js')()\n","'use strict'\n\n/**\n * Validate a topic to see if it's valid or not.\n * A topic is valid if it follow below rules:\n * - Rule #1: If any part of the topic is not `+` or `#`, then it must not contain `+` and '#'\n * - Rule #2: Part `#` must be located at the end of the mailbox\n *\n * @param {String} topic - A topic\n * @returns {Boolean} If the topic is valid, returns true. Otherwise, returns false.\n */\nfunction validateTopic (topic) {\n const parts = topic.split('/')\n\n for (let i = 0; i < parts.length; i++) {\n if (parts[i] === '+') {\n continue\n }\n\n if (parts[i] === '#') {\n // for Rule #2\n return i === parts.length - 1\n }\n\n if (parts[i].indexOf('+') !== -1 || parts[i].indexOf('#') !== -1) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * Validate an array of topics to see if any of them is valid or not\n * @param {Array} topics - Array of topics\n * @returns {String} If the topics is valid, returns null. Otherwise, returns the invalid one\n */\nfunction validateTopics (topics) {\n if (topics.length === 0) {\n return 'empty_topic_list'\n }\n for (let i = 0; i < topics.length; i++) {\n if (!validateTopic(topics[i])) {\n return topics[i]\n }\n }\n return null\n}\n\nmodule.exports = {\n validateTopics: validateTopics\n}\n","'use strict'\n\n/**\n * Module dependencies\n */\nconst EventEmitter = require('events').EventEmitter\nconst Store = require('./store')\nconst TopicAliasRecv = require('./topic-alias-recv')\nconst TopicAliasSend = require('./topic-alias-send')\nconst mqttPacket = require('mqtt-packet')\nconst DefaultMessageIdProvider = require('./default-message-id-provider')\nconst Writable = require('readable-stream').Writable\nconst inherits = require('inherits')\nconst reInterval = require('reinterval')\nconst clone = require('rfdc/default')\nconst validations = require('./validations')\nconst xtend = require('xtend')\nconst debug = require('debug')('mqttjs:client')\nconst nextTick = process ? process.nextTick : function (callback) { setTimeout(callback, 0) }\nconst setImmediate = global.setImmediate || function (callback) {\n // works in node v0.8\n nextTick(callback)\n}\nconst defaultConnectOptions = {\n keepalive: 60,\n reschedulePings: true,\n protocolId: 'MQTT',\n protocolVersion: 4,\n reconnectPeriod: 1000,\n connectTimeout: 30 * 1000,\n clean: true,\n resubscribe: true\n}\n\nconst socketErrors = [\n 'ECONNREFUSED',\n 'EADDRINUSE',\n 'ECONNRESET',\n 'ENOTFOUND'\n]\n\n// Other Socket Errors: EADDRINUSE, ECONNRESET, ENOTFOUND.\n\nconst errors = {\n 0: '',\n 1: 'Unacceptable protocol version',\n 2: 'Identifier rejected',\n 3: 'Server unavailable',\n 4: 'Bad username or password',\n 5: 'Not authorized',\n 16: 'No matching subscribers',\n 17: 'No subscription existed',\n 128: 'Unspecified error',\n 129: 'Malformed Packet',\n 130: 'Protocol Error',\n 131: 'Implementation specific error',\n 132: 'Unsupported Protocol Version',\n 133: 'Client Identifier not valid',\n 134: 'Bad User Name or Password',\n 135: 'Not authorized',\n 136: 'Server unavailable',\n 137: 'Server busy',\n 138: 'Banned',\n 139: 'Server shutting down',\n 140: 'Bad authentication method',\n 141: 'Keep Alive timeout',\n 142: 'Session taken over',\n 143: 'Topic Filter invalid',\n 144: 'Topic Name invalid',\n 145: 'Packet identifier in use',\n 146: 'Packet Identifier not found',\n 147: 'Receive Maximum exceeded',\n 148: 'Topic Alias invalid',\n 149: 'Packet too large',\n 150: 'Message rate too high',\n 151: 'Quota exceeded',\n 152: 'Administrative action',\n 153: 'Payload format invalid',\n 154: 'Retain not supported',\n 155: 'QoS not supported',\n 156: 'Use another server',\n 157: 'Server moved',\n 158: 'Shared Subscriptions not supported',\n 159: 'Connection rate exceeded',\n 160: 'Maximum connect time',\n 161: 'Subscription Identifiers not supported',\n 162: 'Wildcard Subscriptions not supported'\n}\n\nfunction defaultId () {\n return 'mqttjs_' + Math.random().toString(16).substr(2, 8)\n}\n\nfunction applyTopicAlias (client, packet) {\n if (client.options.protocolVersion === 5) {\n if (packet.cmd === 'publish') {\n let alias\n if (packet.properties) {\n alias = packet.properties.topicAlias\n }\n const topic = packet.topic.toString()\n if (client.topicAliasSend) {\n if (alias) {\n if (topic.length !== 0) {\n // register topic alias\n debug('applyTopicAlias :: register topic: %s - alias: %d', topic, alias)\n if (!client.topicAliasSend.put(topic, alias)) {\n debug('applyTopicAlias :: error out of range. topic: %s - alias: %d', topic, alias)\n return new Error('Sending Topic Alias out of range')\n }\n }\n } else {\n if (topic.length !== 0) {\n if (client.options.autoAssignTopicAlias) {\n alias = client.topicAliasSend.getAliasByTopic(topic)\n if (alias) {\n packet.topic = ''\n packet.properties = { ...(packet.properties), topicAlias: alias }\n debug('applyTopicAlias :: auto assign(use) topic: %s - alias: %d', topic, alias)\n } else {\n alias = client.topicAliasSend.getLruAlias()\n client.topicAliasSend.put(topic, alias)\n packet.properties = { ...(packet.properties), topicAlias: alias }\n debug('applyTopicAlias :: auto assign topic: %s - alias: %d', topic, alias)\n }\n } else if (client.options.autoUseTopicAlias) {\n alias = client.topicAliasSend.getAliasByTopic(topic)\n if (alias) {\n packet.topic = ''\n packet.properties = { ...(packet.properties), topicAlias: alias }\n debug('applyTopicAlias :: auto use topic: %s - alias: %d', topic, alias)\n }\n }\n }\n }\n } else if (alias) {\n debug('applyTopicAlias :: error out of range. topic: %s - alias: %d', topic, alias)\n return new Error('Sending Topic Alias out of range')\n }\n }\n }\n}\n\nfunction removeTopicAliasAndRecoverTopicName (client, packet) {\n let alias\n if (packet.properties) {\n alias = packet.properties.topicAlias\n }\n\n let topic = packet.topic.toString()\n if (topic.length === 0) {\n // restore topic from alias\n if (typeof alias === 'undefined') {\n return new Error('Unregistered Topic Alias')\n } else {\n topic = client.topicAliasSend.getTopicByAlias(alias)\n if (typeof topic === 'undefined') {\n return new Error('Unregistered Topic Alias')\n } else {\n packet.topic = topic\n }\n }\n }\n if (alias) {\n delete packet.properties.topicAlias\n }\n}\n\nfunction sendPacket (client, packet, cb) {\n debug('sendPacket :: packet: %O', packet)\n debug('sendPacket :: emitting `packetsend`')\n\n client.emit('packetsend', packet)\n\n debug('sendPacket :: writing to stream')\n const result = mqttPacket.writeToStream(packet, client.stream, client.options)\n debug('sendPacket :: writeToStream result %s', result)\n if (!result && cb && cb !== nop) {\n debug('sendPacket :: handle events on `drain` once through callback.')\n client.stream.once('drain', cb)\n } else if (cb) {\n debug('sendPacket :: invoking cb')\n cb()\n }\n}\n\nfunction flush (queue) {\n if (queue) {\n debug('flush: queue exists? %b', !!(queue))\n Object.keys(queue).forEach(function (messageId) {\n if (typeof queue[messageId].cb === 'function') {\n queue[messageId].cb(new Error('Connection closed'))\n // This is suspicious. Why do we only delete this if we have a callbck?\n // If this is by-design, then adding no as callback would cause this to get deleted unintentionally.\n delete queue[messageId]\n }\n })\n }\n}\n\nfunction flushVolatile (queue) {\n if (queue) {\n debug('flushVolatile :: deleting volatile messages from the queue and setting their callbacks as error function')\n Object.keys(queue).forEach(function (messageId) {\n if (queue[messageId].volatile && typeof queue[messageId].cb === 'function') {\n queue[messageId].cb(new Error('Connection closed'))\n delete queue[messageId]\n }\n })\n }\n}\n\nfunction storeAndSend (client, packet, cb, cbStorePut) {\n debug('storeAndSend :: store packet with cmd %s to outgoingStore', packet.cmd)\n let storePacket = packet\n let err\n if (storePacket.cmd === 'publish') {\n // The original packet is for sending.\n // The cloned storePacket is for storing to resend on reconnect.\n // Topic Alias must not be used after disconnected.\n storePacket = clone(packet)\n err = removeTopicAliasAndRecoverTopicName(client, storePacket)\n if (err) {\n return cb && cb(err)\n }\n }\n client.outgoingStore.put(storePacket, function storedPacket (err) {\n if (err) {\n return cb && cb(err)\n }\n cbStorePut()\n sendPacket(client, packet, cb)\n })\n}\n\nfunction nop (error) {\n debug('nop ::', error)\n}\n\n/**\n * MqttClient constructor\n *\n * @param {Stream} stream - stream\n * @param {Object} [options] - connection options\n * (see Connection#connect)\n */\nfunction MqttClient (streamBuilder, options) {\n let k\n const that = this\n\n if (!(this instanceof MqttClient)) {\n return new MqttClient(streamBuilder, options)\n }\n\n this.options = options || {}\n\n // Defaults\n for (k in defaultConnectOptions) {\n if (typeof this.options[k] === 'undefined') {\n this.options[k] = defaultConnectOptions[k]\n } else {\n this.options[k] = options[k]\n }\n }\n\n debug('MqttClient :: options.protocol', options.protocol)\n debug('MqttClient :: options.protocolVersion', options.protocolVersion)\n debug('MqttClient :: options.username', options.username)\n debug('MqttClient :: options.keepalive', options.keepalive)\n debug('MqttClient :: options.reconnectPeriod', options.reconnectPeriod)\n debug('MqttClient :: options.rejectUnauthorized', options.rejectUnauthorized)\n debug('MqttClient :: options.topicAliasMaximum', options.topicAliasMaximum)\n\n this.options.clientId = (typeof options.clientId === 'string') ? options.clientId : defaultId()\n\n debug('MqttClient :: clientId', this.options.clientId)\n\n this.options.customHandleAcks = (options.protocolVersion === 5 && options.customHandleAcks) ? options.customHandleAcks : function () { arguments[3](0) }\n\n this.streamBuilder = streamBuilder\n\n this.messageIdProvider = (typeof this.options.messageIdProvider === 'undefined') ? new DefaultMessageIdProvider() : this.options.messageIdProvider\n\n // Inflight message storages\n this.outgoingStore = options.outgoingStore || new Store()\n this.incomingStore = options.incomingStore || new Store()\n\n // Should QoS zero messages be queued when the connection is broken?\n this.queueQoSZero = options.queueQoSZero === undefined ? true : options.queueQoSZero\n\n // map of subscribed topics to support reconnection\n this._resubscribeTopics = {}\n\n // map of a subscribe messageId and a topic\n this.messageIdToTopic = {}\n\n // Ping timer, setup in _setupPingTimer\n this.pingTimer = null\n // Is the client connected?\n this.connected = false\n // Are we disconnecting?\n this.disconnecting = false\n // Packet queue\n this.queue = []\n // connack timer\n this.connackTimer = null\n // Reconnect timer\n this.reconnectTimer = null\n // Is processing store?\n this._storeProcessing = false\n // Packet Ids are put into the store during store processing\n this._packetIdsDuringStoreProcessing = {}\n // Store processing queue\n this._storeProcessingQueue = []\n\n // Inflight callbacks\n this.outgoing = {}\n\n // True if connection is first time.\n this._firstConnection = true\n\n if (options.topicAliasMaximum > 0) {\n if (options.topicAliasMaximum > 0xffff) {\n debug('MqttClient :: options.topicAliasMaximum is out of range')\n } else {\n this.topicAliasRecv = new TopicAliasRecv(options.topicAliasMaximum)\n }\n }\n\n // Send queued packets\n this.on('connect', function () {\n const queue = this.queue\n\n function deliver () {\n const entry = queue.shift()\n debug('deliver :: entry %o', entry)\n let packet = null\n\n if (!entry) {\n that._resubscribe()\n return\n }\n\n packet = entry.packet\n debug('deliver :: call _sendPacket for %o', packet)\n let send = true\n if (packet.messageId && packet.messageId !== 0) {\n if (!that.messageIdProvider.register(packet.messageId)) {\n send = false\n }\n }\n if (send) {\n that._sendPacket(\n packet,\n function (err) {\n if (entry.cb) {\n entry.cb(err)\n }\n deliver()\n }\n )\n } else {\n debug('messageId: %d has already used. The message is skipped and removed.', packet.messageId)\n deliver()\n }\n }\n\n debug('connect :: sending queued packets')\n deliver()\n })\n\n this.on('close', function () {\n debug('close :: connected set to `false`')\n this.connected = false\n\n debug('close :: clearing connackTimer')\n clearTimeout(this.connackTimer)\n\n debug('close :: clearing ping timer')\n if (that.pingTimer !== null) {\n that.pingTimer.clear()\n that.pingTimer = null\n }\n\n if (this.topicAliasRecv) {\n this.topicAliasRecv.clear()\n }\n\n debug('close :: calling _setupReconnect')\n this._setupReconnect()\n })\n EventEmitter.call(this)\n\n debug('MqttClient :: setting up stream')\n this._setupStream()\n}\ninherits(MqttClient, EventEmitter)\n\n/**\n * setup the event handlers in the inner stream.\n *\n * @api private\n */\nMqttClient.prototype._setupStream = function () {\n const that = this\n const writable = new Writable()\n const parser = mqttPacket.parser(this.options)\n let completeParse = null\n const packets = []\n\n debug('_setupStream :: calling method to clear reconnect')\n this._clearReconnect()\n\n debug('_setupStream :: using streamBuilder provided to client to create stream')\n this.stream = this.streamBuilder(this)\n\n parser.on('packet', function (packet) {\n debug('parser :: on packet push to packets array.')\n packets.push(packet)\n })\n\n function nextTickWork () {\n if (packets.length) {\n nextTick(work)\n } else {\n const done = completeParse\n completeParse = null\n done()\n }\n }\n\n function work () {\n debug('work :: getting next packet in queue')\n const packet = packets.shift()\n\n if (packet) {\n debug('work :: packet pulled from queue')\n that._handlePacket(packet, nextTickWork)\n } else {\n debug('work :: no packets in queue')\n const done = completeParse\n completeParse = null\n debug('work :: done flag is %s', !!(done))\n if (done) done()\n }\n }\n\n writable._write = function (buf, enc, done) {\n completeParse = done\n debug('writable stream :: parsing buffer')\n parser.parse(buf)\n work()\n }\n\n function streamErrorHandler (error) {\n debug('streamErrorHandler :: error', error.message)\n if (socketErrors.includes(error.code)) {\n // handle error\n debug('streamErrorHandler :: emitting error')\n that.emit('error', error)\n } else {\n nop(error)\n }\n }\n\n debug('_setupStream :: pipe stream to writable stream')\n this.stream.pipe(writable)\n\n // Suppress connection errors\n this.stream.on('error', streamErrorHandler)\n\n // Echo stream close\n this.stream.on('close', function () {\n debug('(%s)stream :: on close', that.options.clientId)\n flushVolatile(that.outgoing)\n debug('stream: emit close to MqttClient')\n that.emit('close')\n })\n\n // Send a connect packet\n debug('_setupStream: sending packet `connect`')\n const connectPacket = Object.create(this.options)\n connectPacket.cmd = 'connect'\n if (this.topicAliasRecv) {\n if (!connectPacket.properties) {\n connectPacket.properties = {}\n }\n if (this.topicAliasRecv) {\n connectPacket.properties.topicAliasMaximum = this.topicAliasRecv.max\n }\n }\n // avoid message queue\n sendPacket(this, connectPacket)\n\n // Echo connection errors\n parser.on('error', this.emit.bind(this, 'error'))\n\n // auth\n if (this.options.properties) {\n if (!this.options.properties.authenticationMethod && this.options.properties.authenticationData) {\n that.end(() =>\n this.emit('error', new Error('Packet has no Authentication Method')\n ))\n return this\n }\n if (this.options.properties.authenticationMethod && this.options.authPacket && typeof this.options.authPacket === 'object') {\n const authPacket = xtend({ cmd: 'auth', reasonCode: 0 }, this.options.authPacket)\n sendPacket(this, authPacket)\n }\n }\n\n // many drain listeners are needed for qos 1 callbacks if the connection is intermittent\n this.stream.setMaxListeners(1000)\n\n clearTimeout(this.connackTimer)\n this.connackTimer = setTimeout(function () {\n debug('!!connectTimeout hit!! Calling _cleanUp with force `true`')\n that._cleanUp(true)\n }, this.options.connectTimeout)\n}\n\nMqttClient.prototype._handlePacket = function (packet, done) {\n const options = this.options\n\n if (options.protocolVersion === 5 && options.properties && options.properties.maximumPacketSize && options.properties.maximumPacketSize < packet.length) {\n this.emit('error', new Error('exceeding packets size ' + packet.cmd))\n this.end({ reasonCode: 149, properties: { reasonString: 'Maximum packet size was exceeded' } })\n return this\n }\n debug('_handlePacket :: emitting packetreceive')\n this.emit('packetreceive', packet)\n\n switch (packet.cmd) {\n case 'publish':\n this._handlePublish(packet, done)\n break\n case 'puback':\n case 'pubrec':\n case 'pubcomp':\n case 'suback':\n case 'unsuback':\n this._handleAck(packet)\n done()\n break\n case 'pubrel':\n this._handlePubrel(packet, done)\n break\n case 'connack':\n this._handleConnack(packet)\n done()\n break\n case 'auth':\n this._handleAuth(packet)\n done()\n break\n case 'pingresp':\n this._handlePingresp(packet)\n done()\n break\n case 'disconnect':\n this._handleDisconnect(packet)\n done()\n break\n default:\n // do nothing\n // maybe we should do an error handling\n // or just log it\n break\n }\n}\n\nMqttClient.prototype._checkDisconnecting = function (callback) {\n if (this.disconnecting) {\n if (callback && callback !== nop) {\n callback(new Error('client disconnecting'))\n } else {\n this.emit('error', new Error('client disconnecting'))\n }\n }\n return this.disconnecting\n}\n\n/**\n * publish - publish <message> to <topic>\n *\n * @param {String} topic - topic to publish to\n * @param {String, Buffer} message - message to publish\n * @param {Object} [opts] - publish options, includes:\n * {Number} qos - qos level to publish on\n * {Boolean} retain - whether or not to retain the message\n * {Boolean} dup - whether or not mark a message as duplicate\n * {Function} cbStorePut - function(){} called when message is put into `outgoingStore`\n * @param {Function} [callback] - function(err){}\n * called when publish succeeds or fails\n * @returns {MqttClient} this - for chaining\n * @api public\n *\n * @example client.publish('topic', 'message');\n * @example\n * client.publish('topic', 'message', {qos: 1, retain: true, dup: true});\n * @example client.publish('topic', 'message', console.log);\n */\nMqttClient.prototype.publish = function (topic, message, opts, callback) {\n debug('publish :: message `%s` to topic `%s`', message, topic)\n const options = this.options\n\n // .publish(topic, payload, cb);\n if (typeof opts === 'function') {\n callback = opts\n opts = null\n }\n\n // default opts\n const defaultOpts = { qos: 0, retain: false, dup: false }\n opts = xtend(defaultOpts, opts)\n\n if (this._checkDisconnecting(callback)) {\n return this\n }\n\n const that = this\n const publishProc = function () {\n let messageId = 0\n if (opts.qos === 1 || opts.qos === 2) {\n messageId = that._nextId()\n if (messageId === null) {\n debug('No messageId left')\n return false\n }\n }\n const packet = {\n cmd: 'publish',\n topic: topic,\n payload: message,\n qos: opts.qos,\n retain: opts.retain,\n messageId: messageId,\n dup: opts.dup\n }\n\n if (options.protocolVersion === 5) {\n packet.properties = opts.properties\n }\n\n debug('publish :: qos', opts.qos)\n switch (opts.qos) {\n case 1:\n case 2:\n // Add to callbacks\n that.outgoing[packet.messageId] = {\n volatile: false,\n cb: callback || nop\n }\n debug('MqttClient:publish: packet cmd: %s', packet.cmd)\n that._sendPacket(packet, undefined, opts.cbStorePut)\n break\n default:\n debug('MqttClient:publish: packet cmd: %s', packet.cmd)\n that._sendPacket(packet, callback, opts.cbStorePut)\n break\n }\n return true\n }\n\n if (this._storeProcessing || this._storeProcessingQueue.length > 0 || !publishProc()) {\n this._storeProcessingQueue.push(\n {\n invoke: publishProc,\n cbStorePut: opts.cbStorePut,\n callback: callback\n }\n )\n }\n return this\n}\n\n/**\n * subscribe - subscribe to <topic>\n *\n * @param {String, Array, Object} topic - topic(s) to subscribe to, supports objects in the form {'topic': qos}\n * @param {Object} [opts] - optional subscription options, includes:\n * {Number} qos - subscribe qos level\n * @param {Function} [callback] - function(err, granted){} where:\n * {Error} err - subscription error (none at the moment!)\n * {Array} granted - array of {topic: 't', qos: 0}\n * @returns {MqttClient} this - for chaining\n * @api public\n * @example client.subscribe('topic');\n * @example client.subscribe('topic', {qos: 1});\n * @example client.subscribe({'topic': {qos: 0}, 'topic2': {qos: 1}}, console.log);\n * @example client.subscribe('topic', console.log);\n */\nMqttClient.prototype.subscribe = function () {\n const that = this\n const args = new Array(arguments.length)\n for (let i = 0; i < arguments.length; i++) {\n args[i] = arguments[i]\n }\n const subs = []\n let obj = args.shift()\n const resubscribe = obj.resubscribe\n let callback = args.pop() || nop\n let opts = args.pop()\n const version = this.options.protocolVersion\n\n delete obj.resubscribe\n\n if (typeof obj === 'string') {\n obj = [obj]\n }\n\n if (typeof callback !== 'function') {\n opts = callback\n callback = nop\n }\n\n const invalidTopic = validations.validateTopics(obj)\n if (invalidTopic !== null) {\n setImmediate(callback, new Error('Invalid topic ' + invalidTopic))\n return this\n }\n\n if (this._checkDisconnecting(callback)) {\n debug('subscribe: discconecting true')\n return this\n }\n\n const defaultOpts = {\n qos: 0\n }\n if (version === 5) {\n defaultOpts.nl = false\n defaultOpts.rap = false\n defaultOpts.rh = 0\n }\n opts = xtend(defaultOpts, opts)\n\n if (Array.isArray(obj)) {\n obj.forEach(function (topic) {\n debug('subscribe: array topic %s', topic)\n if (!Object.prototype.hasOwnProperty.call(that._resubscribeTopics, topic) ||\n that._resubscribeTopics[topic].qos < opts.qos ||\n resubscribe) {\n const currentOpts = {\n topic: topic,\n qos: opts.qos\n }\n if (version === 5) {\n currentOpts.nl = opts.nl\n currentOpts.rap = opts.rap\n currentOpts.rh = opts.rh\n currentOpts.properties = opts.properties\n }\n debug('subscribe: pushing topic `%s` and qos `%s` to subs list', currentOpts.topic, currentOpts.qos)\n subs.push(currentOpts)\n }\n })\n } else {\n Object\n .keys(obj)\n .forEach(function (k) {\n debug('subscribe: object topic %s', k)\n if (!Object.prototype.hasOwnProperty.call(that._resubscribeTopics, k) ||\n that._resubscribeTopics[k].qos < obj[k].qos ||\n resubscribe) {\n const currentOpts = {\n topic: k,\n qos: obj[k].qos\n }\n if (version === 5) {\n currentOpts.nl = obj[k].nl\n currentOpts.rap = obj[k].rap\n currentOpts.rh = obj[k].rh\n currentOpts.properties = opts.properties\n }\n debug('subscribe: pushing `%s` to subs list', currentOpts)\n subs.push(currentOpts)\n }\n })\n }\n\n if (!subs.length) {\n callback(null, [])\n return this\n }\n\n const subscribeProc = function () {\n const messageId = that._nextId()\n if (messageId === null) {\n debug('No messageId left')\n return false\n }\n\n const packet = {\n cmd: 'subscribe',\n subscriptions: subs,\n qos: 1,\n retain: false,\n dup: false,\n messageId: messageId\n }\n\n if (opts.properties) {\n packet.properties = opts.properties\n }\n\n // subscriptions to resubscribe to in case of disconnect\n if (that.options.resubscribe) {\n debug('subscribe :: resubscribe true')\n const topics = []\n subs.forEach(function (sub) {\n if (that.options.reconnectPeriod > 0) {\n const topic = { qos: sub.qos }\n if (version === 5) {\n topic.nl = sub.nl || false\n topic.rap = sub.rap || false\n topic.rh = sub.rh || 0\n topic.properties = sub.properties\n }\n that._resubscribeTopics[sub.topic] = topic\n topics.push(sub.topic)\n }\n })\n that.messageIdToTopic[packet.messageId] = topics\n }\n\n that.outgoing[packet.messageId] = {\n volatile: true,\n cb: function (err, packet) {\n if (!err) {\n const granted = packet.granted\n for (let i = 0; i < granted.length; i += 1) {\n subs[i].qos = granted[i]\n }\n }\n\n callback(err, subs)\n }\n }\n debug('subscribe :: call _sendPacket')\n that._sendPacket(packet)\n return true\n }\n\n if (this._storeProcessing || this._storeProcessingQueue.length > 0 || !subscribeProc()) {\n this._storeProcessingQueue.push(\n {\n invoke: subscribeProc,\n callback: callback\n }\n )\n }\n\n return this\n}\n\n/**\n * unsubscribe - unsubscribe from topic(s)\n *\n * @param {String, Array} topic - topics to unsubscribe from\n * @param {Object} [opts] - optional subscription options, includes:\n * {Object} properties - properties of unsubscribe packet\n * @param {Function} [callback] - callback fired on unsuback\n * @returns {MqttClient} this - for chaining\n * @api public\n * @example client.unsubscribe('topic');\n * @example client.unsubscribe('topic', console.log);\n */\nMqttClient.prototype.unsubscribe = function () {\n const that = this\n const args = new Array(arguments.length)\n for (let i = 0; i < arguments.length; i++) {\n args[i] = arguments[i]\n }\n let topic = args.shift()\n let callback = args.pop() || nop\n let opts = args.pop()\n if (typeof topic === 'string') {\n topic = [topic]\n }\n\n if (typeof callback !== 'function') {\n opts = callback\n callback = nop\n }\n\n const invalidTopic = validations.validateTopics(topic)\n if (invalidTopic !== null) {\n setImmediate(callback, new Error('Invalid topic ' + invalidTopic))\n return this\n }\n\n if (that._checkDisconnecting(callback)) {\n return this\n }\n\n const unsubscribeProc = function () {\n const messageId = that._nextId()\n if (messageId === null) {\n debug('No messageId left')\n return false\n }\n const packet = {\n cmd: 'unsubscribe',\n qos: 1,\n messageId: messageId\n }\n\n if (typeof topic === 'string') {\n packet.unsubscriptions = [topic]\n } else if (Array.isArray(topic)) {\n packet.unsubscriptions = topic\n }\n\n if (that.options.resubscribe) {\n packet.unsubscriptions.forEach(function (topic) {\n delete that._resubscribeTopics[topic]\n })\n }\n\n if (typeof opts === 'object' && opts.properties) {\n packet.properties = opts.properties\n }\n\n that.outgoing[packet.messageId] = {\n volatile: true,\n cb: callback\n }\n\n debug('unsubscribe: call _sendPacket')\n that._sendPacket(packet)\n\n return true\n }\n\n if (this._storeProcessing || this._storeProcessingQueue.length > 0 || !unsubscribeProc()) {\n this._storeProcessingQueue.push(\n {\n invoke: unsubscribeProc,\n callback: callback\n }\n )\n }\n\n return this\n}\n\n/**\n * end - close connection\n *\n * @returns {MqttClient} this - for chaining\n * @param {Boolean} force - do not wait for all in-flight messages to be acked\n * @param {Object} opts - added to the disconnect packet\n * @param {Function} cb - called when the client has been closed\n *\n * @api public\n */\nMqttClient.prototype.end = function (force, opts, cb) {\n const that = this\n\n debug('end :: (%s)', this.options.clientId)\n\n if (force == null || typeof force !== 'boolean') {\n cb = opts || nop\n opts = force\n force = false\n if (typeof opts !== 'object') {\n cb = opts\n opts = null\n if (typeof cb !== 'function') {\n cb = nop\n }\n }\n }\n\n if (typeof opts !== 'object') {\n cb = opts\n opts = null\n }\n\n debug('end :: cb? %s', !!cb)\n cb = cb || nop\n\n function closeStores () {\n debug('end :: closeStores: closing incoming and outgoing stores')\n that.disconnected = true\n that.incomingStore.close(function (e1) {\n that.outgoingStore.close(function (e2) {\n debug('end :: closeStores: emitting end')\n that.emit('end')\n if (cb) {\n const err = e1 || e2\n debug('end :: closeStores: invoking callback with args')\n cb(err)\n }\n })\n })\n if (that._deferredReconnect) {\n that._deferredReconnect()\n }\n }\n\n function finish () {\n // defer closesStores of an I/O cycle,\n // just to make sure things are\n // ok for websockets\n debug('end :: (%s) :: finish :: calling _cleanUp with force %s', that.options.clientId, force)\n that._cleanUp(force, () => {\n debug('end :: finish :: calling process.nextTick on closeStores')\n // const boundProcess = nextTick.bind(null, closeStores)\n nextTick(closeStores.bind(that))\n }, opts)\n }\n\n if (this.disconnecting) {\n cb()\n return this\n }\n\n this._clearReconnect()\n\n this.disconnecting = true\n\n if (!force && Object.keys(this.outgoing).length > 0) {\n // wait 10ms, just to be sure we received all of it\n debug('end :: (%s) :: calling finish in 10ms once outgoing is empty', that.options.clientId)\n this.once('outgoingEmpty', setTimeout.bind(null, finish, 10))\n } else {\n debug('end :: (%s) :: immediately calling finish', that.options.clientId)\n finish()\n }\n\n return this\n}\n\n/**\n * removeOutgoingMessage - remove a message in outgoing store\n * the outgoing callback will be called withe Error('Message removed') if the message is removed\n *\n * @param {Number} messageId - messageId to remove message\n * @returns {MqttClient} this - for chaining\n * @api public\n *\n * @example client.removeOutgoingMessage(client.getLastAllocated());\n */\nMqttClient.prototype.removeOutgoingMessage = function (messageId) {\n const cb = this.outgoing[messageId] ? this.outgoing[messageId].cb : null\n delete this.outgoing[messageId]\n this.outgoingStore.del({ messageId: messageId }, function () {\n cb(new Error('Message removed'))\n })\n return this\n}\n\n/**\n * reconnect - connect again using the same options as connect()\n *\n * @param {Object} [opts] - optional reconnect options, includes:\n * {Store} incomingStore - a store for the incoming packets\n * {Store} outgoingStore - a store for the outgoing packets\n * if opts is not given, current stores are used\n * @returns {MqttClient} this - for chaining\n *\n * @api public\n */\nMqttClient.prototype.reconnect = function (opts) {\n debug('client reconnect')\n const that = this\n const f = function () {\n if (opts) {\n that.options.incomingStore = opts.incomingStore\n that.options.outgoingStore = opts.outgoingStore\n } else {\n that.options.incomingStore = null\n that.options.outgoingStore = null\n }\n that.incomingStore = that.options.incomingStore || new Store()\n that.outgoingStore = that.options.outgoingStore || new Store()\n that.disconnecting = false\n that.disconnected = false\n that._deferredReconnect = null\n that._reconnect()\n }\n\n if (this.disconnecting && !this.disconnected) {\n this._deferredReconnect = f\n } else {\n f()\n }\n return this\n}\n\n/**\n * _reconnect - implement reconnection\n * @api privateish\n */\nMqttClient.prototype._reconnect = function () {\n debug('_reconnect: emitting reconnect to client')\n this.emit('reconnect')\n if (this.connected) {\n this.end(() => { this._setupStream() })\n debug('client already connected. disconnecting first.')\n } else {\n debug('_reconnect: calling _setupStream')\n this._setupStream()\n }\n}\n\n/**\n * _setupReconnect - setup reconnect timer\n */\nMqttClient.prototype._setupReconnect = function () {\n const that = this\n\n if (!that.disconnecting && !that.reconnectTimer && (that.options.reconnectPeriod > 0)) {\n if (!this.reconnecting) {\n debug('_setupReconnect :: emit `offline` state')\n this.emit('offline')\n debug('_setupReconnect :: set `reconnecting` to `true`')\n this.reconnecting = true\n }\n debug('_setupReconnect :: setting reconnectTimer for %d ms', that.options.reconnectPeriod)\n that.reconnectTimer = setInterval(function () {\n debug('reconnectTimer :: reconnect triggered!')\n that._reconnect()\n }, that.options.reconnectPeriod)\n } else {\n debug('_setupReconnect :: doing nothing...')\n }\n}\n\n/**\n * _clearReconnect - clear the reconnect timer\n */\nMqttClient.prototype._clearReconnect = function () {\n debug('_clearReconnect : clearing reconnect timer')\n if (this.reconnectTimer) {\n clearInterval(this.reconnectTimer)\n this.reconnectTimer = null\n }\n}\n\n/**\n * _cleanUp - clean up on connection end\n * @api private\n */\nMqttClient.prototype._cleanUp = function (forced, done) {\n const opts = arguments[2]\n if (done) {\n debug('_cleanUp :: done callback provided for on stream close')\n this.stream.on('close', done)\n }\n\n debug('_cleanUp :: forced? %s', forced)\n if (forced) {\n if ((this.options.reconnectPeriod === 0) && this.options.clean) {\n flush(this.outgoing)\n }\n debug('_cleanUp :: (%s) :: destroying stream', this.options.clientId)\n this.stream.destroy()\n } else {\n const packet = xtend({ cmd: 'disconnect' }, opts)\n debug('_cleanUp :: (%s) :: call _sendPacket with disconnect packet', this.options.clientId)\n this._sendPacket(\n packet,\n setImmediate.bind(\n null,\n this.stream.end.bind(this.stream)\n )\n )\n }\n\n if (!this.disconnecting) {\n debug('_cleanUp :: client not disconnecting. Clearing and resetting reconnect.')\n this._clearReconnect()\n this._setupReconnect()\n }\n\n if (this.pingTimer !== null) {\n debug('_cleanUp :: clearing pingTimer')\n this.pingTimer.clear()\n this.pingTimer = null\n }\n\n if (done && !this.connected) {\n debug('_cleanUp :: (%s) :: removing stream `done` callback `close` listener', this.options.clientId)\n this.stream.removeListener('close', done)\n done()\n }\n}\n\n/**\n * _sendPacket - send or queue a packet\n * @param {Object} packet - packet options\n * @param {Function} cb - callback when the packet is sent\n * @param {Function} cbStorePut - called when message is put into outgoingStore\n * @api private\n */\nMqttClient.prototype._sendPacket = function (packet, cb, cbStorePut) {\n debug('_sendPacket :: (%s) :: start', this.options.clientId)\n cbStorePut = cbStorePut || nop\n cb = cb || nop\n\n const err = applyTopicAlias(this, packet)\n if (err) {\n cb(err)\n return\n }\n\n if (!this.connected) {\n // allow auth packets to be sent while authenticating with the broker (mqtt5 enhanced auth)\n if (packet.cmd === 'auth') {\n this._shiftPingInterval()\n sendPacket(this, packet, cb)\n return\n }\n\n debug('_sendPacket :: client not connected. Storing packet offline.')\n this._storePacket(packet, cb, cbStorePut)\n return\n }\n\n // When sending a packet, reschedule the ping timer\n this._shiftPingInterval()\n\n switch (packet.cmd) {\n case 'publish':\n break\n case 'pubrel':\n storeAndSend(this, packet, cb, cbStorePut)\n return\n default:\n sendPacket(this, packet, cb)\n return\n }\n\n switch (packet.qos) {\n case 2:\n case 1:\n storeAndSend(this, packet, cb, cbStorePut)\n break\n /**\n * no need of case here since it will be caught by default\n * and jshint comply that before default it must be a break\n * anyway it will result in -1 evaluation\n */\n case 0:\n /* falls through */\n default:\n sendPacket(this, packet, cb)\n break\n }\n debug('_sendPacket :: (%s) :: end', this.options.clientId)\n}\n\n/**\n * _storePacket - queue a packet\n * @param {Object} packet - packet options\n * @param {Function} cb - callback when the packet is sent\n * @param {Function} cbStorePut - called when message is put into outgoingStore\n * @api private\n */\nMqttClient.prototype._storePacket = function (packet, cb, cbStorePut) {\n debug('_storePacket :: packet: %o', packet)\n debug('_storePacket :: cb? %s', !!cb)\n cbStorePut = cbStorePut || nop\n\n let storePacket = packet\n if (storePacket.cmd === 'publish') {\n // The original packet is for sending.\n // The cloned storePacket is for storing to resend on reconnect.\n // Topic Alias must not be used after disconnected.\n storePacket = clone(packet)\n const err = removeTopicAliasAndRecoverTopicName(this, storePacket)\n if (err) {\n return cb && cb(err)\n }\n }\n // check that the packet is not a qos of 0, or that the command is not a publish\n if (((storePacket.qos || 0) === 0 && this.queueQoSZero) || storePacket.cmd !== 'publish') {\n this.queue.push({ packet: storePacket, cb: cb })\n } else if (storePacket.qos > 0) {\n cb = this.outgoing[storePacket.messageId] ? this.outgoing[storePacket.messageId].cb : null\n this.outgoingStore.put(storePacket, function (err) {\n if (err) {\n return cb && cb(err)\n }\n cbStorePut()\n })\n } else if (cb) {\n cb(new Error('No connection to broker'))\n }\n}\n\n/**\n * _setupPingTimer - setup the ping timer\n *\n * @api private\n */\nMqttClient.prototype._setupPingTimer = function () {\n debug('_setupPingTimer :: keepalive %d (seconds)', this.options.keepalive)\n const that = this\n\n if (!this.pingTimer && this.options.keepalive) {\n this.pingResp = true\n this.pingTimer = reInterval(function () {\n that._checkPing()\n }, this.options.keepalive * 1000)\n }\n}\n\n/**\n * _shiftPingInterval - reschedule the ping interval\n *\n * @api private\n */\nMqttClient.prototype._shiftPingInterval = function () {\n if (this.pingTimer && this.options.keepalive && this.options.reschedulePings) {\n this.pingTimer.reschedule(this.options.keepalive * 1000)\n }\n}\n/**\n * _checkPing - check if a pingresp has come back, and ping the server again\n *\n * @api private\n */\nMqttClient.prototype._checkPing = function () {\n debug('_checkPing :: checking ping...')\n if (this.pingResp) {\n debug('_checkPing :: ping response received. Clearing flag and sending `pingreq`')\n this.pingResp = false\n this._sendPacket({ cmd: 'pingreq' })\n } else {\n // do a forced cleanup since socket will be in bad shape\n debug('_checkPing :: calling _cleanUp with force true')\n this._cleanUp(true)\n }\n}\n\n/**\n * _handlePingresp - handle a pingresp\n *\n * @api private\n */\nMqttClient.prototype._handlePingresp = function () {\n this.pingResp = true\n}\n\n/**\n * _handleConnack\n *\n * @param {Object} packet\n * @api private\n */\nMqttClient.prototype._handleConnack = function (packet) {\n debug('_handleConnack')\n const options = this.options\n const version = options.protocolVersion\n const rc = version === 5 ? packet.reasonCode : packet.returnCode\n\n clearTimeout(this.connackTimer)\n delete this.topicAliasSend\n\n if (packet.properties) {\n if (packet.properties.topicAliasMaximum) {\n if (packet.properties.topicAliasMaximum > 0xffff) {\n this.emit('error', new Error('topicAliasMaximum from broker is out of range'))\n return\n }\n if (packet.properties.topicAliasMaximum > 0) {\n this.topicAliasSend = new TopicAliasSend(packet.properties.topicAliasMaximum)\n }\n }\n if (packet.properties.serverKeepAlive && options.keepalive) {\n options.keepalive = packet.properties.serverKeepAlive\n this._shiftPingInterval()\n }\n if (packet.properties.maximumPacketSize) {\n if (!options.properties) { options.properties = {} }\n options.properties.maximumPacketSize = packet.properties.maximumPacketSize\n }\n }\n\n if (rc === 0) {\n this.reconnecting = false\n this._onConnect(packet)\n } else if (rc > 0) {\n const err = new Error('Connection refused: ' + errors[rc])\n err.code = rc\n this.emit('error', err)\n }\n}\n\nMqttClient.prototype._handleAuth = function (packet) {\n const options = this.options\n const version = options.protocolVersion\n const rc = version === 5 ? packet.reasonCode : packet.returnCode\n\n if (version !== 5) {\n const err = new Error('Protocol error: Auth packets are only supported in MQTT 5. Your version:' + version)\n err.code = rc\n this.emit('error', err)\n return\n }\n\n const that = this\n this.handleAuth(packet, function (err, packet) {\n if (err) {\n that.emit('error', err)\n return\n }\n\n if (rc === 24) {\n that.reconnecting = false\n that._sendPacket(packet)\n } else {\n const error = new Error('Connection refused: ' + errors[rc])\n err.code = rc\n that.emit('error', error)\n }\n })\n}\n\n/**\n * @param packet the packet received by the broker\n * @return the auth packet to be returned to the broker\n * @api public\n */\nMqttClient.prototype.handleAuth = function (packet, callback) {\n callback()\n}\n\n/**\n * _handlePublish\n *\n * @param {Object} packet\n * @api private\n */\n/*\nthose late 2 case should be rewrite to comply with coding style:\n\ncase 1:\ncase 0:\n // do not wait sending a puback\n // no callback passed\n if (1 === qos) {\n this._sendPacket({\n cmd: 'puback',\n messageId: messageId\n });\n }\n // emit the message event for both qos 1 and 0\n this.emit('message', topic, message, packet);\n this.handleMessage(packet, done);\n break;\ndefault:\n // do nothing but every switch mus have a default\n // log or throw an error about unknown qos\n break;\n\nfor now i just suppressed the warnings\n*/\nMqttClient.prototype._handlePublish = function (packet, done) {\n debug('_handlePublish: packet %o', packet)\n done = typeof done !== 'undefined' ? done : nop\n let topic = packet.topic.toString()\n const message = packet.payload\n const qos = packet.qos\n const messageId = packet.messageId\n const that = this\n const options = this.options\n const validReasonCodes = [0, 16, 128, 131, 135, 144, 145, 151, 153]\n if (this.options.protocolVersion === 5) {\n let alias\n if (packet.properties) {\n alias = packet.properties.topicAlias\n }\n if (typeof alias !== 'undefined') {\n if (topic.length === 0) {\n if (alias > 0 && alias <= 0xffff) {\n const gotTopic = this.topicAliasRecv.getTopicByAlias(alias)\n if (gotTopic) {\n topic = gotTopic\n debug('_handlePublish :: topic complemented by alias. topic: %s - alias: %d', topic, alias)\n } else {\n debug('_handlePublish :: unregistered topic alias. alias: %d', alias)\n this.emit('error', new Error('Received unregistered Topic Alias'))\n return\n }\n } else {\n debug('_handlePublish :: topic alias out of range. alias: %d', alias)\n this.emit('error', new Error('Received Topic Alias is out of range'))\n return\n }\n } else {\n if (this.topicAliasRecv.put(topic, alias)) {\n debug('_handlePublish :: registered topic: %s - alias: %d', topic, alias)\n } else {\n debug('_handlePublish :: topic alias out of range. alias: %d', alias)\n this.emit('error', new Error('Received Topic Alias is out of range'))\n return\n }\n }\n }\n }\n debug('_handlePublish: qos %d', qos)\n switch (qos) {\n case 2: {\n options.customHandleAcks(topic, message, packet, function (error, code) {\n if (!(error instanceof Error)) {\n code = error\n error = null\n }\n if (error) { return that.emit('error', error) }\n if (validReasonCodes.indexOf(code) === -1) { return that.emit('error', new Error('Wrong reason code for pubrec')) }\n if (code) {\n that._sendPacket({ cmd: 'pubrec', messageId: messageId, reasonCode: code }, done)\n } else {\n that.incomingStore.put(packet, function () {\n that._sendPacket({ cmd: 'pubrec', messageId: messageId }, done)\n })\n }\n })\n break\n }\n case 1: {\n // emit the message event\n options.customHandleAcks(topic, message, packet, function (error, code) {\n if (!(error instanceof Error)) {\n code = error\n error = null\n }\n if (error) { return that.emit('error', error) }\n if (validReasonCodes.indexOf(code) === -1) { return that.emit('error', new Error('Wrong reason code for puback')) }\n if (!code) { that.emit('message', topic, message, packet) }\n that.handleMessage(packet, function (err) {\n if (err) {\n return done && done(err)\n }\n that._sendPacket({ cmd: 'puback', messageId: messageId, reasonCode: code }, done)\n })\n })\n break\n }\n case 0:\n // emit the message event\n this.emit('message', topic, message, packet)\n this.handleMessage(packet, done)\n break\n default:\n // do nothing\n debug('_handlePublish: unknown QoS. Doing nothing.')\n // log or throw an error about unknown qos\n break\n }\n}\n\n/**\n * Handle messages with backpressure support, one at a time.\n * Override at will.\n *\n * @param Packet packet the packet\n * @param Function callback call when finished\n * @api public\n */\nMqttClient.prototype.handleMessage = function (packet, callback) {\n callback()\n}\n\n/**\n * _handleAck\n *\n * @param {Object} packet\n * @api private\n */\n\nMqttClient.prototype._handleAck = function (packet) {\n /* eslint no-fallthrough: \"off\" */\n const messageId = packet.messageId\n const type = packet.cmd\n let response = null\n const cb = this.outgoing[messageId] ? this.outgoing[messageId].cb : null\n const that = this\n let err\n\n // Checking `!cb` happens to work, but it's not technically \"correct\".\n //\n // Why? This code assumes that \"no callback\" is the same as that \"we're not\n // waiting for responses\" (puback, pubrec, pubcomp, suback, or unsuback).\n //\n // It would be better to check `if (!this.outgoing[messageId])` here, but\n // there's no reason to change it and risk (another) regression.\n //\n // The only reason this code works is becaues code in MqttClient.publish,\n // MqttClinet.subscribe, and MqttClient.unsubscribe ensures that we will\n // have a callback even if the user doesn't pass one in.)\n if (!cb) {\n debug('_handleAck :: Server sent an ack in error. Ignoring.')\n // Server sent an ack in error, ignore it.\n return\n }\n\n // Process\n debug('_handleAck :: packet type', type)\n switch (type) {\n case 'pubcomp':\n // same thing as puback for QoS 2\n case 'puback': {\n const pubackRC = packet.reasonCode\n // Callback - we're done\n if (pubackRC && pubackRC > 0 && pubackRC !== 16) {\n err = new Error('Publish error: ' + errors[pubackRC])\n err.code = pubackRC\n cb(err, packet)\n }\n delete this.outgoing[messageId]\n this.outgoingStore.del(packet, cb)\n this.messageIdProvider.deallocate(messageId)\n this._invokeStoreProcessingQueue()\n break\n }\n case 'pubrec': {\n response = {\n cmd: 'pubrel',\n qos: 2,\n messageId: messageId\n }\n const pubrecRC = packet.reasonCode\n\n if (pubrecRC && pubrecRC > 0 && pubrecRC !== 16) {\n err = new Error('Publish error: ' + errors[pubrecRC])\n err.code = pubrecRC\n cb(err, packet)\n } else {\n this._sendPacket(response)\n }\n break\n }\n case 'suback': {\n delete this.outgoing[messageId]\n this.messageIdProvider.deallocate(messageId)\n for (let grantedI = 0; grantedI < packet.granted.length; grantedI++) {\n if ((packet.granted[grantedI] & 0x80) !== 0) {\n // suback with Failure status\n const topics = this.messageIdToTopic[messageId]\n if (topics) {\n topics.forEach(function (topic) {\n delete that._resubscribeTopics[topic]\n })\n }\n }\n }\n this._invokeStoreProcessingQueue()\n cb(null, packet)\n break\n }\n case 'unsuback': {\n delete this.outgoing[messageId]\n this.messageIdProvider.deallocate(messageId)\n this._invokeStoreProcessingQueue()\n cb(null)\n break\n }\n default:\n that.emit('error', new Error('unrecognized packet type'))\n }\n\n if (this.disconnecting &&\n Object.keys(this.outgoing).length === 0) {\n this.emit('outgoingEmpty')\n }\n}\n\n/**\n * _handlePubrel\n *\n * @param {Object} packet\n * @api private\n */\nMqttClient.prototype._handlePubrel = function (packet, callback) {\n debug('handling pubrel packet')\n callback = typeof callback !== 'undefined' ? callback : nop\n const messageId = packet.messageId\n const that = this\n\n const comp = { cmd: 'pubcomp', messageId: messageId }\n\n that.incomingStore.get(packet, function (err, pub) {\n if (!err) {\n that.emit('message', pub.topic, pub.payload, pub)\n that.handleMessage(pub, function (err) {\n if (err) {\n return callback(err)\n }\n that.incomingStore.del(pub, nop)\n that._sendPacket(comp, callback)\n })\n } else {\n that._sendPacket(comp, callback)\n }\n })\n}\n\n/**\n * _handleDisconnect\n *\n * @param {Object} packet\n * @api private\n */\nMqttClient.prototype._handleDisconnect = function (packet) {\n this.emit('disconnect', packet)\n}\n\n/**\n * _nextId\n * @return unsigned int\n */\nMqttClient.prototype._nextId = function () {\n return this.messageIdProvider.allocate()\n}\n\n/**\n * getLastMessageId\n * @return unsigned int\n */\nMqttClient.prototype.getLastMessageId = function () {\n return this.messageIdProvider.getLastAllocated()\n}\n\n/**\n * _resubscribe\n * @api private\n */\nMqttClient.prototype._resubscribe = function () {\n debug('_resubscribe')\n const _resubscribeTopicsKeys = Object.keys(this._resubscribeTopics)\n if (!this._firstConnection &&\n (this.options.clean || (this.options.protocolVersion === 5 && !this.connackPacket.sessionPresent)) &&\n _resubscribeTopicsKeys.length > 0) {\n if (this.options.resubscribe) {\n if (this.options.protocolVersion === 5) {\n debug('_resubscribe: protocolVersion 5')\n for (let topicI = 0; topicI < _resubscribeTopicsKeys.length; topicI++) {\n const resubscribeTopic = {}\n resubscribeTopic[_resubscribeTopicsKeys[topicI]] = this._resubscribeTopics[_resubscribeTopicsKeys[topicI]]\n resubscribeTopic.resubscribe = true\n this.subscribe(resubscribeTopic, { properties: resubscribeTopic[_resubscribeTopicsKeys[topicI]].properties })\n }\n } else {\n this._resubscribeTopics.resubscribe = true\n this.subscribe(this._resubscribeTopics)\n }\n } else {\n this._resubscribeTopics = {}\n }\n }\n\n this._firstConnection = false\n}\n\n/**\n * _onConnect\n *\n * @api private\n */\nMqttClient.prototype._onConnect = function (packet) {\n if (this.disconnected) {\n this.emit('connect', packet)\n return\n }\n\n const that = this\n\n this.connackPacket = packet\n this.messageIdProvider.clear()\n this._setupPingTimer()\n\n this.connected = true\n\n function startStreamProcess () {\n let outStore = that.outgoingStore.createStream()\n\n function clearStoreProcessing () {\n that._storeProcessing = false\n that._packetIdsDuringStoreProcessing = {}\n }\n\n that.once('close', remove)\n outStore.on('error', function (err) {\n clearStoreProcessing()\n that._flushStoreProcessingQueue()\n that.removeListener('close', remove)\n that.emit('error', err)\n })\n\n function remove () {\n outStore.destroy()\n outStore = null\n that._flushStoreProcessingQueue()\n clearStoreProcessing()\n }\n\n function storeDeliver () {\n // edge case, we wrapped this twice\n if (!outStore) {\n return\n }\n that._storeProcessing = true\n\n const packet = outStore.read(1)\n\n let cb\n\n if (!packet) {\n // read when data is available in the future\n outStore.once('readable', storeDeliver)\n return\n }\n\n // Skip already processed store packets\n if (that._packetIdsDuringStoreProcessing[packet.messageId]) {\n storeDeliver()\n return\n }\n\n // Avoid unnecessary stream read operations when disconnected\n if (!that.disconnecting && !that.reconnectTimer) {\n cb = that.outgoing[packet.messageId] ? that.outgoing[packet.messageId].cb : null\n that.outgoing[packet.messageId] = {\n volatile: false,\n cb: function (err, status) {\n // Ensure that the original callback passed in to publish gets invoked\n if (cb) {\n cb(err, status)\n }\n\n storeDeliver()\n }\n }\n that._packetIdsDuringStoreProcessing[packet.messageId] = true\n if (that.messageIdProvider.register(packet.messageId)) {\n that._sendPacket(packet)\n } else {\n debug('messageId: %d has already used.', packet.messageId)\n }\n } else if (outStore.destroy) {\n outStore.destroy()\n }\n }\n\n outStore.on('end', function () {\n let allProcessed = true\n for (const id in that._packetIdsDuringStoreProcessing) {\n if (!that._packetIdsDuringStoreProcessing[id]) {\n allProcessed = false\n break\n }\n }\n if (allProcessed) {\n clearStoreProcessing()\n that.removeListener('close', remove)\n that._invokeAllStoreProcessingQueue()\n that.emit('connect', packet)\n } else {\n startStreamProcess()\n }\n })\n storeDeliver()\n }\n // start flowing\n startStreamProcess()\n}\n\nMqttClient.prototype._invokeStoreProcessingQueue = function () {\n if (this._storeProcessingQueue.length > 0) {\n const f = this._storeProcessingQueue[0]\n if (f && f.invoke()) {\n this._storeProcessingQueue.shift()\n return true\n }\n }\n return false\n}\n\nMqttClient.prototype._invokeAllStoreProcessingQueue = function () {\n while (this._invokeStoreProcessingQueue()) { /* empty */ }\n}\n\nMqttClient.prototype._flushStoreProcessingQueue = function () {\n for (const f of this._storeProcessingQueue) {\n if (f.cbStorePut) f.cbStorePut(new Error('Connection closed'))\n if (f.callback) f.callback(new Error('Connection closed'))\n }\n this._storeProcessingQueue.splice(0)\n}\n\nmodule.exports = MqttClient\n","'use strict'\nconst net = require('net')\nconst debug = require('debug')('mqttjs:tcp')\n\n/*\n variables port and host can be removed since\n you have all required information in opts object\n*/\nfunction streamBuilder (client, opts) {\n opts.port = opts.port || 1883\n opts.hostname = opts.hostname || opts.host || 'localhost'\n\n const port = opts.port\n const host = opts.hostname\n\n debug('port %d and host %s', port, host)\n return net.createConnection(port, host)\n}\n\nmodule.exports = streamBuilder\n","'use strict'\nconst tls = require('tls')\nconst net = require('net')\nconst debug = require('debug')('mqttjs:tls')\n\nfunction buildBuilder (mqttClient, opts) {\n opts.port = opts.port || 8883\n opts.host = opts.hostname || opts.host || 'localhost'\n\n if (net.isIP(opts.host) === 0) {\n opts.servername = opts.host\n }\n\n opts.rejectUnauthorized = opts.rejectUnauthorized !== false\n\n delete opts.path\n\n debug('port %d host %s rejectUnauthorized %b', opts.port, opts.host, opts.rejectUnauthorized)\n\n const connection = tls.connect(opts)\n /* eslint no-use-before-define: [2, \"nofunc\"] */\n connection.on('secureConnect', function () {\n if (opts.rejectUnauthorized && !connection.authorized) {\n connection.emit('error', new Error('TLS not authorized'))\n } else {\n connection.removeListener('error', handleTLSerrors)\n }\n })\n\n function handleTLSerrors (err) {\n // How can I get verify this error is a tls error?\n if (opts.rejectUnauthorized) {\n mqttClient.emit('error', err)\n }\n\n // close this connection to match the behaviour of net\n // otherwise all we get is an error from the connection\n // and close event doesn't fire. This is a work around\n // to enable the reconnect code to work the same as with\n // net.createConnection\n connection.end()\n }\n\n connection.on('error', handleTLSerrors)\n return connection\n}\n\nmodule.exports = buildBuilder\n","// Returns a wrapper function that returns a wrapped callback\n// The wrapper function should do some stuff, and return a\n// presumably different callback function.\n// This makes sure that own properties are retained, so that\n// decorations and such are not lost along the way.\nmodule.exports = wrappy\nfunction wrappy (fn, cb) {\n if (fn && cb) return wrappy(fn)(cb)\n\n if (typeof fn !== 'function')\n throw new TypeError('need wrapper function')\n\n Object.keys(fn).forEach(function (k) {\n wrapper[k] = fn[k]\n })\n\n return wrapper\n\n function wrapper() {\n var args = new Array(arguments.length)\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i]\n }\n var ret = fn.apply(this, args)\n var cb = args[args.length-1]\n if (typeof ret === 'function' && ret !== cb) {\n Object.keys(cb).forEach(function (k) {\n ret[k] = cb[k]\n })\n }\n return ret\n }\n}\n","var wrappy = require('wrappy')\nmodule.exports = wrappy(once)\nmodule.exports.strict = wrappy(onceStrict)\n\nonce.proto = once(function () {\n Object.defineProperty(Function.prototype, 'once', {\n value: function () {\n return once(this)\n },\n configurable: true\n })\n\n Object.defineProperty(Function.prototype, 'onceStrict', {\n value: function () {\n return onceStrict(this)\n },\n configurable: true\n })\n})\n\nfunction once (fn) {\n var f = function () {\n if (f.called) return f.value\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n f.called = false\n return f\n}\n\nfunction onceStrict (fn) {\n var f = function () {\n if (f.called)\n throw new Error(f.onceError)\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n var name = fn.name || 'Function wrapped with `once`'\n f.onceError = name + \" shouldn't be called more than once\"\n f.called = false\n return f\n}\n","var once = require('once');\n\nvar noop = function() {};\n\nvar isRequest = function(stream) {\n\treturn stream.setHeader && typeof stream.abort === 'function';\n};\n\nvar isChildProcess = function(stream) {\n\treturn stream.stdio && Array.isArray(stream.stdio) && stream.stdio.length === 3\n};\n\nvar eos = function(stream, opts, callback) {\n\tif (typeof opts === 'function') return eos(stream, null, opts);\n\tif (!opts) opts = {};\n\n\tcallback = once(callback || noop);\n\n\tvar ws = stream._writableState;\n\tvar rs = stream._readableState;\n\tvar readable = opts.readable || (opts.readable !== false && stream.readable);\n\tvar writable = opts.writable || (opts.writable !== false && stream.writable);\n\tvar cancelled = false;\n\n\tvar onlegacyfinish = function() {\n\t\tif (!stream.writable) onfinish();\n\t};\n\n\tvar onfinish = function() {\n\t\twritable = false;\n\t\tif (!readable) callback.call(stream);\n\t};\n\n\tvar onend = function() {\n\t\treadable = false;\n\t\tif (!writable) callback.call(stream);\n\t};\n\n\tvar onexit = function(exitCode) {\n\t\tcallback.call(stream, exitCode ? new Error('exited with error code: ' + exitCode) : null);\n\t};\n\n\tvar onerror = function(err) {\n\t\tcallback.call(stream, err);\n\t};\n\n\tvar onclose = function() {\n\t\tprocess.nextTick(onclosenexttick);\n\t};\n\n\tvar onclosenexttick = function() {\n\t\tif (cancelled) return;\n\t\tif (readable && !(rs && (rs.ended && !rs.destroyed))) return callback.call(stream, new Error('premature close'));\n\t\tif (writable && !(ws && (ws.ended && !ws.destroyed))) return callback.call(stream, new Error('premature close'));\n\t};\n\n\tvar onrequest = function() {\n\t\tstream.req.on('finish', onfinish);\n\t};\n\n\tif (isRequest(stream)) {\n\t\tstream.on('complete', onfinish);\n\t\tstream.on('abort', onclose);\n\t\tif (stream.req) onrequest();\n\t\telse stream.on('request', onrequest);\n\t} else if (writable && !ws) { // legacy streams\n\t\tstream.on('end', onlegacyfinish);\n\t\tstream.on('close', onlegacyfinish);\n\t}\n\n\tif (isChildProcess(stream)) stream.on('exit', onexit);\n\n\tstream.on('end', onend);\n\tstream.on('finish', onfinish);\n\tif (opts.error !== false) stream.on('error', onerror);\n\tstream.on('close', onclose);\n\n\treturn function() {\n\t\tcancelled = true;\n\t\tstream.removeListener('complete', onfinish);\n\t\tstream.removeListener('abort', onclose);\n\t\tstream.removeListener('request', onrequest);\n\t\tif (stream.req) stream.req.removeListener('finish', onfinish);\n\t\tstream.removeListener('end', onlegacyfinish);\n\t\tstream.removeListener('close', onlegacyfinish);\n\t\tstream.removeListener('finish', onfinish);\n\t\tstream.removeListener('exit', onexit);\n\t\tstream.removeListener('end', onend);\n\t\tstream.removeListener('error', onerror);\n\t\tstream.removeListener('close', onclose);\n\t};\n};\n\nmodule.exports = eos;\n","module.exports = shift\n\nfunction shift (stream) {\n var rs = stream._readableState\n if (!rs) return null\n return (rs.objectMode || typeof stream._duplexState === 'number') ? stream.read() : stream.read(getStateLength(rs))\n}\n\nfunction getStateLength (state) {\n if (state.buffer.length) {\n // Since node 6.3.0 state.buffer is a BufferList not an array\n if (state.buffer.head) {\n return state.buffer.head.data.length\n }\n\n return state.buffer[0].length\n }\n\n return state.length\n}\n","var stream = require('readable-stream')\nvar eos = require('end-of-stream')\nvar inherits = require('inherits')\nvar shift = require('stream-shift')\n\nvar SIGNAL_FLUSH = (Buffer.from && Buffer.from !== Uint8Array.from)\n ? Buffer.from([0])\n : new Buffer([0])\n\nvar onuncork = function(self, fn) {\n if (self._corked) self.once('uncork', fn)\n else fn()\n}\n\nvar autoDestroy = function (self, err) {\n if (self._autoDestroy) self.destroy(err)\n}\n\nvar destroyer = function(self, end) {\n return function(err) {\n if (err) autoDestroy(self, err.message === 'premature close' ? null : err)\n else if (end && !self._ended) self.end()\n }\n}\n\nvar end = function(ws, fn) {\n if (!ws) return fn()\n if (ws._writableState && ws._writableState.finished) return fn()\n if (ws._writableState) return ws.end(fn)\n ws.end()\n fn()\n}\n\nvar noop = function() {}\n\nvar toStreams2 = function(rs) {\n return new (stream.Readable)({objectMode:true, highWaterMark:16}).wrap(rs)\n}\n\nvar Duplexify = function(writable, readable, opts) {\n if (!(this instanceof Duplexify)) return new Duplexify(writable, readable, opts)\n stream.Duplex.call(this, opts)\n\n this._writable = null\n this._readable = null\n this._readable2 = null\n\n this._autoDestroy = !opts || opts.autoDestroy !== false\n this._forwardDestroy = !opts || opts.destroy !== false\n this._forwardEnd = !opts || opts.end !== false\n this._corked = 1 // start corked\n this._ondrain = null\n this._drained = false\n this._forwarding = false\n this._unwrite = null\n this._unread = null\n this._ended = false\n\n this.destroyed = false\n\n if (writable) this.setWritable(writable)\n if (readable) this.setReadable(readable)\n}\n\ninherits(Duplexify, stream.Duplex)\n\nDuplexify.obj = function(writable, readable, opts) {\n if (!opts) opts = {}\n opts.objectMode = true\n opts.highWaterMark = 16\n return new Duplexify(writable, readable, opts)\n}\n\nDuplexify.prototype.cork = function() {\n if (++this._corked === 1) this.emit('cork')\n}\n\nDuplexify.prototype.uncork = function() {\n if (this._corked && --this._corked === 0) this.emit('uncork')\n}\n\nDuplexify.prototype.setWritable = function(writable) {\n if (this._unwrite) this._unwrite()\n\n if (this.destroyed) {\n if (writable && writable.destroy) writable.destroy()\n return\n }\n\n if (writable === null || writable === false) {\n this.end()\n return\n }\n\n var self = this\n var unend = eos(writable, {writable:true, readable:false}, destroyer(this, this._forwardEnd))\n\n var ondrain = function() {\n var ondrain = self._ondrain\n self._ondrain = null\n if (ondrain) ondrain()\n }\n\n var clear = function() {\n self._writable.removeListener('drain', ondrain)\n unend()\n }\n\n if (this._unwrite) process.nextTick(ondrain) // force a drain on stream reset to avoid livelocks\n\n this._writable = writable\n this._writable.on('drain', ondrain)\n this._unwrite = clear\n\n this.uncork() // always uncork setWritable\n}\n\nDuplexify.prototype.setReadable = function(readable) {\n if (this._unread) this._unread()\n\n if (this.destroyed) {\n if (readable && readable.destroy) readable.destroy()\n return\n }\n\n if (readable === null || readable === false) {\n this.push(null)\n this.resume()\n return\n }\n\n var self = this\n var unend = eos(readable, {writable:false, readable:true}, destroyer(this))\n\n var onreadable = function() {\n self._forward()\n }\n\n var onend = function() {\n self.push(null)\n }\n\n var clear = function() {\n self._readable2.removeListener('readable', onreadable)\n self._readable2.removeListener('end', onend)\n unend()\n }\n\n this._drained = true\n this._readable = readable\n this._readable2 = readable._readableState ? readable : toStreams2(readable)\n this._readable2.on('readable', onreadable)\n this._readable2.on('end', onend)\n this._unread = clear\n\n this._forward()\n}\n\nDuplexify.prototype._read = function() {\n this._drained = true\n this._forward()\n}\n\nDuplexify.prototype._forward = function() {\n if (this._forwarding || !this._readable2 || !this._drained) return\n this._forwarding = true\n\n var data\n\n while (this._drained && (data = shift(this._readable2)) !== null) {\n if (this.destroyed) continue\n this._drained = this.push(data)\n }\n\n this._forwarding = false\n}\n\nDuplexify.prototype.destroy = function(err, cb) {\n if (!cb) cb = noop\n if (this.destroyed) return cb(null)\n this.destroyed = true\n\n var self = this\n process.nextTick(function() {\n self._destroy(err)\n cb(null)\n })\n}\n\nDuplexify.prototype._destroy = function(err) {\n if (err) {\n var ondrain = this._ondrain\n this._ondrain = null\n if (ondrain) ondrain(err)\n else this.emit('error', err)\n }\n\n if (this._forwardDestroy) {\n if (this._readable && this._readable.destroy) this._readable.destroy()\n if (this._writable && this._writable.destroy) this._writable.destroy()\n }\n\n this.emit('close')\n}\n\nDuplexify.prototype._write = function(data, enc, cb) {\n if (this.destroyed) return\n if (this._corked) return onuncork(this, this._write.bind(this, data, enc, cb))\n if (data === SIGNAL_FLUSH) return this._finish(cb)\n if (!this._writable) return cb()\n\n if (this._writable.write(data) === false) this._ondrain = cb\n else if (!this.destroyed) cb()\n}\n\nDuplexify.prototype._finish = function(cb) {\n var self = this\n this.emit('preend')\n onuncork(this, function() {\n end(self._forwardEnd && self._writable, function() {\n // haxx to not emit prefinish twice\n if (self._writableState.prefinished === false) self._writableState.prefinished = true\n self.emit('prefinish')\n onuncork(self, cb)\n })\n })\n}\n\nDuplexify.prototype.end = function(data, enc, cb) {\n if (typeof data === 'function') return this.end(null, null, data)\n if (typeof enc === 'function') return this.end(data, null, enc)\n this._ended = true\n if (data) this.write(data)\n if (!this._writableState.ending && !this._writableState.destroyed) this.write(SIGNAL_FLUSH)\n return stream.Writable.prototype.end.call(this, cb)\n}\n\nmodule.exports = Duplexify\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst Transform = require('readable-stream').Transform\nconst duplexify = require('duplexify')\n\n/* global wx */\nlet socketTask, proxy, stream\n\nfunction buildProxy () {\n const proxy = new Transform()\n proxy._write = function (chunk, encoding, next) {\n socketTask.send({\n data: chunk.buffer,\n success: function () {\n next()\n },\n fail: function (errMsg) {\n next(new Error(errMsg))\n }\n })\n }\n proxy._flush = function socketEnd (done) {\n socketTask.close({\n success: function () {\n done()\n }\n })\n }\n\n return proxy\n}\n\nfunction setDefaultOpts (opts) {\n if (!opts.hostname) {\n opts.hostname = 'localhost'\n }\n if (!opts.path) {\n opts.path = '/'\n }\n\n if (!opts.wsOptions) {\n opts.wsOptions = {}\n }\n}\n\nfunction buildUrl (opts, client) {\n const protocol = opts.protocol === 'wxs' ? 'wss' : 'ws'\n let url = protocol + '://' + opts.hostname + opts.path\n if (opts.port && opts.port !== 80 && opts.port !== 443) {\n url = protocol + '://' + opts.hostname + ':' + opts.port + opts.path\n }\n if (typeof (opts.transformWsUrl) === 'function') {\n url = opts.transformWsUrl(url, opts, client)\n }\n return url\n}\n\nfunction bindEventHandler () {\n socketTask.onOpen(function () {\n stream.setReadable(proxy)\n stream.setWritable(proxy)\n stream.emit('connect')\n })\n\n socketTask.onMessage(function (res) {\n let data = res.data\n\n if (data instanceof ArrayBuffer) data = Buffer.from(data)\n else data = Buffer.from(data, 'utf8')\n proxy.push(data)\n })\n\n socketTask.onClose(function () {\n stream.end()\n stream.destroy()\n })\n\n socketTask.onError(function (res) {\n stream.destroy(new Error(res.errMsg))\n })\n}\n\nfunction buildStream (client, opts) {\n opts.hostname = opts.hostname || opts.host\n\n if (!opts.hostname) {\n throw new Error('Could not determine host. Specify host manually.')\n }\n\n const websocketSubProtocol =\n (opts.protocolId === 'MQIsdp') && (opts.protocolVersion === 3)\n ? 'mqttv3.1'\n : 'mqtt'\n\n setDefaultOpts(opts)\n\n const url = buildUrl(opts, client)\n socketTask = wx.connectSocket({\n url: url,\n protocols: [websocketSubProtocol]\n })\n\n proxy = buildProxy()\n stream = duplexify.obj()\n stream._destroy = function (err, cb) {\n socketTask.close({\n success: function () {\n cb && cb(err)\n }\n })\n }\n\n const destroyRef = stream.destroy\n stream.destroy = function () {\n stream.destroy = destroyRef\n\n const self = this\n setTimeout(function () {\n socketTask.close({\n fail: function () {\n self._destroy(new Error())\n }\n })\n }, 0)\n }.bind(stream)\n\n bindEventHandler()\n\n return stream\n}\n\nmodule.exports = buildStream\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst Transform = require('readable-stream').Transform\nconst duplexify = require('duplexify')\n\n/* global FileReader */\nlet my\nlet proxy\nlet stream\nlet isInitialized = false\n\nfunction buildProxy () {\n const proxy = new Transform()\n proxy._write = function (chunk, encoding, next) {\n my.sendSocketMessage({\n data: chunk.buffer,\n success: function () {\n next()\n },\n fail: function () {\n next(new Error())\n }\n })\n }\n proxy._flush = function socketEnd (done) {\n my.closeSocket({\n success: function () {\n done()\n }\n })\n }\n\n return proxy\n}\n\nfunction setDefaultOpts (opts) {\n if (!opts.hostname) {\n opts.hostname = 'localhost'\n }\n if (!opts.path) {\n opts.path = '/'\n }\n\n if (!opts.wsOptions) {\n opts.wsOptions = {}\n }\n}\n\nfunction buildUrl (opts, client) {\n const protocol = opts.protocol === 'alis' ? 'wss' : 'ws'\n let url = protocol + '://' + opts.hostname + opts.path\n if (opts.port && opts.port !== 80 && opts.port !== 443) {\n url = protocol + '://' + opts.hostname + ':' + opts.port + opts.path\n }\n if (typeof (opts.transformWsUrl) === 'function') {\n url = opts.transformWsUrl(url, opts, client)\n }\n return url\n}\n\nfunction bindEventHandler () {\n if (isInitialized) return\n\n isInitialized = true\n\n my.onSocketOpen(function () {\n stream.setReadable(proxy)\n stream.setWritable(proxy)\n stream.emit('connect')\n })\n\n my.onSocketMessage(function (res) {\n if (typeof res.data === 'string') {\n const buffer = Buffer.from(res.data, 'base64')\n proxy.push(buffer)\n } else {\n const reader = new FileReader()\n reader.addEventListener('load', function () {\n let data = reader.result\n\n if (data instanceof ArrayBuffer) data = Buffer.from(data)\n else data = Buffer.from(data, 'utf8')\n proxy.push(data)\n })\n reader.readAsArrayBuffer(res.data)\n }\n })\n\n my.onSocketClose(function () {\n stream.end()\n stream.destroy()\n })\n\n my.onSocketError(function (res) {\n stream.destroy(res)\n })\n}\n\nfunction buildStream (client, opts) {\n opts.hostname = opts.hostname || opts.host\n\n if (!opts.hostname) {\n throw new Error('Could not determine host. Specify host manually.')\n }\n\n const websocketSubProtocol =\n (opts.protocolId === 'MQIsdp') && (opts.protocolVersion === 3)\n ? 'mqttv3.1'\n : 'mqtt'\n\n setDefaultOpts(opts)\n\n const url = buildUrl(opts, client)\n my = opts.my\n my.connectSocket({\n url: url,\n protocols: websocketSubProtocol\n })\n\n proxy = buildProxy()\n stream = duplexify.obj()\n\n bindEventHandler()\n\n return stream\n}\n\nmodule.exports = buildStream\n","'use strict';\n\nmodule.exports = {\n BINARY_TYPES: ['nodebuffer', 'arraybuffer', 'fragments'],\n GUID: '258EAFA5-E914-47DA-95CA-C5AB0DC85B11',\n kStatusCode: Symbol('status-code'),\n kWebSocket: Symbol('websocket'),\n EMPTY_BUFFER: Buffer.alloc(0),\n NOOP: () => {}\n};\n","'use strict';\n\nconst { EMPTY_BUFFER } = require('./constants');\n\n/**\n * Merges an array of buffers into a new buffer.\n *\n * @param {Buffer[]} list The array of buffers to concat\n * @param {Number} totalLength The total length of buffers in the list\n * @return {Buffer} The resulting buffer\n * @public\n */\nfunction concat(list, totalLength) {\n if (list.length === 0) return EMPTY_BUFFER;\n if (list.length === 1) return list[0];\n\n const target = Buffer.allocUnsafe(totalLength);\n let offset = 0;\n\n for (let i = 0; i < list.length; i++) {\n const buf = list[i];\n target.set(buf, offset);\n offset += buf.length;\n }\n\n if (offset < totalLength) return target.slice(0, offset);\n\n return target;\n}\n\n/**\n * Masks a buffer using the given mask.\n *\n * @param {Buffer} source The buffer to mask\n * @param {Buffer} mask The mask to use\n * @param {Buffer} output The buffer where to store the result\n * @param {Number} offset The offset at which to start writing\n * @param {Number} length The number of bytes to mask.\n * @public\n */\nfunction _mask(source, mask, output, offset, length) {\n for (let i = 0; i < length; i++) {\n output[offset + i] = source[i] ^ mask[i & 3];\n }\n}\n\n/**\n * Unmasks a buffer using the given mask.\n *\n * @param {Buffer} buffer The buffer to unmask\n * @param {Buffer} mask The mask to use\n * @public\n */\nfunction _unmask(buffer, mask) {\n // Required until https://github.com/nodejs/node/issues/9006 is resolved.\n const length = buffer.length;\n for (let i = 0; i < length; i++) {\n buffer[i] ^= mask[i & 3];\n }\n}\n\n/**\n * Converts a buffer to an `ArrayBuffer`.\n *\n * @param {Buffer} buf The buffer to convert\n * @return {ArrayBuffer} Converted buffer\n * @public\n */\nfunction toArrayBuffer(buf) {\n if (buf.byteLength === buf.buffer.byteLength) {\n return buf.buffer;\n }\n\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);\n}\n\n/**\n * Converts `data` to a `Buffer`.\n *\n * @param {*} data The data to convert\n * @return {Buffer} The buffer\n * @throws {TypeError}\n * @public\n */\nfunction toBuffer(data) {\n toBuffer.readOnly = true;\n\n if (Buffer.isBuffer(data)) return data;\n\n let buf;\n\n if (data instanceof ArrayBuffer) {\n buf = Buffer.from(data);\n } else if (ArrayBuffer.isView(data)) {\n buf = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n } else {\n buf = Buffer.from(data);\n toBuffer.readOnly = false;\n }\n\n return buf;\n}\n\ntry {\n const bufferUtil = require('bufferutil');\n const bu = bufferUtil.BufferUtil || bufferUtil;\n\n module.exports = {\n concat,\n mask(source, mask, output, offset, length) {\n if (length < 48) _mask(source, mask, output, offset, length);\n else bu.mask(source, mask, output, offset, length);\n },\n toArrayBuffer,\n toBuffer,\n unmask(buffer, mask) {\n if (buffer.length < 32) _unmask(buffer, mask);\n else bu.unmask(buffer, mask);\n }\n };\n} catch (e) /* istanbul ignore next */ {\n module.exports = {\n concat,\n mask: _mask,\n toArrayBuffer,\n toBuffer,\n unmask: _unmask\n };\n}\n","'use strict';\n\nconst kDone = Symbol('kDone');\nconst kRun = Symbol('kRun');\n\n/**\n * A very simple job queue with adjustable concurrency. Adapted from\n * https://github.com/STRML/async-limiter\n */\nclass Limiter {\n /**\n * Creates a new `Limiter`.\n *\n * @param {Number} [concurrency=Infinity] The maximum number of jobs allowed\n * to run concurrently\n */\n constructor(concurrency) {\n this[kDone] = () => {\n this.pending--;\n this[kRun]();\n };\n this.concurrency = concurrency || Infinity;\n this.jobs = [];\n this.pending = 0;\n }\n\n /**\n * Adds a job to the queue.\n *\n * @param {Function} job The job to run\n * @public\n */\n add(job) {\n this.jobs.push(job);\n this[kRun]();\n }\n\n /**\n * Removes a job from the queue and runs it if possible.\n *\n * @private\n */\n [kRun]() {\n if (this.pending === this.concurrency) return;\n\n if (this.jobs.length) {\n const job = this.jobs.shift();\n\n this.pending++;\n job(this[kDone]);\n }\n }\n}\n\nmodule.exports = Limiter;\n","'use strict';\n\nconst zlib = require('zlib');\n\nconst bufferUtil = require('./buffer-util');\nconst Limiter = require('./limiter');\nconst { kStatusCode, NOOP } = require('./constants');\n\nconst TRAILER = Buffer.from([0x00, 0x00, 0xff, 0xff]);\nconst kPerMessageDeflate = Symbol('permessage-deflate');\nconst kTotalLength = Symbol('total-length');\nconst kCallback = Symbol('callback');\nconst kBuffers = Symbol('buffers');\nconst kError = Symbol('error');\n\n//\n// We limit zlib concurrency, which prevents severe memory fragmentation\n// as documented in https://github.com/nodejs/node/issues/8871#issuecomment-250915913\n// and https://github.com/websockets/ws/issues/1202\n//\n// Intentionally global; it's the global thread pool that's an issue.\n//\nlet zlibLimiter;\n\n/**\n * permessage-deflate implementation.\n */\nclass PerMessageDeflate {\n /**\n * Creates a PerMessageDeflate instance.\n *\n * @param {Object} [options] Configuration options\n * @param {Boolean} [options.serverNoContextTakeover=false] Request/accept\n * disabling of server context takeover\n * @param {Boolean} [options.clientNoContextTakeover=false] Advertise/\n * acknowledge disabling of client context takeover\n * @param {(Boolean|Number)} [options.serverMaxWindowBits] Request/confirm the\n * use of a custom server window size\n * @param {(Boolean|Number)} [options.clientMaxWindowBits] Advertise support\n * for, or request, a custom client window size\n * @param {Object} [options.zlibDeflateOptions] Options to pass to zlib on\n * deflate\n * @param {Object} [options.zlibInflateOptions] Options to pass to zlib on\n * inflate\n * @param {Number} [options.threshold=1024] Size (in bytes) below which\n * messages should not be compressed\n * @param {Number} [options.concurrencyLimit=10] The number of concurrent\n * calls to zlib\n * @param {Boolean} [isServer=false] Create the instance in either server or\n * client mode\n * @param {Number} [maxPayload=0] The maximum allowed message length\n */\n constructor(options, isServer, maxPayload) {\n this._maxPayload = maxPayload | 0;\n this._options = options || {};\n this._threshold =\n this._options.threshold !== undefined ? this._options.threshold : 1024;\n this._isServer = !!isServer;\n this._deflate = null;\n this._inflate = null;\n\n this.params = null;\n\n if (!zlibLimiter) {\n const concurrency =\n this._options.concurrencyLimit !== undefined\n ? this._options.concurrencyLimit\n : 10;\n zlibLimiter = new Limiter(concurrency);\n }\n }\n\n /**\n * @type {String}\n */\n static get extensionName() {\n return 'permessage-deflate';\n }\n\n /**\n * Create an extension negotiation offer.\n *\n * @return {Object} Extension parameters\n * @public\n */\n offer() {\n const params = {};\n\n if (this._options.serverNoContextTakeover) {\n params.server_no_context_takeover = true;\n }\n if (this._options.clientNoContextTakeover) {\n params.client_no_context_takeover = true;\n }\n if (this._options.serverMaxWindowBits) {\n params.server_max_window_bits = this._options.serverMaxWindowBits;\n }\n if (this._options.clientMaxWindowBits) {\n params.client_max_window_bits = this._options.clientMaxWindowBits;\n } else if (this._options.clientMaxWindowBits == null) {\n params.client_max_window_bits = true;\n }\n\n return params;\n }\n\n /**\n * Accept an extension negotiation offer/response.\n *\n * @param {Array} configurations The extension negotiation offers/reponse\n * @return {Object} Accepted configuration\n * @public\n */\n accept(configurations) {\n configurations = this.normalizeParams(configurations);\n\n this.params = this._isServer\n ? this.acceptAsServer(configurations)\n : this.acceptAsClient(configurations);\n\n return this.params;\n }\n\n /**\n * Releases all resources used by the extension.\n *\n * @public\n */\n cleanup() {\n if (this._inflate) {\n this._inflate.close();\n this._inflate = null;\n }\n\n if (this._deflate) {\n const callback = this._deflate[kCallback];\n\n this._deflate.close();\n this._deflate = null;\n\n if (callback) {\n callback(\n new Error(\n 'The deflate stream was closed while data was being processed'\n )\n );\n }\n }\n }\n\n /**\n * Accept an extension negotiation offer.\n *\n * @param {Array} offers The extension negotiation offers\n * @return {Object} Accepted configuration\n * @private\n */\n acceptAsServer(offers) {\n const opts = this._options;\n const accepted = offers.find((params) => {\n if (\n (opts.serverNoContextTakeover === false &&\n params.server_no_context_takeover) ||\n (params.server_max_window_bits &&\n (opts.serverMaxWindowBits === false ||\n (typeof opts.serverMaxWindowBits === 'number' &&\n opts.serverMaxWindowBits > params.server_max_window_bits))) ||\n (typeof opts.clientMaxWindowBits === 'number' &&\n !params.client_max_window_bits)\n ) {\n return false;\n }\n\n return true;\n });\n\n if (!accepted) {\n throw new Error('None of the extension offers can be accepted');\n }\n\n if (opts.serverNoContextTakeover) {\n accepted.server_no_context_takeover = true;\n }\n if (opts.clientNoContextTakeover) {\n accepted.client_no_context_takeover = true;\n }\n if (typeof opts.serverMaxWindowBits === 'number') {\n accepted.server_max_window_bits = opts.serverMaxWindowBits;\n }\n if (typeof opts.clientMaxWindowBits === 'number') {\n accepted.client_max_window_bits = opts.clientMaxWindowBits;\n } else if (\n accepted.client_max_window_bits === true ||\n opts.clientMaxWindowBits === false\n ) {\n delete accepted.client_max_window_bits;\n }\n\n return accepted;\n }\n\n /**\n * Accept the extension negotiation response.\n *\n * @param {Array} response The extension negotiation response\n * @return {Object} Accepted configuration\n * @private\n */\n acceptAsClient(response) {\n const params = response[0];\n\n if (\n this._options.clientNoContextTakeover === false &&\n params.client_no_context_takeover\n ) {\n throw new Error('Unexpected parameter \"client_no_context_takeover\"');\n }\n\n if (!params.client_max_window_bits) {\n if (typeof this._options.clientMaxWindowBits === 'number') {\n params.client_max_window_bits = this._options.clientMaxWindowBits;\n }\n } else if (\n this._options.clientMaxWindowBits === false ||\n (typeof this._options.clientMaxWindowBits === 'number' &&\n params.client_max_window_bits > this._options.clientMaxWindowBits)\n ) {\n throw new Error(\n 'Unexpected or invalid parameter \"client_max_window_bits\"'\n );\n }\n\n return params;\n }\n\n /**\n * Normalize parameters.\n *\n * @param {Array} configurations The extension negotiation offers/reponse\n * @return {Array} The offers/response with normalized parameters\n * @private\n */\n normalizeParams(configurations) {\n configurations.forEach((params) => {\n Object.keys(params).forEach((key) => {\n let value = params[key];\n\n if (value.length > 1) {\n throw new Error(`Parameter \"${key}\" must have only a single value`);\n }\n\n value = value[0];\n\n if (key === 'client_max_window_bits') {\n if (value !== true) {\n const num = +value;\n if (!Number.isInteger(num) || num < 8 || num > 15) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n value = num;\n } else if (!this._isServer) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n } else if (key === 'server_max_window_bits') {\n const num = +value;\n if (!Number.isInteger(num) || num < 8 || num > 15) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n value = num;\n } else if (\n key === 'client_no_context_takeover' ||\n key === 'server_no_context_takeover'\n ) {\n if (value !== true) {\n throw new TypeError(\n `Invalid value for parameter \"${key}\": ${value}`\n );\n }\n } else {\n throw new Error(`Unknown parameter \"${key}\"`);\n }\n\n params[key] = value;\n });\n });\n\n return configurations;\n }\n\n /**\n * Decompress data. Concurrency limited.\n *\n * @param {Buffer} data Compressed data\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @public\n */\n decompress(data, fin, callback) {\n zlibLimiter.add((done) => {\n this._decompress(data, fin, (err, result) => {\n done();\n callback(err, result);\n });\n });\n }\n\n /**\n * Compress data. Concurrency limited.\n *\n * @param {Buffer} data Data to compress\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @public\n */\n compress(data, fin, callback) {\n zlibLimiter.add((done) => {\n this._compress(data, fin, (err, result) => {\n done();\n callback(err, result);\n });\n });\n }\n\n /**\n * Decompress data.\n *\n * @param {Buffer} data Compressed data\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @private\n */\n _decompress(data, fin, callback) {\n const endpoint = this._isServer ? 'client' : 'server';\n\n if (!this._inflate) {\n const key = `${endpoint}_max_window_bits`;\n const windowBits =\n typeof this.params[key] !== 'number'\n ? zlib.Z_DEFAULT_WINDOWBITS\n : this.params[key];\n\n this._inflate = zlib.createInflateRaw({\n ...this._options.zlibInflateOptions,\n windowBits\n });\n this._inflate[kPerMessageDeflate] = this;\n this._inflate[kTotalLength] = 0;\n this._inflate[kBuffers] = [];\n this._inflate.on('error', inflateOnError);\n this._inflate.on('data', inflateOnData);\n }\n\n this._inflate[kCallback] = callback;\n\n this._inflate.write(data);\n if (fin) this._inflate.write(TRAILER);\n\n this._inflate.flush(() => {\n const err = this._inflate[kError];\n\n if (err) {\n this._inflate.close();\n this._inflate = null;\n callback(err);\n return;\n }\n\n const data = bufferUtil.concat(\n this._inflate[kBuffers],\n this._inflate[kTotalLength]\n );\n\n if (this._inflate._readableState.endEmitted) {\n this._inflate.close();\n this._inflate = null;\n } else {\n this._inflate[kTotalLength] = 0;\n this._inflate[kBuffers] = [];\n\n if (fin && this.params[`${endpoint}_no_context_takeover`]) {\n this._inflate.reset();\n }\n }\n\n callback(null, data);\n });\n }\n\n /**\n * Compress data.\n *\n * @param {Buffer} data Data to compress\n * @param {Boolean} fin Specifies whether or not this is the last fragment\n * @param {Function} callback Callback\n * @private\n */\n _compress(data, fin, callback) {\n const endpoint = this._isServer ? 'server' : 'client';\n\n if (!this._deflate) {\n const key = `${endpoint}_max_window_bits`;\n const windowBits =\n typeof this.params[key] !== 'number'\n ? zlib.Z_DEFAULT_WINDOWBITS\n : this.params[key];\n\n this._deflate = zlib.createDeflateRaw({\n ...this._options.zlibDeflateOptions,\n windowBits\n });\n\n this._deflate[kTotalLength] = 0;\n this._deflate[kBuffers] = [];\n\n //\n // An `'error'` event is emitted, only on Node.js < 10.0.0, if the\n // `zlib.DeflateRaw` instance is closed while data is being processed.\n // This can happen if `PerMessageDeflate#cleanup()` is called at the wrong\n // time due to an abnormal WebSocket closure.\n //\n this._deflate.on('error', NOOP);\n this._deflate.on('data', deflateOnData);\n }\n\n this._deflate[kCallback] = callback;\n\n this._deflate.write(data);\n this._deflate.flush(zlib.Z_SYNC_FLUSH, () => {\n if (!this._deflate) {\n //\n // The deflate stream was closed while data was being processed.\n //\n return;\n }\n\n let data = bufferUtil.concat(\n this._deflate[kBuffers],\n this._deflate[kTotalLength]\n );\n\n if (fin) data = data.slice(0, data.length - 4);\n\n //\n // Ensure that the callback will not be called again in\n // `PerMessageDeflate#cleanup()`.\n //\n this._deflate[kCallback] = null;\n\n this._deflate[kTotalLength] = 0;\n this._deflate[kBuffers] = [];\n\n if (fin && this.params[`${endpoint}_no_context_takeover`]) {\n this._deflate.reset();\n }\n\n callback(null, data);\n });\n }\n}\n\nmodule.exports = PerMessageDeflate;\n\n/**\n * The listener of the `zlib.DeflateRaw` stream `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction deflateOnData(chunk) {\n this[kBuffers].push(chunk);\n this[kTotalLength] += chunk.length;\n}\n\n/**\n * The listener of the `zlib.InflateRaw` stream `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction inflateOnData(chunk) {\n this[kTotalLength] += chunk.length;\n\n if (\n this[kPerMessageDeflate]._maxPayload < 1 ||\n this[kTotalLength] <= this[kPerMessageDeflate]._maxPayload\n ) {\n this[kBuffers].push(chunk);\n return;\n }\n\n this[kError] = new RangeError('Max payload size exceeded');\n this[kError].code = 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH';\n this[kError][kStatusCode] = 1009;\n this.removeListener('data', inflateOnData);\n this.reset();\n}\n\n/**\n * The listener of the `zlib.InflateRaw` stream `'error'` event.\n *\n * @param {Error} err The emitted error\n * @private\n */\nfunction inflateOnError(err) {\n //\n // There is no need to call `Zlib#close()` as the handle is automatically\n // closed when an error is emitted.\n //\n this[kPerMessageDeflate]._inflate = null;\n err[kStatusCode] = 1007;\n this[kCallback](err);\n}\n","'use strict';\n\n/**\n * Checks if a status code is allowed in a close frame.\n *\n * @param {Number} code The status code\n * @return {Boolean} `true` if the status code is valid, else `false`\n * @public\n */\nfunction isValidStatusCode(code) {\n return (\n (code >= 1000 &&\n code <= 1014 &&\n code !== 1004 &&\n code !== 1005 &&\n code !== 1006) ||\n (code >= 3000 && code <= 4999)\n );\n}\n\n/**\n * Checks if a given buffer contains only correct UTF-8.\n * Ported from https://www.cl.cam.ac.uk/%7Emgk25/ucs/utf8_check.c by\n * Markus Kuhn.\n *\n * @param {Buffer} buf The buffer to check\n * @return {Boolean} `true` if `buf` contains only correct UTF-8, else `false`\n * @public\n */\nfunction _isValidUTF8(buf) {\n const len = buf.length;\n let i = 0;\n\n while (i < len) {\n if ((buf[i] & 0x80) === 0) {\n // 0xxxxxxx\n i++;\n } else if ((buf[i] & 0xe0) === 0xc0) {\n // 110xxxxx 10xxxxxx\n if (\n i + 1 === len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i] & 0xfe) === 0xc0 // Overlong\n ) {\n return false;\n }\n\n i += 2;\n } else if ((buf[i] & 0xf0) === 0xe0) {\n // 1110xxxx 10xxxxxx 10xxxxxx\n if (\n i + 2 >= len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i + 2] & 0xc0) !== 0x80 ||\n (buf[i] === 0xe0 && (buf[i + 1] & 0xe0) === 0x80) || // Overlong\n (buf[i] === 0xed && (buf[i + 1] & 0xe0) === 0xa0) // Surrogate (U+D800 - U+DFFF)\n ) {\n return false;\n }\n\n i += 3;\n } else if ((buf[i] & 0xf8) === 0xf0) {\n // 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx\n if (\n i + 3 >= len ||\n (buf[i + 1] & 0xc0) !== 0x80 ||\n (buf[i + 2] & 0xc0) !== 0x80 ||\n (buf[i + 3] & 0xc0) !== 0x80 ||\n (buf[i] === 0xf0 && (buf[i + 1] & 0xf0) === 0x80) || // Overlong\n (buf[i] === 0xf4 && buf[i + 1] > 0x8f) ||\n buf[i] > 0xf4 // > U+10FFFF\n ) {\n return false;\n }\n\n i += 4;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\ntry {\n let isValidUTF8 = require('utf-8-validate');\n\n /* istanbul ignore if */\n if (typeof isValidUTF8 === 'object') {\n isValidUTF8 = isValidUTF8.Validation.isValidUTF8; // utf-8-validate@<3.0.0\n }\n\n module.exports = {\n isValidStatusCode,\n isValidUTF8(buf) {\n return buf.length < 150 ? _isValidUTF8(buf) : isValidUTF8(buf);\n }\n };\n} catch (e) /* istanbul ignore next */ {\n module.exports = {\n isValidStatusCode,\n isValidUTF8: _isValidUTF8\n };\n}\n","'use strict';\n\nconst { Writable } = require('stream');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst {\n BINARY_TYPES,\n EMPTY_BUFFER,\n kStatusCode,\n kWebSocket\n} = require('./constants');\nconst { concat, toArrayBuffer, unmask } = require('./buffer-util');\nconst { isValidStatusCode, isValidUTF8 } = require('./validation');\n\nconst GET_INFO = 0;\nconst GET_PAYLOAD_LENGTH_16 = 1;\nconst GET_PAYLOAD_LENGTH_64 = 2;\nconst GET_MASK = 3;\nconst GET_DATA = 4;\nconst INFLATING = 5;\n\n/**\n * HyBi Receiver implementation.\n *\n * @extends Writable\n */\nclass Receiver extends Writable {\n /**\n * Creates a Receiver instance.\n *\n * @param {String} [binaryType=nodebuffer] The type for binary data\n * @param {Object} [extensions] An object containing the negotiated extensions\n * @param {Boolean} [isServer=false] Specifies whether to operate in client or\n * server mode\n * @param {Number} [maxPayload=0] The maximum allowed message length\n */\n constructor(binaryType, extensions, isServer, maxPayload) {\n super();\n\n this._binaryType = binaryType || BINARY_TYPES[0];\n this[kWebSocket] = undefined;\n this._extensions = extensions || {};\n this._isServer = !!isServer;\n this._maxPayload = maxPayload | 0;\n\n this._bufferedBytes = 0;\n this._buffers = [];\n\n this._compressed = false;\n this._payloadLength = 0;\n this._mask = undefined;\n this._fragmented = 0;\n this._masked = false;\n this._fin = false;\n this._opcode = 0;\n\n this._totalPayloadLength = 0;\n this._messageLength = 0;\n this._fragments = [];\n\n this._state = GET_INFO;\n this._loop = false;\n }\n\n /**\n * Implements `Writable.prototype._write()`.\n *\n * @param {Buffer} chunk The chunk of data to write\n * @param {String} encoding The character encoding of `chunk`\n * @param {Function} cb Callback\n * @private\n */\n _write(chunk, encoding, cb) {\n if (this._opcode === 0x08 && this._state == GET_INFO) return cb();\n\n this._bufferedBytes += chunk.length;\n this._buffers.push(chunk);\n this.startLoop(cb);\n }\n\n /**\n * Consumes `n` bytes from the buffered data.\n *\n * @param {Number} n The number of bytes to consume\n * @return {Buffer} The consumed bytes\n * @private\n */\n consume(n) {\n this._bufferedBytes -= n;\n\n if (n === this._buffers[0].length) return this._buffers.shift();\n\n if (n < this._buffers[0].length) {\n const buf = this._buffers[0];\n this._buffers[0] = buf.slice(n);\n return buf.slice(0, n);\n }\n\n const dst = Buffer.allocUnsafe(n);\n\n do {\n const buf = this._buffers[0];\n const offset = dst.length - n;\n\n if (n >= buf.length) {\n dst.set(this._buffers.shift(), offset);\n } else {\n dst.set(new Uint8Array(buf.buffer, buf.byteOffset, n), offset);\n this._buffers[0] = buf.slice(n);\n }\n\n n -= buf.length;\n } while (n > 0);\n\n return dst;\n }\n\n /**\n * Starts the parsing loop.\n *\n * @param {Function} cb Callback\n * @private\n */\n startLoop(cb) {\n let err;\n this._loop = true;\n\n do {\n switch (this._state) {\n case GET_INFO:\n err = this.getInfo();\n break;\n case GET_PAYLOAD_LENGTH_16:\n err = this.getPayloadLength16();\n break;\n case GET_PAYLOAD_LENGTH_64:\n err = this.getPayloadLength64();\n break;\n case GET_MASK:\n this.getMask();\n break;\n case GET_DATA:\n err = this.getData(cb);\n break;\n default:\n // `INFLATING`\n this._loop = false;\n return;\n }\n } while (this._loop);\n\n cb(err);\n }\n\n /**\n * Reads the first two bytes of a frame.\n *\n * @return {(RangeError|undefined)} A possible error\n * @private\n */\n getInfo() {\n if (this._bufferedBytes < 2) {\n this._loop = false;\n return;\n }\n\n const buf = this.consume(2);\n\n if ((buf[0] & 0x30) !== 0x00) {\n this._loop = false;\n return error(\n RangeError,\n 'RSV2 and RSV3 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_2_3'\n );\n }\n\n const compressed = (buf[0] & 0x40) === 0x40;\n\n if (compressed && !this._extensions[PerMessageDeflate.extensionName]) {\n this._loop = false;\n return error(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n }\n\n this._fin = (buf[0] & 0x80) === 0x80;\n this._opcode = buf[0] & 0x0f;\n this._payloadLength = buf[1] & 0x7f;\n\n if (this._opcode === 0x00) {\n if (compressed) {\n this._loop = false;\n return error(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n }\n\n if (!this._fragmented) {\n this._loop = false;\n return error(\n RangeError,\n 'invalid opcode 0',\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n }\n\n this._opcode = this._fragmented;\n } else if (this._opcode === 0x01 || this._opcode === 0x02) {\n if (this._fragmented) {\n this._loop = false;\n return error(\n RangeError,\n `invalid opcode ${this._opcode}`,\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n }\n\n this._compressed = compressed;\n } else if (this._opcode > 0x07 && this._opcode < 0x0b) {\n if (!this._fin) {\n this._loop = false;\n return error(\n RangeError,\n 'FIN must be set',\n true,\n 1002,\n 'WS_ERR_EXPECTED_FIN'\n );\n }\n\n if (compressed) {\n this._loop = false;\n return error(\n RangeError,\n 'RSV1 must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_RSV_1'\n );\n }\n\n if (this._payloadLength > 0x7d) {\n this._loop = false;\n return error(\n RangeError,\n `invalid payload length ${this._payloadLength}`,\n true,\n 1002,\n 'WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH'\n );\n }\n } else {\n this._loop = false;\n return error(\n RangeError,\n `invalid opcode ${this._opcode}`,\n true,\n 1002,\n 'WS_ERR_INVALID_OPCODE'\n );\n }\n\n if (!this._fin && !this._fragmented) this._fragmented = this._opcode;\n this._masked = (buf[1] & 0x80) === 0x80;\n\n if (this._isServer) {\n if (!this._masked) {\n this._loop = false;\n return error(\n RangeError,\n 'MASK must be set',\n true,\n 1002,\n 'WS_ERR_EXPECTED_MASK'\n );\n }\n } else if (this._masked) {\n this._loop = false;\n return error(\n RangeError,\n 'MASK must be clear',\n true,\n 1002,\n 'WS_ERR_UNEXPECTED_MASK'\n );\n }\n\n if (this._payloadLength === 126) this._state = GET_PAYLOAD_LENGTH_16;\n else if (this._payloadLength === 127) this._state = GET_PAYLOAD_LENGTH_64;\n else return this.haveLength();\n }\n\n /**\n * Gets extended payload length (7+16).\n *\n * @return {(RangeError|undefined)} A possible error\n * @private\n */\n getPayloadLength16() {\n if (this._bufferedBytes < 2) {\n this._loop = false;\n return;\n }\n\n this._payloadLength = this.consume(2).readUInt16BE(0);\n return this.haveLength();\n }\n\n /**\n * Gets extended payload length (7+64).\n *\n * @return {(RangeError|undefined)} A possible error\n * @private\n */\n getPayloadLength64() {\n if (this._bufferedBytes < 8) {\n this._loop = false;\n return;\n }\n\n const buf = this.consume(8);\n const num = buf.readUInt32BE(0);\n\n //\n // The maximum safe integer in JavaScript is 2^53 - 1. An error is returned\n // if payload length is greater than this number.\n //\n if (num > Math.pow(2, 53 - 32) - 1) {\n this._loop = false;\n return error(\n RangeError,\n 'Unsupported WebSocket frame: payload length > 2^53 - 1',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH'\n );\n }\n\n this._payloadLength = num * Math.pow(2, 32) + buf.readUInt32BE(4);\n return this.haveLength();\n }\n\n /**\n * Payload length has been read.\n *\n * @return {(RangeError|undefined)} A possible error\n * @private\n */\n haveLength() {\n if (this._payloadLength && this._opcode < 0x08) {\n this._totalPayloadLength += this._payloadLength;\n if (this._totalPayloadLength > this._maxPayload && this._maxPayload > 0) {\n this._loop = false;\n return error(\n RangeError,\n 'Max payload size exceeded',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'\n );\n }\n }\n\n if (this._masked) this._state = GET_MASK;\n else this._state = GET_DATA;\n }\n\n /**\n * Reads mask bytes.\n *\n * @private\n */\n getMask() {\n if (this._bufferedBytes < 4) {\n this._loop = false;\n return;\n }\n\n this._mask = this.consume(4);\n this._state = GET_DATA;\n }\n\n /**\n * Reads data bytes.\n *\n * @param {Function} cb Callback\n * @return {(Error|RangeError|undefined)} A possible error\n * @private\n */\n getData(cb) {\n let data = EMPTY_BUFFER;\n\n if (this._payloadLength) {\n if (this._bufferedBytes < this._payloadLength) {\n this._loop = false;\n return;\n }\n\n data = this.consume(this._payloadLength);\n if (this._masked) unmask(data, this._mask);\n }\n\n if (this._opcode > 0x07) return this.controlMessage(data);\n\n if (this._compressed) {\n this._state = INFLATING;\n this.decompress(data, cb);\n return;\n }\n\n if (data.length) {\n //\n // This message is not compressed so its lenght is the sum of the payload\n // length of all fragments.\n //\n this._messageLength = this._totalPayloadLength;\n this._fragments.push(data);\n }\n\n return this.dataMessage();\n }\n\n /**\n * Decompresses data.\n *\n * @param {Buffer} data Compressed data\n * @param {Function} cb Callback\n * @private\n */\n decompress(data, cb) {\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n\n perMessageDeflate.decompress(data, this._fin, (err, buf) => {\n if (err) return cb(err);\n\n if (buf.length) {\n this._messageLength += buf.length;\n if (this._messageLength > this._maxPayload && this._maxPayload > 0) {\n return cb(\n error(\n RangeError,\n 'Max payload size exceeded',\n false,\n 1009,\n 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'\n )\n );\n }\n\n this._fragments.push(buf);\n }\n\n const er = this.dataMessage();\n if (er) return cb(er);\n\n this.startLoop(cb);\n });\n }\n\n /**\n * Handles a data message.\n *\n * @return {(Error|undefined)} A possible error\n * @private\n */\n dataMessage() {\n if (this._fin) {\n const messageLength = this._messageLength;\n const fragments = this._fragments;\n\n this._totalPayloadLength = 0;\n this._messageLength = 0;\n this._fragmented = 0;\n this._fragments = [];\n\n if (this._opcode === 2) {\n let data;\n\n if (this._binaryType === 'nodebuffer') {\n data = concat(fragments, messageLength);\n } else if (this._binaryType === 'arraybuffer') {\n data = toArrayBuffer(concat(fragments, messageLength));\n } else {\n data = fragments;\n }\n\n this.emit('message', data);\n } else {\n const buf = concat(fragments, messageLength);\n\n if (!isValidUTF8(buf)) {\n this._loop = false;\n return error(\n Error,\n 'invalid UTF-8 sequence',\n true,\n 1007,\n 'WS_ERR_INVALID_UTF8'\n );\n }\n\n this.emit('message', buf.toString());\n }\n }\n\n this._state = GET_INFO;\n }\n\n /**\n * Handles a control message.\n *\n * @param {Buffer} data Data to handle\n * @return {(Error|RangeError|undefined)} A possible error\n * @private\n */\n controlMessage(data) {\n if (this._opcode === 0x08) {\n this._loop = false;\n\n if (data.length === 0) {\n this.emit('conclude', 1005, '');\n this.end();\n } else if (data.length === 1) {\n return error(\n RangeError,\n 'invalid payload length 1',\n true,\n 1002,\n 'WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH'\n );\n } else {\n const code = data.readUInt16BE(0);\n\n if (!isValidStatusCode(code)) {\n return error(\n RangeError,\n `invalid status code ${code}`,\n true,\n 1002,\n 'WS_ERR_INVALID_CLOSE_CODE'\n );\n }\n\n const buf = data.slice(2);\n\n if (!isValidUTF8(buf)) {\n return error(\n Error,\n 'invalid UTF-8 sequence',\n true,\n 1007,\n 'WS_ERR_INVALID_UTF8'\n );\n }\n\n this.emit('conclude', code, buf.toString());\n this.end();\n }\n } else if (this._opcode === 0x09) {\n this.emit('ping', data);\n } else {\n this.emit('pong', data);\n }\n\n this._state = GET_INFO;\n }\n}\n\nmodule.exports = Receiver;\n\n/**\n * Builds an error object.\n *\n * @param {function(new:Error|RangeError)} ErrorCtor The error constructor\n * @param {String} message The error message\n * @param {Boolean} prefix Specifies whether or not to add a default prefix to\n * `message`\n * @param {Number} statusCode The status code\n * @param {String} errorCode The exposed error code\n * @return {(Error|RangeError)} The error\n * @private\n */\nfunction error(ErrorCtor, message, prefix, statusCode, errorCode) {\n const err = new ErrorCtor(\n prefix ? `Invalid WebSocket frame: ${message}` : message\n );\n\n Error.captureStackTrace(err, error);\n err.code = errorCode;\n err[kStatusCode] = statusCode;\n return err;\n}\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^net|tls$\" }] */\n\n'use strict';\n\nconst net = require('net');\nconst tls = require('tls');\nconst { randomFillSync } = require('crypto');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst { EMPTY_BUFFER } = require('./constants');\nconst { isValidStatusCode } = require('./validation');\nconst { mask: applyMask, toBuffer } = require('./buffer-util');\n\nconst mask = Buffer.alloc(4);\n\n/**\n * HyBi Sender implementation.\n */\nclass Sender {\n /**\n * Creates a Sender instance.\n *\n * @param {(net.Socket|tls.Socket)} socket The connection socket\n * @param {Object} [extensions] An object containing the negotiated extensions\n */\n constructor(socket, extensions) {\n this._extensions = extensions || {};\n this._socket = socket;\n\n this._firstFragment = true;\n this._compress = false;\n\n this._bufferedBytes = 0;\n this._deflating = false;\n this._queue = [];\n }\n\n /**\n * Frames a piece of data according to the HyBi WebSocket protocol.\n *\n * @param {Buffer} data The data to frame\n * @param {Object} options Options object\n * @param {Number} options.opcode The opcode\n * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be\n * modified\n * @param {Boolean} [options.fin=false] Specifies whether or not to set the\n * FIN bit\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the\n * RSV1 bit\n * @return {Buffer[]} The framed data as a list of `Buffer` instances\n * @public\n */\n static frame(data, options) {\n const merge = options.mask && options.readOnly;\n let offset = options.mask ? 6 : 2;\n let payloadLength = data.length;\n\n if (data.length >= 65536) {\n offset += 8;\n payloadLength = 127;\n } else if (data.length > 125) {\n offset += 2;\n payloadLength = 126;\n }\n\n const target = Buffer.allocUnsafe(merge ? data.length + offset : offset);\n\n target[0] = options.fin ? options.opcode | 0x80 : options.opcode;\n if (options.rsv1) target[0] |= 0x40;\n\n target[1] = payloadLength;\n\n if (payloadLength === 126) {\n target.writeUInt16BE(data.length, 2);\n } else if (payloadLength === 127) {\n target.writeUInt32BE(0, 2);\n target.writeUInt32BE(data.length, 6);\n }\n\n if (!options.mask) return [target, data];\n\n randomFillSync(mask, 0, 4);\n\n target[1] |= 0x80;\n target[offset - 4] = mask[0];\n target[offset - 3] = mask[1];\n target[offset - 2] = mask[2];\n target[offset - 1] = mask[3];\n\n if (merge) {\n applyMask(data, mask, target, offset, data.length);\n return [target];\n }\n\n applyMask(data, mask, data, 0, data.length);\n return [target, data];\n }\n\n /**\n * Sends a close message to the other peer.\n *\n * @param {Number} [code] The status code component of the body\n * @param {String} [data] The message component of the body\n * @param {Boolean} [mask=false] Specifies whether or not to mask the message\n * @param {Function} [cb] Callback\n * @public\n */\n close(code, data, mask, cb) {\n let buf;\n\n if (code === undefined) {\n buf = EMPTY_BUFFER;\n } else if (typeof code !== 'number' || !isValidStatusCode(code)) {\n throw new TypeError('First argument must be a valid error code number');\n } else if (data === undefined || data === '') {\n buf = Buffer.allocUnsafe(2);\n buf.writeUInt16BE(code, 0);\n } else {\n const length = Buffer.byteLength(data);\n\n if (length > 123) {\n throw new RangeError('The message must not be greater than 123 bytes');\n }\n\n buf = Buffer.allocUnsafe(2 + length);\n buf.writeUInt16BE(code, 0);\n buf.write(data, 2);\n }\n\n if (this._deflating) {\n this.enqueue([this.doClose, buf, mask, cb]);\n } else {\n this.doClose(buf, mask, cb);\n }\n }\n\n /**\n * Frames and sends a close message.\n *\n * @param {Buffer} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback\n * @private\n */\n doClose(data, mask, cb) {\n this.sendFrame(\n Sender.frame(data, {\n fin: true,\n rsv1: false,\n opcode: 0x08,\n mask,\n readOnly: false\n }),\n cb\n );\n }\n\n /**\n * Sends a ping message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback\n * @public\n */\n ping(data, mask, cb) {\n const buf = toBuffer(data);\n\n if (buf.length > 125) {\n throw new RangeError('The data size must not be greater than 125 bytes');\n }\n\n if (this._deflating) {\n this.enqueue([this.doPing, buf, mask, toBuffer.readOnly, cb]);\n } else {\n this.doPing(buf, mask, toBuffer.readOnly, cb);\n }\n }\n\n /**\n * Frames and sends a ping message.\n *\n * @param {Buffer} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Boolean} [readOnly=false] Specifies whether `data` can be modified\n * @param {Function} [cb] Callback\n * @private\n */\n doPing(data, mask, readOnly, cb) {\n this.sendFrame(\n Sender.frame(data, {\n fin: true,\n rsv1: false,\n opcode: 0x09,\n mask,\n readOnly\n }),\n cb\n );\n }\n\n /**\n * Sends a pong message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback\n * @public\n */\n pong(data, mask, cb) {\n const buf = toBuffer(data);\n\n if (buf.length > 125) {\n throw new RangeError('The data size must not be greater than 125 bytes');\n }\n\n if (this._deflating) {\n this.enqueue([this.doPong, buf, mask, toBuffer.readOnly, cb]);\n } else {\n this.doPong(buf, mask, toBuffer.readOnly, cb);\n }\n }\n\n /**\n * Frames and sends a pong message.\n *\n * @param {Buffer} data The message to send\n * @param {Boolean} [mask=false] Specifies whether or not to mask `data`\n * @param {Boolean} [readOnly=false] Specifies whether `data` can be modified\n * @param {Function} [cb] Callback\n * @private\n */\n doPong(data, mask, readOnly, cb) {\n this.sendFrame(\n Sender.frame(data, {\n fin: true,\n rsv1: false,\n opcode: 0x0a,\n mask,\n readOnly\n }),\n cb\n );\n }\n\n /**\n * Sends a data message to the other peer.\n *\n * @param {*} data The message to send\n * @param {Object} options Options object\n * @param {Boolean} [options.compress=false] Specifies whether or not to\n * compress `data`\n * @param {Boolean} [options.binary=false] Specifies whether `data` is binary\n * or text\n * @param {Boolean} [options.fin=false] Specifies whether the fragment is the\n * last one\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Function} [cb] Callback\n * @public\n */\n send(data, options, cb) {\n const buf = toBuffer(data);\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n let opcode = options.binary ? 2 : 1;\n let rsv1 = options.compress;\n\n if (this._firstFragment) {\n this._firstFragment = false;\n if (rsv1 && perMessageDeflate) {\n rsv1 = buf.length >= perMessageDeflate._threshold;\n }\n this._compress = rsv1;\n } else {\n rsv1 = false;\n opcode = 0;\n }\n\n if (options.fin) this._firstFragment = true;\n\n if (perMessageDeflate) {\n const opts = {\n fin: options.fin,\n rsv1,\n opcode,\n mask: options.mask,\n readOnly: toBuffer.readOnly\n };\n\n if (this._deflating) {\n this.enqueue([this.dispatch, buf, this._compress, opts, cb]);\n } else {\n this.dispatch(buf, this._compress, opts, cb);\n }\n } else {\n this.sendFrame(\n Sender.frame(buf, {\n fin: options.fin,\n rsv1: false,\n opcode,\n mask: options.mask,\n readOnly: toBuffer.readOnly\n }),\n cb\n );\n }\n }\n\n /**\n * Dispatches a data message.\n *\n * @param {Buffer} data The message to send\n * @param {Boolean} [compress=false] Specifies whether or not to compress\n * `data`\n * @param {Object} options Options object\n * @param {Number} options.opcode The opcode\n * @param {Boolean} [options.readOnly=false] Specifies whether `data` can be\n * modified\n * @param {Boolean} [options.fin=false] Specifies whether or not to set the\n * FIN bit\n * @param {Boolean} [options.mask=false] Specifies whether or not to mask\n * `data`\n * @param {Boolean} [options.rsv1=false] Specifies whether or not to set the\n * RSV1 bit\n * @param {Function} [cb] Callback\n * @private\n */\n dispatch(data, compress, options, cb) {\n if (!compress) {\n this.sendFrame(Sender.frame(data, options), cb);\n return;\n }\n\n const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];\n\n this._bufferedBytes += data.length;\n this._deflating = true;\n perMessageDeflate.compress(data, options.fin, (_, buf) => {\n if (this._socket.destroyed) {\n const err = new Error(\n 'The socket was closed while data was being compressed'\n );\n\n if (typeof cb === 'function') cb(err);\n\n for (let i = 0; i < this._queue.length; i++) {\n const callback = this._queue[i][4];\n\n if (typeof callback === 'function') callback(err);\n }\n\n return;\n }\n\n this._bufferedBytes -= data.length;\n this._deflating = false;\n options.readOnly = false;\n this.sendFrame(Sender.frame(buf, options), cb);\n this.dequeue();\n });\n }\n\n /**\n * Executes queued send operations.\n *\n * @private\n */\n dequeue() {\n while (!this._deflating && this._queue.length) {\n const params = this._queue.shift();\n\n this._bufferedBytes -= params[1].length;\n Reflect.apply(params[0], this, params.slice(1));\n }\n }\n\n /**\n * Enqueues a send operation.\n *\n * @param {Array} params Send operation parameters.\n * @private\n */\n enqueue(params) {\n this._bufferedBytes += params[1].length;\n this._queue.push(params);\n }\n\n /**\n * Sends a frame.\n *\n * @param {Buffer[]} list The frame to send\n * @param {Function} [cb] Callback\n * @private\n */\n sendFrame(list, cb) {\n if (list.length === 2) {\n this._socket.cork();\n this._socket.write(list[0]);\n this._socket.write(list[1], cb);\n this._socket.uncork();\n } else {\n this._socket.write(list[0], cb);\n }\n }\n}\n\nmodule.exports = Sender;\n","'use strict';\n\n/**\n * Class representing an event.\n *\n * @private\n */\nclass Event {\n /**\n * Create a new `Event`.\n *\n * @param {String} type The name of the event\n * @param {Object} target A reference to the target to which the event was\n * dispatched\n */\n constructor(type, target) {\n this.target = target;\n this.type = type;\n }\n}\n\n/**\n * Class representing a message event.\n *\n * @extends Event\n * @private\n */\nclass MessageEvent extends Event {\n /**\n * Create a new `MessageEvent`.\n *\n * @param {(String|Buffer|ArrayBuffer|Buffer[])} data The received data\n * @param {WebSocket} target A reference to the target to which the event was\n * dispatched\n */\n constructor(data, target) {\n super('message', target);\n\n this.data = data;\n }\n}\n\n/**\n * Class representing a close event.\n *\n * @extends Event\n * @private\n */\nclass CloseEvent extends Event {\n /**\n * Create a new `CloseEvent`.\n *\n * @param {Number} code The status code explaining why the connection is being\n * closed\n * @param {String} reason A human-readable string explaining why the\n * connection is closing\n * @param {WebSocket} target A reference to the target to which the event was\n * dispatched\n */\n constructor(code, reason, target) {\n super('close', target);\n\n this.wasClean = target._closeFrameReceived && target._closeFrameSent;\n this.reason = reason;\n this.code = code;\n }\n}\n\n/**\n * Class representing an open event.\n *\n * @extends Event\n * @private\n */\nclass OpenEvent extends Event {\n /**\n * Create a new `OpenEvent`.\n *\n * @param {WebSocket} target A reference to the target to which the event was\n * dispatched\n */\n constructor(target) {\n super('open', target);\n }\n}\n\n/**\n * Class representing an error event.\n *\n * @extends Event\n * @private\n */\nclass ErrorEvent extends Event {\n /**\n * Create a new `ErrorEvent`.\n *\n * @param {Object} error The error that generated this event\n * @param {WebSocket} target A reference to the target to which the event was\n * dispatched\n */\n constructor(error, target) {\n super('error', target);\n\n this.message = error.message;\n this.error = error;\n }\n}\n\n/**\n * This provides methods for emulating the `EventTarget` interface. It's not\n * meant to be used directly.\n *\n * @mixin\n */\nconst EventTarget = {\n /**\n * Register an event listener.\n *\n * @param {String} type A string representing the event type to listen for\n * @param {Function} listener The listener to add\n * @param {Object} [options] An options object specifies characteristics about\n * the event listener\n * @param {Boolean} [options.once=false] A `Boolean`` indicating that the\n * listener should be invoked at most once after being added. If `true`,\n * the listener would be automatically removed when invoked.\n * @public\n */\n addEventListener(type, listener, options) {\n if (typeof listener !== 'function') return;\n\n function onMessage(data) {\n listener.call(this, new MessageEvent(data, this));\n }\n\n function onClose(code, message) {\n listener.call(this, new CloseEvent(code, message, this));\n }\n\n function onError(error) {\n listener.call(this, new ErrorEvent(error, this));\n }\n\n function onOpen() {\n listener.call(this, new OpenEvent(this));\n }\n\n const method = options && options.once ? 'once' : 'on';\n\n if (type === 'message') {\n onMessage._listener = listener;\n this[method](type, onMessage);\n } else if (type === 'close') {\n onClose._listener = listener;\n this[method](type, onClose);\n } else if (type === 'error') {\n onError._listener = listener;\n this[method](type, onError);\n } else if (type === 'open') {\n onOpen._listener = listener;\n this[method](type, onOpen);\n } else {\n this[method](type, listener);\n }\n },\n\n /**\n * Remove an event listener.\n *\n * @param {String} type A string representing the event type to remove\n * @param {Function} listener The listener to remove\n * @public\n */\n removeEventListener(type, listener) {\n const listeners = this.listeners(type);\n\n for (let i = 0; i < listeners.length; i++) {\n if (listeners[i] === listener || listeners[i]._listener === listener) {\n this.removeListener(type, listeners[i]);\n }\n }\n }\n};\n\nmodule.exports = EventTarget;\n","'use strict';\n\n//\n// Allowed token characters:\n//\n// '!', '#', '$', '%', '&', ''', '*', '+', '-',\n// '.', 0-9, A-Z, '^', '_', '`', a-z, '|', '~'\n//\n// tokenChars[32] === 0 // ' '\n// tokenChars[33] === 1 // '!'\n// tokenChars[34] === 0 // '\"'\n// ...\n//\n// prettier-ignore\nconst tokenChars = [\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0 - 15\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16 - 31\n 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, // 32 - 47\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, // 48 - 63\n 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64 - 79\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, // 80 - 95\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96 - 111\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0 // 112 - 127\n];\n\n/**\n * Adds an offer to the map of extension offers or a parameter to the map of\n * parameters.\n *\n * @param {Object} dest The map of extension offers or parameters\n * @param {String} name The extension or parameter name\n * @param {(Object|Boolean|String)} elem The extension parameters or the\n * parameter value\n * @private\n */\nfunction push(dest, name, elem) {\n if (dest[name] === undefined) dest[name] = [elem];\n else dest[name].push(elem);\n}\n\n/**\n * Parses the `Sec-WebSocket-Extensions` header into an object.\n *\n * @param {String} header The field value of the header\n * @return {Object} The parsed object\n * @public\n */\nfunction parse(header) {\n const offers = Object.create(null);\n\n if (header === undefined || header === '') return offers;\n\n let params = Object.create(null);\n let mustUnescape = false;\n let isEscaping = false;\n let inQuotes = false;\n let extensionName;\n let paramName;\n let start = -1;\n let end = -1;\n let i = 0;\n\n for (; i < header.length; i++) {\n const code = header.charCodeAt(i);\n\n if (extensionName === undefined) {\n if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (code === 0x20 /* ' ' */ || code === 0x09 /* '\\t' */) {\n if (end === -1 && start !== -1) end = i;\n } else if (code === 0x3b /* ';' */ || code === 0x2c /* ',' */) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n const name = header.slice(start, end);\n if (code === 0x2c) {\n push(offers, name, params);\n params = Object.create(null);\n } else {\n extensionName = name;\n }\n\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else if (paramName === undefined) {\n if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (code === 0x20 || code === 0x09) {\n if (end === -1 && start !== -1) end = i;\n } else if (code === 0x3b || code === 0x2c) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n push(params, header.slice(start, end), true);\n if (code === 0x2c) {\n push(offers, extensionName, params);\n params = Object.create(null);\n extensionName = undefined;\n }\n\n start = end = -1;\n } else if (code === 0x3d /* '=' */ && start !== -1 && end === -1) {\n paramName = header.slice(start, i);\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else {\n //\n // The value of a quoted-string after unescaping must conform to the\n // token ABNF, so only token characters are valid.\n // Ref: https://tools.ietf.org/html/rfc6455#section-9.1\n //\n if (isEscaping) {\n if (tokenChars[code] !== 1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n if (start === -1) start = i;\n else if (!mustUnescape) mustUnescape = true;\n isEscaping = false;\n } else if (inQuotes) {\n if (tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (code === 0x22 /* '\"' */ && start !== -1) {\n inQuotes = false;\n end = i;\n } else if (code === 0x5c /* '\\' */) {\n isEscaping = true;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n } else if (code === 0x22 && header.charCodeAt(i - 1) === 0x3d) {\n inQuotes = true;\n } else if (end === -1 && tokenChars[code] === 1) {\n if (start === -1) start = i;\n } else if (start !== -1 && (code === 0x20 || code === 0x09)) {\n if (end === -1) end = i;\n } else if (code === 0x3b || code === 0x2c) {\n if (start === -1) {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n\n if (end === -1) end = i;\n let value = header.slice(start, end);\n if (mustUnescape) {\n value = value.replace(/\\\\/g, '');\n mustUnescape = false;\n }\n push(params, paramName, value);\n if (code === 0x2c) {\n push(offers, extensionName, params);\n params = Object.create(null);\n extensionName = undefined;\n }\n\n paramName = undefined;\n start = end = -1;\n } else {\n throw new SyntaxError(`Unexpected character at index ${i}`);\n }\n }\n }\n\n if (start === -1 || inQuotes) {\n throw new SyntaxError('Unexpected end of input');\n }\n\n if (end === -1) end = i;\n const token = header.slice(start, end);\n if (extensionName === undefined) {\n push(offers, token, params);\n } else {\n if (paramName === undefined) {\n push(params, token, true);\n } else if (mustUnescape) {\n push(params, paramName, token.replace(/\\\\/g, ''));\n } else {\n push(params, paramName, token);\n }\n push(offers, extensionName, params);\n }\n\n return offers;\n}\n\n/**\n * Builds the `Sec-WebSocket-Extensions` header field value.\n *\n * @param {Object} extensions The map of extensions and parameters to format\n * @return {String} A string representing the given object\n * @public\n */\nfunction format(extensions) {\n return Object.keys(extensions)\n .map((extension) => {\n let configurations = extensions[extension];\n if (!Array.isArray(configurations)) configurations = [configurations];\n return configurations\n .map((params) => {\n return [extension]\n .concat(\n Object.keys(params).map((k) => {\n let values = params[k];\n if (!Array.isArray(values)) values = [values];\n return values\n .map((v) => (v === true ? k : `${k}=${v}`))\n .join('; ');\n })\n )\n .join('; ');\n })\n .join(', ');\n })\n .join(', ');\n}\n\nmodule.exports = { format, parse };\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^Readable$\" }] */\n\n'use strict';\n\nconst EventEmitter = require('events');\nconst https = require('https');\nconst http = require('http');\nconst net = require('net');\nconst tls = require('tls');\nconst { randomBytes, createHash } = require('crypto');\nconst { Readable } = require('stream');\nconst { URL } = require('url');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst Receiver = require('./receiver');\nconst Sender = require('./sender');\nconst {\n BINARY_TYPES,\n EMPTY_BUFFER,\n GUID,\n kStatusCode,\n kWebSocket,\n NOOP\n} = require('./constants');\nconst { addEventListener, removeEventListener } = require('./event-target');\nconst { format, parse } = require('./extension');\nconst { toBuffer } = require('./buffer-util');\n\nconst readyStates = ['CONNECTING', 'OPEN', 'CLOSING', 'CLOSED'];\nconst protocolVersions = [8, 13];\nconst closeTimeout = 30 * 1000;\n\n/**\n * Class representing a WebSocket.\n *\n * @extends EventEmitter\n */\nclass WebSocket extends EventEmitter {\n /**\n * Create a new `WebSocket`.\n *\n * @param {(String|URL)} address The URL to which to connect\n * @param {(String|String[])} [protocols] The subprotocols\n * @param {Object} [options] Connection options\n */\n constructor(address, protocols, options) {\n super();\n\n this._binaryType = BINARY_TYPES[0];\n this._closeCode = 1006;\n this._closeFrameReceived = false;\n this._closeFrameSent = false;\n this._closeMessage = '';\n this._closeTimer = null;\n this._extensions = {};\n this._protocol = '';\n this._readyState = WebSocket.CONNECTING;\n this._receiver = null;\n this._sender = null;\n this._socket = null;\n\n if (address !== null) {\n this._bufferedAmount = 0;\n this._isServer = false;\n this._redirects = 0;\n\n if (Array.isArray(protocols)) {\n protocols = protocols.join(', ');\n } else if (typeof protocols === 'object' && protocols !== null) {\n options = protocols;\n protocols = undefined;\n }\n\n initAsClient(this, address, protocols, options);\n } else {\n this._isServer = true;\n }\n }\n\n /**\n * This deviates from the WHATWG interface since ws doesn't support the\n * required default \"blob\" type (instead we define a custom \"nodebuffer\"\n * type).\n *\n * @type {String}\n */\n get binaryType() {\n return this._binaryType;\n }\n\n set binaryType(type) {\n if (!BINARY_TYPES.includes(type)) return;\n\n this._binaryType = type;\n\n //\n // Allow to change `binaryType` on the fly.\n //\n if (this._receiver) this._receiver._binaryType = type;\n }\n\n /**\n * @type {Number}\n */\n get bufferedAmount() {\n if (!this._socket) return this._bufferedAmount;\n\n return this._socket._writableState.length + this._sender._bufferedBytes;\n }\n\n /**\n * @type {String}\n */\n get extensions() {\n return Object.keys(this._extensions).join();\n }\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onclose() {\n return undefined;\n }\n\n /* istanbul ignore next */\n set onclose(listener) {}\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onerror() {\n return undefined;\n }\n\n /* istanbul ignore next */\n set onerror(listener) {}\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onopen() {\n return undefined;\n }\n\n /* istanbul ignore next */\n set onopen(listener) {}\n\n /**\n * @type {Function}\n */\n /* istanbul ignore next */\n get onmessage() {\n return undefined;\n }\n\n /* istanbul ignore next */\n set onmessage(listener) {}\n\n /**\n * @type {String}\n */\n get protocol() {\n return this._protocol;\n }\n\n /**\n * @type {Number}\n */\n get readyState() {\n return this._readyState;\n }\n\n /**\n * @type {String}\n */\n get url() {\n return this._url;\n }\n\n /**\n * Set up the socket and the internal resources.\n *\n * @param {(net.Socket|tls.Socket)} socket The network socket between the\n * server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Number} [maxPayload=0] The maximum allowed message size\n * @private\n */\n setSocket(socket, head, maxPayload) {\n const receiver = new Receiver(\n this.binaryType,\n this._extensions,\n this._isServer,\n maxPayload\n );\n\n this._sender = new Sender(socket, this._extensions);\n this._receiver = receiver;\n this._socket = socket;\n\n receiver[kWebSocket] = this;\n socket[kWebSocket] = this;\n\n receiver.on('conclude', receiverOnConclude);\n receiver.on('drain', receiverOnDrain);\n receiver.on('error', receiverOnError);\n receiver.on('message', receiverOnMessage);\n receiver.on('ping', receiverOnPing);\n receiver.on('pong', receiverOnPong);\n\n socket.setTimeout(0);\n socket.setNoDelay();\n\n if (head.length > 0) socket.unshift(head);\n\n socket.on('close', socketOnClose);\n socket.on('data', socketOnData);\n socket.on('end', socketOnEnd);\n socket.on('error', socketOnError);\n\n this._readyState = WebSocket.OPEN;\n this.emit('open');\n }\n\n /**\n * Emit the `'close'` event.\n *\n * @private\n */\n emitClose() {\n if (!this._socket) {\n this._readyState = WebSocket.CLOSED;\n this.emit('close', this._closeCode, this._closeMessage);\n return;\n }\n\n if (this._extensions[PerMessageDeflate.extensionName]) {\n this._extensions[PerMessageDeflate.extensionName].cleanup();\n }\n\n this._receiver.removeAllListeners();\n this._readyState = WebSocket.CLOSED;\n this.emit('close', this._closeCode, this._closeMessage);\n }\n\n /**\n * Start a closing handshake.\n *\n * +----------+ +-----------+ +----------+\n * - - -|ws.close()|-->|close frame|-->|ws.close()|- - -\n * | +----------+ +-----------+ +----------+ |\n * +----------+ +-----------+ |\n * CLOSING |ws.close()|<--|close frame|<--+-----+ CLOSING\n * +----------+ +-----------+ |\n * | | | +---+ |\n * +------------------------+-->|fin| - - - -\n * | +---+ | +---+\n * - - - - -|fin|<---------------------+\n * +---+\n *\n * @param {Number} [code] Status code explaining why the connection is closing\n * @param {String} [data] A string explaining why the connection is closing\n * @public\n */\n close(code, data) {\n if (this.readyState === WebSocket.CLOSED) return;\n if (this.readyState === WebSocket.CONNECTING) {\n const msg = 'WebSocket was closed before the connection was established';\n return abortHandshake(this, this._req, msg);\n }\n\n if (this.readyState === WebSocket.CLOSING) {\n if (\n this._closeFrameSent &&\n (this._closeFrameReceived || this._receiver._writableState.errorEmitted)\n ) {\n this._socket.end();\n }\n\n return;\n }\n\n this._readyState = WebSocket.CLOSING;\n this._sender.close(code, data, !this._isServer, (err) => {\n //\n // This error is handled by the `'error'` listener on the socket. We only\n // want to know if the close frame has been sent here.\n //\n if (err) return;\n\n this._closeFrameSent = true;\n\n if (\n this._closeFrameReceived ||\n this._receiver._writableState.errorEmitted\n ) {\n this._socket.end();\n }\n });\n\n //\n // Specify a timeout for the closing handshake to complete.\n //\n this._closeTimer = setTimeout(\n this._socket.destroy.bind(this._socket),\n closeTimeout\n );\n }\n\n /**\n * Send a ping.\n *\n * @param {*} [data] The data to send\n * @param {Boolean} [mask] Indicates whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when the ping is sent\n * @public\n */\n ping(data, mask, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof data === 'function') {\n cb = data;\n data = mask = undefined;\n } else if (typeof mask === 'function') {\n cb = mask;\n mask = undefined;\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n if (mask === undefined) mask = !this._isServer;\n this._sender.ping(data || EMPTY_BUFFER, mask, cb);\n }\n\n /**\n * Send a pong.\n *\n * @param {*} [data] The data to send\n * @param {Boolean} [mask] Indicates whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when the pong is sent\n * @public\n */\n pong(data, mask, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof data === 'function') {\n cb = data;\n data = mask = undefined;\n } else if (typeof mask === 'function') {\n cb = mask;\n mask = undefined;\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n if (mask === undefined) mask = !this._isServer;\n this._sender.pong(data || EMPTY_BUFFER, mask, cb);\n }\n\n /**\n * Send a data message.\n *\n * @param {*} data The message to send\n * @param {Object} [options] Options object\n * @param {Boolean} [options.compress] Specifies whether or not to compress\n * `data`\n * @param {Boolean} [options.binary] Specifies whether `data` is binary or\n * text\n * @param {Boolean} [options.fin=true] Specifies whether the fragment is the\n * last one\n * @param {Boolean} [options.mask] Specifies whether or not to mask `data`\n * @param {Function} [cb] Callback which is executed when data is written out\n * @public\n */\n send(data, options, cb) {\n if (this.readyState === WebSocket.CONNECTING) {\n throw new Error('WebSocket is not open: readyState 0 (CONNECTING)');\n }\n\n if (typeof options === 'function') {\n cb = options;\n options = {};\n }\n\n if (typeof data === 'number') data = data.toString();\n\n if (this.readyState !== WebSocket.OPEN) {\n sendAfterClose(this, data, cb);\n return;\n }\n\n const opts = {\n binary: typeof data !== 'string',\n mask: !this._isServer,\n compress: true,\n fin: true,\n ...options\n };\n\n if (!this._extensions[PerMessageDeflate.extensionName]) {\n opts.compress = false;\n }\n\n this._sender.send(data || EMPTY_BUFFER, opts, cb);\n }\n\n /**\n * Forcibly close the connection.\n *\n * @public\n */\n terminate() {\n if (this.readyState === WebSocket.CLOSED) return;\n if (this.readyState === WebSocket.CONNECTING) {\n const msg = 'WebSocket was closed before the connection was established';\n return abortHandshake(this, this._req, msg);\n }\n\n if (this._socket) {\n this._readyState = WebSocket.CLOSING;\n this._socket.destroy();\n }\n }\n}\n\n/**\n * @constant {Number} CONNECTING\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CONNECTING', {\n enumerable: true,\n value: readyStates.indexOf('CONNECTING')\n});\n\n/**\n * @constant {Number} CONNECTING\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CONNECTING', {\n enumerable: true,\n value: readyStates.indexOf('CONNECTING')\n});\n\n/**\n * @constant {Number} OPEN\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'OPEN', {\n enumerable: true,\n value: readyStates.indexOf('OPEN')\n});\n\n/**\n * @constant {Number} OPEN\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'OPEN', {\n enumerable: true,\n value: readyStates.indexOf('OPEN')\n});\n\n/**\n * @constant {Number} CLOSING\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CLOSING', {\n enumerable: true,\n value: readyStates.indexOf('CLOSING')\n});\n\n/**\n * @constant {Number} CLOSING\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CLOSING', {\n enumerable: true,\n value: readyStates.indexOf('CLOSING')\n});\n\n/**\n * @constant {Number} CLOSED\n * @memberof WebSocket\n */\nObject.defineProperty(WebSocket, 'CLOSED', {\n enumerable: true,\n value: readyStates.indexOf('CLOSED')\n});\n\n/**\n * @constant {Number} CLOSED\n * @memberof WebSocket.prototype\n */\nObject.defineProperty(WebSocket.prototype, 'CLOSED', {\n enumerable: true,\n value: readyStates.indexOf('CLOSED')\n});\n\n[\n 'binaryType',\n 'bufferedAmount',\n 'extensions',\n 'protocol',\n 'readyState',\n 'url'\n].forEach((property) => {\n Object.defineProperty(WebSocket.prototype, property, { enumerable: true });\n});\n\n//\n// Add the `onopen`, `onerror`, `onclose`, and `onmessage` attributes.\n// See https://html.spec.whatwg.org/multipage/comms.html#the-websocket-interface\n//\n['open', 'error', 'close', 'message'].forEach((method) => {\n Object.defineProperty(WebSocket.prototype, `on${method}`, {\n enumerable: true,\n get() {\n const listeners = this.listeners(method);\n for (let i = 0; i < listeners.length; i++) {\n if (listeners[i]._listener) return listeners[i]._listener;\n }\n\n return undefined;\n },\n set(listener) {\n const listeners = this.listeners(method);\n for (let i = 0; i < listeners.length; i++) {\n //\n // Remove only the listeners added via `addEventListener`.\n //\n if (listeners[i]._listener) this.removeListener(method, listeners[i]);\n }\n this.addEventListener(method, listener);\n }\n });\n});\n\nWebSocket.prototype.addEventListener = addEventListener;\nWebSocket.prototype.removeEventListener = removeEventListener;\n\nmodule.exports = WebSocket;\n\n/**\n * Initialize a WebSocket client.\n *\n * @param {WebSocket} websocket The client to initialize\n * @param {(String|URL)} address The URL to which to connect\n * @param {String} [protocols] The subprotocols\n * @param {Object} [options] Connection options\n * @param {(Boolean|Object)} [options.perMessageDeflate=true] Enable/disable\n * permessage-deflate\n * @param {Number} [options.handshakeTimeout] Timeout in milliseconds for the\n * handshake request\n * @param {Number} [options.protocolVersion=13] Value of the\n * `Sec-WebSocket-Version` header\n * @param {String} [options.origin] Value of the `Origin` or\n * `Sec-WebSocket-Origin` header\n * @param {Number} [options.maxPayload=104857600] The maximum allowed message\n * size\n * @param {Boolean} [options.followRedirects=false] Whether or not to follow\n * redirects\n * @param {Number} [options.maxRedirects=10] The maximum number of redirects\n * allowed\n * @private\n */\nfunction initAsClient(websocket, address, protocols, options) {\n const opts = {\n protocolVersion: protocolVersions[1],\n maxPayload: 100 * 1024 * 1024,\n perMessageDeflate: true,\n followRedirects: false,\n maxRedirects: 10,\n ...options,\n createConnection: undefined,\n socketPath: undefined,\n hostname: undefined,\n protocol: undefined,\n timeout: undefined,\n method: undefined,\n host: undefined,\n path: undefined,\n port: undefined\n };\n\n if (!protocolVersions.includes(opts.protocolVersion)) {\n throw new RangeError(\n `Unsupported protocol version: ${opts.protocolVersion} ` +\n `(supported versions: ${protocolVersions.join(', ')})`\n );\n }\n\n let parsedUrl;\n\n if (address instanceof URL) {\n parsedUrl = address;\n websocket._url = address.href;\n } else {\n parsedUrl = new URL(address);\n websocket._url = address;\n }\n\n const isUnixSocket = parsedUrl.protocol === 'ws+unix:';\n\n if (!parsedUrl.host && (!isUnixSocket || !parsedUrl.pathname)) {\n const err = new Error(`Invalid URL: ${websocket.url}`);\n\n if (websocket._redirects === 0) {\n throw err;\n } else {\n emitErrorAndClose(websocket, err);\n return;\n }\n }\n\n const isSecure =\n parsedUrl.protocol === 'wss:' || parsedUrl.protocol === 'https:';\n const defaultPort = isSecure ? 443 : 80;\n const key = randomBytes(16).toString('base64');\n const get = isSecure ? https.get : http.get;\n let perMessageDeflate;\n\n opts.createConnection = isSecure ? tlsConnect : netConnect;\n opts.defaultPort = opts.defaultPort || defaultPort;\n opts.port = parsedUrl.port || defaultPort;\n opts.host = parsedUrl.hostname.startsWith('[')\n ? parsedUrl.hostname.slice(1, -1)\n : parsedUrl.hostname;\n opts.headers = {\n 'Sec-WebSocket-Version': opts.protocolVersion,\n 'Sec-WebSocket-Key': key,\n Connection: 'Upgrade',\n Upgrade: 'websocket',\n ...opts.headers\n };\n opts.path = parsedUrl.pathname + parsedUrl.search;\n opts.timeout = opts.handshakeTimeout;\n\n if (opts.perMessageDeflate) {\n perMessageDeflate = new PerMessageDeflate(\n opts.perMessageDeflate !== true ? opts.perMessageDeflate : {},\n false,\n opts.maxPayload\n );\n opts.headers['Sec-WebSocket-Extensions'] = format({\n [PerMessageDeflate.extensionName]: perMessageDeflate.offer()\n });\n }\n if (protocols) {\n opts.headers['Sec-WebSocket-Protocol'] = protocols;\n }\n if (opts.origin) {\n if (opts.protocolVersion < 13) {\n opts.headers['Sec-WebSocket-Origin'] = opts.origin;\n } else {\n opts.headers.Origin = opts.origin;\n }\n }\n if (parsedUrl.username || parsedUrl.password) {\n opts.auth = `${parsedUrl.username}:${parsedUrl.password}`;\n }\n\n if (isUnixSocket) {\n const parts = opts.path.split(':');\n\n opts.socketPath = parts[0];\n opts.path = parts[1];\n }\n\n if (opts.followRedirects) {\n if (websocket._redirects === 0) {\n websocket._originalUnixSocket = isUnixSocket;\n websocket._originalSecure = isSecure;\n websocket._originalHostOrSocketPath = isUnixSocket\n ? opts.socketPath\n : parsedUrl.host;\n\n const headers = options && options.headers;\n\n //\n // Shallow copy the user provided options so that headers can be changed\n // without mutating the original object.\n //\n options = { ...options, headers: {} };\n\n if (headers) {\n for (const [key, value] of Object.entries(headers)) {\n options.headers[key.toLowerCase()] = value;\n }\n }\n } else {\n const isSameHost = isUnixSocket\n ? websocket._originalUnixSocket\n ? opts.socketPath === websocket._originalHostOrSocketPath\n : false\n : websocket._originalUnixSocket\n ? false\n : parsedUrl.host === websocket._originalHostOrSocketPath;\n\n if (!isSameHost || (websocket._originalSecure && !isSecure)) {\n //\n // Match curl 7.77.0 behavior and drop the following headers. These\n // headers are also dropped when following a redirect to a subdomain.\n //\n delete opts.headers.authorization;\n delete opts.headers.cookie;\n\n if (!isSameHost) delete opts.headers.host;\n\n opts.auth = undefined;\n }\n }\n\n //\n // Match curl 7.77.0 behavior and make the first `Authorization` header win.\n // If the `Authorization` header is set, then there is nothing to do as it\n // will take precedence.\n //\n if (opts.auth && !options.headers.authorization) {\n options.headers.authorization =\n 'Basic ' + Buffer.from(opts.auth).toString('base64');\n }\n }\n\n let req = (websocket._req = get(opts));\n\n if (opts.timeout) {\n req.on('timeout', () => {\n abortHandshake(websocket, req, 'Opening handshake has timed out');\n });\n }\n\n req.on('error', (err) => {\n if (req === null || req.aborted) return;\n\n req = websocket._req = null;\n emitErrorAndClose(websocket, err);\n });\n\n req.on('response', (res) => {\n const location = res.headers.location;\n const statusCode = res.statusCode;\n\n if (\n location &&\n opts.followRedirects &&\n statusCode >= 300 &&\n statusCode < 400\n ) {\n if (++websocket._redirects > opts.maxRedirects) {\n abortHandshake(websocket, req, 'Maximum redirects exceeded');\n return;\n }\n\n req.abort();\n\n let addr;\n\n try {\n addr = new URL(location, address);\n } catch (err) {\n emitErrorAndClose(websocket, err);\n return;\n }\n\n initAsClient(websocket, addr, protocols, options);\n } else if (!websocket.emit('unexpected-response', req, res)) {\n abortHandshake(\n websocket,\n req,\n `Unexpected server response: ${res.statusCode}`\n );\n }\n });\n\n req.on('upgrade', (res, socket, head) => {\n websocket.emit('upgrade', res);\n\n //\n // The user may have closed the connection from a listener of the `upgrade`\n // event.\n //\n if (websocket.readyState !== WebSocket.CONNECTING) return;\n\n req = websocket._req = null;\n\n if (res.headers.upgrade.toLowerCase() !== 'websocket') {\n abortHandshake(websocket, socket, 'Invalid Upgrade header');\n return;\n }\n\n const digest = createHash('sha1')\n .update(key + GUID)\n .digest('base64');\n\n if (res.headers['sec-websocket-accept'] !== digest) {\n abortHandshake(websocket, socket, 'Invalid Sec-WebSocket-Accept header');\n return;\n }\n\n const serverProt = res.headers['sec-websocket-protocol'];\n const protList = (protocols || '').split(/, */);\n let protError;\n\n if (!protocols && serverProt) {\n protError = 'Server sent a subprotocol but none was requested';\n } else if (protocols && !serverProt) {\n protError = 'Server sent no subprotocol';\n } else if (serverProt && !protList.includes(serverProt)) {\n protError = 'Server sent an invalid subprotocol';\n }\n\n if (protError) {\n abortHandshake(websocket, socket, protError);\n return;\n }\n\n if (serverProt) websocket._protocol = serverProt;\n\n const secWebSocketExtensions = res.headers['sec-websocket-extensions'];\n\n if (secWebSocketExtensions !== undefined) {\n if (!perMessageDeflate) {\n const message =\n 'Server sent a Sec-WebSocket-Extensions header but no extension ' +\n 'was requested';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n let extensions;\n\n try {\n extensions = parse(secWebSocketExtensions);\n } catch (err) {\n const message = 'Invalid Sec-WebSocket-Extensions header';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n const extensionNames = Object.keys(extensions);\n\n if (extensionNames.length) {\n if (\n extensionNames.length !== 1 ||\n extensionNames[0] !== PerMessageDeflate.extensionName\n ) {\n const message =\n 'Server indicated an extension that was not requested';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n try {\n perMessageDeflate.accept(extensions[PerMessageDeflate.extensionName]);\n } catch (err) {\n const message = 'Invalid Sec-WebSocket-Extensions header';\n abortHandshake(websocket, socket, message);\n return;\n }\n\n websocket._extensions[PerMessageDeflate.extensionName] =\n perMessageDeflate;\n }\n }\n\n websocket.setSocket(socket, head, opts.maxPayload);\n });\n}\n\n/**\n * Emit the `'error'` and `'close'` event.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {Error} The error to emit\n * @private\n */\nfunction emitErrorAndClose(websocket, err) {\n websocket._readyState = WebSocket.CLOSING;\n websocket.emit('error', err);\n websocket.emitClose();\n}\n\n/**\n * Create a `net.Socket` and initiate a connection.\n *\n * @param {Object} options Connection options\n * @return {net.Socket} The newly created socket used to start the connection\n * @private\n */\nfunction netConnect(options) {\n options.path = options.socketPath;\n return net.connect(options);\n}\n\n/**\n * Create a `tls.TLSSocket` and initiate a connection.\n *\n * @param {Object} options Connection options\n * @return {tls.TLSSocket} The newly created socket used to start the connection\n * @private\n */\nfunction tlsConnect(options) {\n options.path = undefined;\n\n if (!options.servername && options.servername !== '') {\n options.servername = net.isIP(options.host) ? '' : options.host;\n }\n\n return tls.connect(options);\n}\n\n/**\n * Abort the handshake and emit an error.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {(http.ClientRequest|net.Socket|tls.Socket)} stream The request to\n * abort or the socket to destroy\n * @param {String} message The error message\n * @private\n */\nfunction abortHandshake(websocket, stream, message) {\n websocket._readyState = WebSocket.CLOSING;\n\n const err = new Error(message);\n Error.captureStackTrace(err, abortHandshake);\n\n if (stream.setHeader) {\n stream.abort();\n\n if (stream.socket && !stream.socket.destroyed) {\n //\n // On Node.js >= 14.3.0 `request.abort()` does not destroy the socket if\n // called after the request completed. See\n // https://github.com/websockets/ws/issues/1869.\n //\n stream.socket.destroy();\n }\n\n stream.once('abort', websocket.emitClose.bind(websocket));\n websocket.emit('error', err);\n } else {\n stream.destroy(err);\n stream.once('error', websocket.emit.bind(websocket, 'error'));\n stream.once('close', websocket.emitClose.bind(websocket));\n }\n}\n\n/**\n * Handle cases where the `ping()`, `pong()`, or `send()` methods are called\n * when the `readyState` attribute is `CLOSING` or `CLOSED`.\n *\n * @param {WebSocket} websocket The WebSocket instance\n * @param {*} [data] The data to send\n * @param {Function} [cb] Callback\n * @private\n */\nfunction sendAfterClose(websocket, data, cb) {\n if (data) {\n const length = toBuffer(data).length;\n\n //\n // The `_bufferedAmount` property is used only when the peer is a client and\n // the opening handshake fails. Under these circumstances, in fact, the\n // `setSocket()` method is not called, so the `_socket` and `_sender`\n // properties are set to `null`.\n //\n if (websocket._socket) websocket._sender._bufferedBytes += length;\n else websocket._bufferedAmount += length;\n }\n\n if (cb) {\n const err = new Error(\n `WebSocket is not open: readyState ${websocket.readyState} ` +\n `(${readyStates[websocket.readyState]})`\n );\n cb(err);\n }\n}\n\n/**\n * The listener of the `Receiver` `'conclude'` event.\n *\n * @param {Number} code The status code\n * @param {String} reason The reason for closing\n * @private\n */\nfunction receiverOnConclude(code, reason) {\n const websocket = this[kWebSocket];\n\n websocket._closeFrameReceived = true;\n websocket._closeMessage = reason;\n websocket._closeCode = code;\n\n if (websocket._socket[kWebSocket] === undefined) return;\n\n websocket._socket.removeListener('data', socketOnData);\n process.nextTick(resume, websocket._socket);\n\n if (code === 1005) websocket.close();\n else websocket.close(code, reason);\n}\n\n/**\n * The listener of the `Receiver` `'drain'` event.\n *\n * @private\n */\nfunction receiverOnDrain() {\n this[kWebSocket]._socket.resume();\n}\n\n/**\n * The listener of the `Receiver` `'error'` event.\n *\n * @param {(RangeError|Error)} err The emitted error\n * @private\n */\nfunction receiverOnError(err) {\n const websocket = this[kWebSocket];\n\n if (websocket._socket[kWebSocket] !== undefined) {\n websocket._socket.removeListener('data', socketOnData);\n\n //\n // On Node.js < 14.0.0 the `'error'` event is emitted synchronously. See\n // https://github.com/websockets/ws/issues/1940.\n //\n process.nextTick(resume, websocket._socket);\n\n websocket.close(err[kStatusCode]);\n }\n\n websocket.emit('error', err);\n}\n\n/**\n * The listener of the `Receiver` `'finish'` event.\n *\n * @private\n */\nfunction receiverOnFinish() {\n this[kWebSocket].emitClose();\n}\n\n/**\n * The listener of the `Receiver` `'message'` event.\n *\n * @param {(String|Buffer|ArrayBuffer|Buffer[])} data The message\n * @private\n */\nfunction receiverOnMessage(data) {\n this[kWebSocket].emit('message', data);\n}\n\n/**\n * The listener of the `Receiver` `'ping'` event.\n *\n * @param {Buffer} data The data included in the ping frame\n * @private\n */\nfunction receiverOnPing(data) {\n const websocket = this[kWebSocket];\n\n websocket.pong(data, !websocket._isServer, NOOP);\n websocket.emit('ping', data);\n}\n\n/**\n * The listener of the `Receiver` `'pong'` event.\n *\n * @param {Buffer} data The data included in the pong frame\n * @private\n */\nfunction receiverOnPong(data) {\n this[kWebSocket].emit('pong', data);\n}\n\n/**\n * Resume a readable stream\n *\n * @param {Readable} stream The readable stream\n * @private\n */\nfunction resume(stream) {\n stream.resume();\n}\n\n/**\n * The listener of the `net.Socket` `'close'` event.\n *\n * @private\n */\nfunction socketOnClose() {\n const websocket = this[kWebSocket];\n\n this.removeListener('close', socketOnClose);\n this.removeListener('data', socketOnData);\n this.removeListener('end', socketOnEnd);\n\n websocket._readyState = WebSocket.CLOSING;\n\n let chunk;\n\n //\n // The close frame might not have been received or the `'end'` event emitted,\n // for example, if the socket was destroyed due to an error. Ensure that the\n // `receiver` stream is closed after writing any remaining buffered data to\n // it. If the readable side of the socket is in flowing mode then there is no\n // buffered data as everything has been already written and `readable.read()`\n // will return `null`. If instead, the socket is paused, any possible buffered\n // data will be read as a single chunk.\n //\n if (\n !this._readableState.endEmitted &&\n !websocket._closeFrameReceived &&\n !websocket._receiver._writableState.errorEmitted &&\n (chunk = websocket._socket.read()) !== null\n ) {\n websocket._receiver.write(chunk);\n }\n\n websocket._receiver.end();\n\n this[kWebSocket] = undefined;\n\n clearTimeout(websocket._closeTimer);\n\n if (\n websocket._receiver._writableState.finished ||\n websocket._receiver._writableState.errorEmitted\n ) {\n websocket.emitClose();\n } else {\n websocket._receiver.on('error', receiverOnFinish);\n websocket._receiver.on('finish', receiverOnFinish);\n }\n}\n\n/**\n * The listener of the `net.Socket` `'data'` event.\n *\n * @param {Buffer} chunk A chunk of data\n * @private\n */\nfunction socketOnData(chunk) {\n if (!this[kWebSocket]._receiver.write(chunk)) {\n this.pause();\n }\n}\n\n/**\n * The listener of the `net.Socket` `'end'` event.\n *\n * @private\n */\nfunction socketOnEnd() {\n const websocket = this[kWebSocket];\n\n websocket._readyState = WebSocket.CLOSING;\n websocket._receiver.end();\n this.end();\n}\n\n/**\n * The listener of the `net.Socket` `'error'` event.\n *\n * @private\n */\nfunction socketOnError() {\n const websocket = this[kWebSocket];\n\n this.removeListener('error', socketOnError);\n this.on('error', NOOP);\n\n if (websocket) {\n websocket._readyState = WebSocket.CLOSING;\n this.destroy();\n }\n}\n","'use strict';\n\nconst { Duplex } = require('stream');\n\n/**\n * Emits the `'close'` event on a stream.\n *\n * @param {Duplex} stream The stream.\n * @private\n */\nfunction emitClose(stream) {\n stream.emit('close');\n}\n\n/**\n * The listener of the `'end'` event.\n *\n * @private\n */\nfunction duplexOnEnd() {\n if (!this.destroyed && this._writableState.finished) {\n this.destroy();\n }\n}\n\n/**\n * The listener of the `'error'` event.\n *\n * @param {Error} err The error\n * @private\n */\nfunction duplexOnError(err) {\n this.removeListener('error', duplexOnError);\n this.destroy();\n if (this.listenerCount('error') === 0) {\n // Do not suppress the throwing behavior.\n this.emit('error', err);\n }\n}\n\n/**\n * Wraps a `WebSocket` in a duplex stream.\n *\n * @param {WebSocket} ws The `WebSocket` to wrap\n * @param {Object} [options] The options for the `Duplex` constructor\n * @return {Duplex} The duplex stream\n * @public\n */\nfunction createWebSocketStream(ws, options) {\n let resumeOnReceiverDrain = true;\n let terminateOnDestroy = true;\n\n function receiverOnDrain() {\n if (resumeOnReceiverDrain) ws._socket.resume();\n }\n\n if (ws.readyState === ws.CONNECTING) {\n ws.once('open', function open() {\n ws._receiver.removeAllListeners('drain');\n ws._receiver.on('drain', receiverOnDrain);\n });\n } else {\n ws._receiver.removeAllListeners('drain');\n ws._receiver.on('drain', receiverOnDrain);\n }\n\n const duplex = new Duplex({\n ...options,\n autoDestroy: false,\n emitClose: false,\n objectMode: false,\n writableObjectMode: false\n });\n\n ws.on('message', function message(msg) {\n if (!duplex.push(msg)) {\n resumeOnReceiverDrain = false;\n ws._socket.pause();\n }\n });\n\n ws.once('error', function error(err) {\n if (duplex.destroyed) return;\n\n // Prevent `ws.terminate()` from being called by `duplex._destroy()`.\n //\n // - If the `'error'` event is emitted before the `'open'` event, then\n // `ws.terminate()` is a noop as no socket is assigned.\n // - Otherwise, the error is re-emitted by the listener of the `'error'`\n // event of the `Receiver` object. The listener already closes the\n // connection by calling `ws.close()`. This allows a close frame to be\n // sent to the other peer. If `ws.terminate()` is called right after this,\n // then the close frame might not be sent.\n terminateOnDestroy = false;\n duplex.destroy(err);\n });\n\n ws.once('close', function close() {\n if (duplex.destroyed) return;\n\n duplex.push(null);\n });\n\n duplex._destroy = function (err, callback) {\n if (ws.readyState === ws.CLOSED) {\n callback(err);\n process.nextTick(emitClose, duplex);\n return;\n }\n\n let called = false;\n\n ws.once('error', function error(err) {\n called = true;\n callback(err);\n });\n\n ws.once('close', function close() {\n if (!called) callback(err);\n process.nextTick(emitClose, duplex);\n });\n\n if (terminateOnDestroy) ws.terminate();\n };\n\n duplex._final = function (callback) {\n if (ws.readyState === ws.CONNECTING) {\n ws.once('open', function open() {\n duplex._final(callback);\n });\n return;\n }\n\n // If the value of the `_socket` property is `null` it means that `ws` is a\n // client websocket and the handshake failed. In fact, when this happens, a\n // socket is never assigned to the websocket. Wait for the `'error'` event\n // that will be emitted by the websocket.\n if (ws._socket === null) return;\n\n if (ws._socket._writableState.finished) {\n callback();\n if (duplex._readableState.endEmitted) duplex.destroy();\n } else {\n ws._socket.once('finish', function finish() {\n // `duplex` is not destroyed here because the `'end'` event will be\n // emitted on `duplex` after this `'finish'` event. The EOF signaling\n // `null` chunk is, in fact, pushed when the websocket emits `'close'`.\n callback();\n });\n ws.close();\n }\n };\n\n duplex._read = function () {\n if (\n (ws.readyState === ws.OPEN || ws.readyState === ws.CLOSING) &&\n !resumeOnReceiverDrain\n ) {\n resumeOnReceiverDrain = true;\n if (!ws._receiver._writableState.needDrain) ws._socket.resume();\n }\n };\n\n duplex._write = function (chunk, encoding, callback) {\n if (ws.readyState === ws.CONNECTING) {\n ws.once('open', function open() {\n duplex._write(chunk, encoding, callback);\n });\n return;\n }\n\n ws.send(chunk, callback);\n };\n\n duplex.on('end', duplexOnEnd);\n duplex.on('error', duplexOnError);\n return duplex;\n}\n\nmodule.exports = createWebSocketStream;\n","/* eslint no-unused-vars: [\"error\", { \"varsIgnorePattern\": \"^net|tls|https$\" }] */\n\n'use strict';\n\nconst EventEmitter = require('events');\nconst http = require('http');\nconst https = require('https');\nconst net = require('net');\nconst tls = require('tls');\nconst { createHash } = require('crypto');\n\nconst PerMessageDeflate = require('./permessage-deflate');\nconst WebSocket = require('./websocket');\nconst { format, parse } = require('./extension');\nconst { GUID, kWebSocket } = require('./constants');\n\nconst keyRegex = /^[+/0-9A-Za-z]{22}==$/;\n\nconst RUNNING = 0;\nconst CLOSING = 1;\nconst CLOSED = 2;\n\n/**\n * Class representing a WebSocket server.\n *\n * @extends EventEmitter\n */\nclass WebSocketServer extends EventEmitter {\n /**\n * Create a `WebSocketServer` instance.\n *\n * @param {Object} options Configuration options\n * @param {Number} [options.backlog=511] The maximum length of the queue of\n * pending connections\n * @param {Boolean} [options.clientTracking=true] Specifies whether or not to\n * track clients\n * @param {Function} [options.handleProtocols] A hook to handle protocols\n * @param {String} [options.host] The hostname where to bind the server\n * @param {Number} [options.maxPayload=104857600] The maximum allowed message\n * size\n * @param {Boolean} [options.noServer=false] Enable no server mode\n * @param {String} [options.path] Accept only connections matching this path\n * @param {(Boolean|Object)} [options.perMessageDeflate=false] Enable/disable\n * permessage-deflate\n * @param {Number} [options.port] The port where to bind the server\n * @param {(http.Server|https.Server)} [options.server] A pre-created HTTP/S\n * server to use\n * @param {Function} [options.verifyClient] A hook to reject connections\n * @param {Function} [callback] A listener for the `listening` event\n */\n constructor(options, callback) {\n super();\n\n options = {\n maxPayload: 100 * 1024 * 1024,\n perMessageDeflate: false,\n handleProtocols: null,\n clientTracking: true,\n verifyClient: null,\n noServer: false,\n backlog: null, // use default (511 as implemented in net.js)\n server: null,\n host: null,\n path: null,\n port: null,\n ...options\n };\n\n if (\n (options.port == null && !options.server && !options.noServer) ||\n (options.port != null && (options.server || options.noServer)) ||\n (options.server && options.noServer)\n ) {\n throw new TypeError(\n 'One and only one of the \"port\", \"server\", or \"noServer\" options ' +\n 'must be specified'\n );\n }\n\n if (options.port != null) {\n this._server = http.createServer((req, res) => {\n const body = http.STATUS_CODES[426];\n\n res.writeHead(426, {\n 'Content-Length': body.length,\n 'Content-Type': 'text/plain'\n });\n res.end(body);\n });\n this._server.listen(\n options.port,\n options.host,\n options.backlog,\n callback\n );\n } else if (options.server) {\n this._server = options.server;\n }\n\n if (this._server) {\n const emitConnection = this.emit.bind(this, 'connection');\n\n this._removeListeners = addListeners(this._server, {\n listening: this.emit.bind(this, 'listening'),\n error: this.emit.bind(this, 'error'),\n upgrade: (req, socket, head) => {\n this.handleUpgrade(req, socket, head, emitConnection);\n }\n });\n }\n\n if (options.perMessageDeflate === true) options.perMessageDeflate = {};\n if (options.clientTracking) this.clients = new Set();\n this.options = options;\n this._state = RUNNING;\n }\n\n /**\n * Returns the bound address, the address family name, and port of the server\n * as reported by the operating system if listening on an IP socket.\n * If the server is listening on a pipe or UNIX domain socket, the name is\n * returned as a string.\n *\n * @return {(Object|String|null)} The address of the server\n * @public\n */\n address() {\n if (this.options.noServer) {\n throw new Error('The server is operating in \"noServer\" mode');\n }\n\n if (!this._server) return null;\n return this._server.address();\n }\n\n /**\n * Close the server.\n *\n * @param {Function} [cb] Callback\n * @public\n */\n close(cb) {\n if (cb) this.once('close', cb);\n\n if (this._state === CLOSED) {\n process.nextTick(emitClose, this);\n return;\n }\n\n if (this._state === CLOSING) return;\n this._state = CLOSING;\n\n //\n // Terminate all associated clients.\n //\n if (this.clients) {\n for (const client of this.clients) client.terminate();\n }\n\n const server = this._server;\n\n if (server) {\n this._removeListeners();\n this._removeListeners = this._server = null;\n\n //\n // Close the http server if it was internally created.\n //\n if (this.options.port != null) {\n server.close(emitClose.bind(undefined, this));\n return;\n }\n }\n\n process.nextTick(emitClose, this);\n }\n\n /**\n * See if a given request should be handled by this server instance.\n *\n * @param {http.IncomingMessage} req Request object to inspect\n * @return {Boolean} `true` if the request is valid, else `false`\n * @public\n */\n shouldHandle(req) {\n if (this.options.path) {\n const index = req.url.indexOf('?');\n const pathname = index !== -1 ? req.url.slice(0, index) : req.url;\n\n if (pathname !== this.options.path) return false;\n }\n\n return true;\n }\n\n /**\n * Handle a HTTP Upgrade request.\n *\n * @param {http.IncomingMessage} req The request object\n * @param {(net.Socket|tls.Socket)} socket The network socket between the\n * server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Function} cb Callback\n * @public\n */\n handleUpgrade(req, socket, head, cb) {\n socket.on('error', socketOnError);\n\n const key =\n req.headers['sec-websocket-key'] !== undefined\n ? req.headers['sec-websocket-key'].trim()\n : false;\n const version = +req.headers['sec-websocket-version'];\n const extensions = {};\n\n if (\n req.method !== 'GET' ||\n req.headers.upgrade.toLowerCase() !== 'websocket' ||\n !key ||\n !keyRegex.test(key) ||\n (version !== 8 && version !== 13) ||\n !this.shouldHandle(req)\n ) {\n return abortHandshake(socket, 400);\n }\n\n if (this.options.perMessageDeflate) {\n const perMessageDeflate = new PerMessageDeflate(\n this.options.perMessageDeflate,\n true,\n this.options.maxPayload\n );\n\n try {\n const offers = parse(req.headers['sec-websocket-extensions']);\n\n if (offers[PerMessageDeflate.extensionName]) {\n perMessageDeflate.accept(offers[PerMessageDeflate.extensionName]);\n extensions[PerMessageDeflate.extensionName] = perMessageDeflate;\n }\n } catch (err) {\n return abortHandshake(socket, 400);\n }\n }\n\n //\n // Optionally call external client verification handler.\n //\n if (this.options.verifyClient) {\n const info = {\n origin:\n req.headers[`${version === 8 ? 'sec-websocket-origin' : 'origin'}`],\n secure: !!(req.socket.authorized || req.socket.encrypted),\n req\n };\n\n if (this.options.verifyClient.length === 2) {\n this.options.verifyClient(info, (verified, code, message, headers) => {\n if (!verified) {\n return abortHandshake(socket, code || 401, message, headers);\n }\n\n this.completeUpgrade(key, extensions, req, socket, head, cb);\n });\n return;\n }\n\n if (!this.options.verifyClient(info)) return abortHandshake(socket, 401);\n }\n\n this.completeUpgrade(key, extensions, req, socket, head, cb);\n }\n\n /**\n * Upgrade the connection to WebSocket.\n *\n * @param {String} key The value of the `Sec-WebSocket-Key` header\n * @param {Object} extensions The accepted extensions\n * @param {http.IncomingMessage} req The request object\n * @param {(net.Socket|tls.Socket)} socket The network socket between the\n * server and client\n * @param {Buffer} head The first packet of the upgraded stream\n * @param {Function} cb Callback\n * @throws {Error} If called more than once with the same socket\n * @private\n */\n completeUpgrade(key, extensions, req, socket, head, cb) {\n //\n // Destroy the socket if the client has already sent a FIN packet.\n //\n if (!socket.readable || !socket.writable) return socket.destroy();\n\n if (socket[kWebSocket]) {\n throw new Error(\n 'server.handleUpgrade() was called more than once with the same ' +\n 'socket, possibly due to a misconfiguration'\n );\n }\n\n if (this._state > RUNNING) return abortHandshake(socket, 503);\n\n const digest = createHash('sha1')\n .update(key + GUID)\n .digest('base64');\n\n const headers = [\n 'HTTP/1.1 101 Switching Protocols',\n 'Upgrade: websocket',\n 'Connection: Upgrade',\n `Sec-WebSocket-Accept: ${digest}`\n ];\n\n const ws = new WebSocket(null);\n let protocol = req.headers['sec-websocket-protocol'];\n\n if (protocol) {\n protocol = protocol.split(',').map(trim);\n\n //\n // Optionally call external protocol selection handler.\n //\n if (this.options.handleProtocols) {\n protocol = this.options.handleProtocols(protocol, req);\n } else {\n protocol = protocol[0];\n }\n\n if (protocol) {\n headers.push(`Sec-WebSocket-Protocol: ${protocol}`);\n ws._protocol = protocol;\n }\n }\n\n if (extensions[PerMessageDeflate.extensionName]) {\n const params = extensions[PerMessageDeflate.extensionName].params;\n const value = format({\n [PerMessageDeflate.extensionName]: [params]\n });\n headers.push(`Sec-WebSocket-Extensions: ${value}`);\n ws._extensions = extensions;\n }\n\n //\n // Allow external modification/inspection of handshake headers.\n //\n this.emit('headers', headers, req);\n\n socket.write(headers.concat('\\r\\n').join('\\r\\n'));\n socket.removeListener('error', socketOnError);\n\n ws.setSocket(socket, head, this.options.maxPayload);\n\n if (this.clients) {\n this.clients.add(ws);\n ws.on('close', () => this.clients.delete(ws));\n }\n\n cb(ws, req);\n }\n}\n\nmodule.exports = WebSocketServer;\n\n/**\n * Add event listeners on an `EventEmitter` using a map of <event, listener>\n * pairs.\n *\n * @param {EventEmitter} server The event emitter\n * @param {Object.<String, Function>} map The listeners to add\n * @return {Function} A function that will remove the added listeners when\n * called\n * @private\n */\nfunction addListeners(server, map) {\n for (const event of Object.keys(map)) server.on(event, map[event]);\n\n return function removeListeners() {\n for (const event of Object.keys(map)) {\n server.removeListener(event, map[event]);\n }\n };\n}\n\n/**\n * Emit a `'close'` event on an `EventEmitter`.\n *\n * @param {EventEmitter} server The event emitter\n * @private\n */\nfunction emitClose(server) {\n server._state = CLOSED;\n server.emit('close');\n}\n\n/**\n * Handle premature socket errors.\n *\n * @private\n */\nfunction socketOnError() {\n this.destroy();\n}\n\n/**\n * Close the connection when preconditions are not fulfilled.\n *\n * @param {(net.Socket|tls.Socket)} socket The socket of the upgrade request\n * @param {Number} code The HTTP response status code\n * @param {String} [message] The HTTP response body\n * @param {Object} [headers] Additional HTTP response headers\n * @private\n */\nfunction abortHandshake(socket, code, message, headers) {\n if (socket.writable) {\n message = message || http.STATUS_CODES[code];\n headers = {\n Connection: 'close',\n 'Content-Type': 'text/html',\n 'Content-Length': Buffer.byteLength(message),\n ...headers\n };\n\n socket.write(\n `HTTP/1.1 ${code} ${http.STATUS_CODES[code]}\\r\\n` +\n Object.keys(headers)\n .map((h) => `${h}: ${headers[h]}`)\n .join('\\r\\n') +\n '\\r\\n\\r\\n' +\n message\n );\n }\n\n socket.removeListener('error', socketOnError);\n socket.destroy();\n}\n\n/**\n * Remove whitespace characters from both ends of a string.\n *\n * @param {String} str The string\n * @return {String} A new string representing `str` stripped of whitespace\n * characters from both its beginning and end\n * @private\n */\nfunction trim(str) {\n return str.trim();\n}\n","'use strict';\n\nconst WebSocket = require('./lib/websocket');\n\nWebSocket.createWebSocketStream = require('./lib/stream');\nWebSocket.Server = require('./lib/websocket-server');\nWebSocket.Receiver = require('./lib/receiver');\nWebSocket.Sender = require('./lib/sender');\n\nmodule.exports = WebSocket;\n","'use strict'\n\nconst { Buffer } = require('buffer')\nconst WS = require('ws')\nconst debug = require('debug')('mqttjs:ws')\nconst duplexify = require('duplexify')\nconst Transform = require('readable-stream').Transform\n\nconst WSS_OPTIONS = [\n 'rejectUnauthorized',\n 'ca',\n 'cert',\n 'key',\n 'pfx',\n 'passphrase'\n]\n// eslint-disable-next-line camelcase\nconst IS_BROWSER = (typeof process !== 'undefined' && process.title === 'browser') || typeof __webpack_require__ === 'function'\nfunction buildUrl (opts, client) {\n let url = opts.protocol + '://' + opts.hostname + ':' + opts.port + opts.path\n if (typeof (opts.transformWsUrl) === 'function') {\n url = opts.transformWsUrl(url, opts, client)\n }\n return url\n}\n\nfunction setDefaultOpts (opts) {\n const options = opts\n if (!opts.hostname) {\n options.hostname = 'localhost'\n }\n if (!opts.port) {\n if (opts.protocol === 'wss') {\n options.port = 443\n } else {\n options.port = 80\n }\n }\n if (!opts.path) {\n options.path = '/'\n }\n\n if (!opts.wsOptions) {\n options.wsOptions = {}\n }\n if (!IS_BROWSER && opts.protocol === 'wss') {\n // Add cert/key/ca etc options\n WSS_OPTIONS.forEach(function (prop) {\n if (Object.prototype.hasOwnProperty.call(opts, prop) && !Object.prototype.hasOwnProperty.call(opts.wsOptions, prop)) {\n options.wsOptions[prop] = opts[prop]\n }\n })\n }\n\n return options\n}\n\nfunction setDefaultBrowserOpts (opts) {\n const options = setDefaultOpts(opts)\n\n if (!options.hostname) {\n options.hostname = options.host\n }\n\n if (!options.hostname) {\n // Throwing an error in a Web Worker if no `hostname` is given, because we\n // can not determine the `hostname` automatically. If connecting to\n // localhost, please supply the `hostname` as an argument.\n if (typeof (document) === 'undefined') {\n throw new Error('Could not determine host. Specify host manually.')\n }\n const parsed = new URL(document.URL)\n options.hostname = parsed.hostname\n\n if (!options.port) {\n options.port = parsed.port\n }\n }\n\n // objectMode should be defined for logic\n if (options.objectMode === undefined) {\n options.objectMode = !(options.binary === true || options.binary === undefined)\n }\n\n return options\n}\n\nfunction createWebSocket (client, url, opts) {\n debug('createWebSocket')\n debug('protocol: ' + opts.protocolId + ' ' + opts.protocolVersion)\n const websocketSubProtocol =\n (opts.protocolId === 'MQIsdp') && (opts.protocolVersion === 3)\n ? 'mqttv3.1'\n : 'mqtt'\n\n debug('creating new Websocket for url: ' + url + ' and protocol: ' + websocketSubProtocol)\n const socket = new WS(url, [websocketSubProtocol], opts.wsOptions)\n return socket\n}\n\nfunction createBrowserWebSocket (client, opts) {\n const websocketSubProtocol =\n (opts.protocolId === 'MQIsdp') && (opts.protocolVersion === 3)\n ? 'mqttv3.1'\n : 'mqtt'\n\n const url = buildUrl(opts, client)\n /* global WebSocket */\n const socket = new WebSocket(url, [websocketSubProtocol])\n socket.binaryType = 'arraybuffer'\n return socket\n}\n\nfunction streamBuilder (client, opts) {\n debug('streamBuilder')\n const options = setDefaultOpts(opts)\n const url = buildUrl(options, client)\n const socket = createWebSocket(client, url, options)\n const webSocketStream = WS.createWebSocketStream(socket, options.wsOptions)\n webSocketStream.url = url\n socket.on('close', () => { webSocketStream.destroy() })\n return webSocketStream\n}\n\nfunction browserStreamBuilder (client, opts) {\n debug('browserStreamBuilder')\n let stream\n const options = setDefaultBrowserOpts(opts)\n // sets the maximum socket buffer size before throttling\n const bufferSize = options.browserBufferSize || 1024 * 512\n\n const bufferTimeout = opts.browserBufferTimeout || 1000\n\n const coerceToBuffer = !opts.objectMode\n\n const socket = createBrowserWebSocket(client, opts)\n\n const proxy = buildProxy(opts, socketWriteBrowser, socketEndBrowser)\n\n if (!opts.objectMode) {\n proxy._writev = writev\n }\n proxy.on('close', () => { socket.close() })\n\n const eventListenerSupport = (typeof socket.addEventListener !== 'undefined')\n\n // was already open when passed in\n if (socket.readyState === socket.OPEN) {\n stream = proxy\n } else {\n stream = stream = duplexify(undefined, undefined, opts)\n if (!opts.objectMode) {\n stream._writev = writev\n }\n\n if (eventListenerSupport) {\n socket.addEventListener('open', onopen)\n } else {\n socket.onopen = onopen\n }\n }\n\n stream.socket = socket\n\n if (eventListenerSupport) {\n socket.addEventListener('close', onclose)\n socket.addEventListener('error', onerror)\n socket.addEventListener('message', onmessage)\n } else {\n socket.onclose = onclose\n socket.onerror = onerror\n socket.onmessage = onmessage\n }\n\n // methods for browserStreamBuilder\n\n function buildProxy (options, socketWrite, socketEnd) {\n const proxy = new Transform({\n objectModeMode: options.objectMode\n })\n\n proxy._write = socketWrite\n proxy._flush = socketEnd\n\n return proxy\n }\n\n function onopen () {\n stream.setReadable(proxy)\n stream.setWritable(proxy)\n stream.emit('connect')\n }\n\n function onclose () {\n stream.end()\n stream.destroy()\n }\n\n function onerror (err) {\n stream.destroy(err)\n }\n\n function onmessage (event) {\n let data = event.data\n if (data instanceof ArrayBuffer) data = Buffer.from(data)\n else data = Buffer.from(data, 'utf8')\n proxy.push(data)\n }\n\n // this is to be enabled only if objectMode is false\n function writev (chunks, cb) {\n const buffers = new Array(chunks.length)\n for (let i = 0; i < chunks.length; i++) {\n if (typeof chunks[i].chunk === 'string') {\n buffers[i] = Buffer.from(chunks[i], 'utf8')\n } else {\n buffers[i] = chunks[i].chunk\n }\n }\n\n this._write(Buffer.concat(buffers), 'binary', cb)\n }\n\n function socketWriteBrowser (chunk, enc, next) {\n if (socket.bufferedAmount > bufferSize) {\n // throttle data until buffered amount is reduced.\n setTimeout(socketWriteBrowser, bufferTimeout, chunk, enc, next)\n }\n\n if (coerceToBuffer && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, 'utf8')\n }\n\n try {\n socket.send(chunk)\n } catch (err) {\n return next(err)\n }\n\n next()\n }\n\n function socketEndBrowser (done) {\n socket.close()\n done()\n }\n\n // end methods for browserStreamBuilder\n\n return stream\n}\n\nif (IS_BROWSER) {\n module.exports = browserStreamBuilder\n} else {\n module.exports = streamBuilder\n}\n","'use strict'\n\nconst MqttClient = require('../client')\nconst Store = require('../store')\nconst url = require('url')\nconst xtend = require('xtend')\nconst debug = require('debug')('mqttjs')\n\nconst protocols = {}\n\n// eslint-disable-next-line camelcase\nif ((typeof process !== 'undefined' && process.title !== 'browser') || typeof __webpack_require__ !== 'function') {\n protocols.mqtt = require('./tcp')\n protocols.tcp = require('./tcp')\n protocols.ssl = require('./tls')\n protocols.tls = require('./tls')\n protocols.mqtts = require('./tls')\n} else {\n protocols.wx = require('./wx')\n protocols.wxs = require('./wx')\n\n protocols.ali = require('./ali')\n protocols.alis = require('./ali')\n}\n\nprotocols.ws = require('./ws')\nprotocols.wss = require('./ws')\n\n/**\n * Parse the auth attribute and merge username and password in the options object.\n *\n * @param {Object} [opts] option object\n */\nfunction parseAuthOptions (opts) {\n let matches\n if (opts.auth) {\n matches = opts.auth.match(/^(.+):(.+)$/)\n if (matches) {\n opts.username = matches[1]\n opts.password = matches[2]\n } else {\n opts.username = opts.auth\n }\n }\n}\n\n/**\n * connect - connect to an MQTT broker.\n *\n * @param {String} [brokerUrl] - url of the broker, optional\n * @param {Object} opts - see MqttClient#constructor\n */\nfunction connect (brokerUrl, opts) {\n debug('connecting to an MQTT broker...')\n if ((typeof brokerUrl === 'object') && !opts) {\n opts = brokerUrl\n brokerUrl = null\n }\n\n opts = opts || {}\n\n if (brokerUrl) {\n // eslint-disable-next-line\n const parsed = url.parse(brokerUrl, true)\n if (parsed.port != null) {\n parsed.port = Number(parsed.port)\n }\n\n opts = xtend(parsed, opts)\n\n if (opts.protocol === null) {\n throw new Error('Missing protocol')\n }\n\n opts.protocol = opts.protocol.replace(/:$/, '')\n }\n\n // merge in the auth options if supplied\n parseAuthOptions(opts)\n\n // support clientId passed in the query string of the url\n if (opts.query && typeof opts.query.clientId === 'string') {\n opts.clientId = opts.query.clientId\n }\n\n if (opts.cert && opts.key) {\n if (opts.protocol) {\n if (['mqtts', 'wss', 'wxs', 'alis'].indexOf(opts.protocol) === -1) {\n switch (opts.protocol) {\n case 'mqtt':\n opts.protocol = 'mqtts'\n break\n case 'ws':\n opts.protocol = 'wss'\n break\n case 'wx':\n opts.protocol = 'wxs'\n break\n case 'ali':\n opts.protocol = 'alis'\n break\n default:\n throw new Error('Unknown protocol for secure connection: \"' + opts.protocol + '\"!')\n }\n }\n } else {\n // A cert and key was provided, however no protocol was specified, so we will throw an error.\n throw new Error('Missing secure protocol key')\n }\n }\n\n if (!protocols[opts.protocol]) {\n const isSecure = ['mqtts', 'wss'].indexOf(opts.protocol) !== -1\n opts.protocol = [\n 'mqtt',\n 'mqtts',\n 'ws',\n 'wss',\n 'wx',\n 'wxs',\n 'ali',\n 'alis'\n ].filter(function (key, index) {\n if (isSecure && index % 2 === 0) {\n // Skip insecure protocols when requesting a secure one.\n return false\n }\n return (typeof protocols[key] === 'function')\n })[0]\n }\n\n if (opts.clean === false && !opts.clientId) {\n throw new Error('Missing clientId for unclean clients')\n }\n\n if (opts.protocol) {\n opts.defaultProtocol = opts.protocol\n }\n\n function wrapper (client) {\n if (opts.servers) {\n if (!client._reconnectCount || client._reconnectCount === opts.servers.length) {\n client._reconnectCount = 0\n }\n\n opts.host = opts.servers[client._reconnectCount].host\n opts.port = opts.servers[client._reconnectCount].port\n opts.protocol = (!opts.servers[client._reconnectCount].protocol ? opts.defaultProtocol : opts.servers[client._reconnectCount].protocol)\n opts.hostname = opts.host\n\n client._reconnectCount++\n }\n\n debug('calling streambuilder for', opts.protocol)\n return protocols[opts.protocol](client, opts)\n }\n const client = new MqttClient(wrapper, opts)\n client.on('error', function () { /* Automatically set up client error handling */ })\n return client\n}\n\nmodule.exports = connect\nmodule.exports.connect = connect\nmodule.exports.MqttClient = MqttClient\nmodule.exports.Store = Store\n","'use strict'\n\nconst NumberAllocator = require('number-allocator').NumberAllocator\n\n/**\n * UniqueMessageAllocator constructor\n * @constructor\n */\nfunction UniqueMessageIdProvider () {\n if (!(this instanceof UniqueMessageIdProvider)) {\n return new UniqueMessageIdProvider()\n }\n\n this.numberAllocator = new NumberAllocator(1, 65535)\n}\n\n/**\n * allocate\n *\n * Get the next messageId.\n * @return if messageId is fully allocated then return null,\n * otherwise return the smallest usable unsigned int messageId.\n */\nUniqueMessageIdProvider.prototype.allocate = function () {\n this.lastId = this.numberAllocator.alloc()\n return this.lastId\n}\n\n/**\n * getLastAllocated\n * Get the last allocated messageId.\n * @return unsigned int\n */\nUniqueMessageIdProvider.prototype.getLastAllocated = function () {\n return this.lastId\n}\n\n/**\n * register\n * Register messageId. If success return true, otherwise return false.\n * @param { unsigned int } - messageId to register,\n * @return boolean\n */\nUniqueMessageIdProvider.prototype.register = function (messageId) {\n return this.numberAllocator.use(messageId)\n}\n\n/**\n * deallocate\n * Deallocate messageId.\n * @param { unsigned int } - messageId to deallocate,\n */\nUniqueMessageIdProvider.prototype.deallocate = function (messageId) {\n this.numberAllocator.free(messageId)\n}\n\n/**\n * clear\n * Deallocate all messageIds.\n */\nUniqueMessageIdProvider.prototype.clear = function () {\n this.numberAllocator.clear()\n}\n\nmodule.exports = UniqueMessageIdProvider\n","/*\n * Copyright (c) 2015-2015 MQTT.js contributors.\n * Copyright (c) 2011-2014 Adam Rudd.\n *\n * See LICENSE for more information\n */\n\nconst MqttClient = require('./lib/client')\nconst connect = require('./lib/connect')\nconst Store = require('./lib/store')\nconst DefaultMessageIdProvider = require('./lib/default-message-id-provider')\nconst UniqueMessageIdProvider = require('./lib/unique-message-id-provider')\n\nmodule.exports.connect = connect\n\n// Expose MqttClient\nmodule.exports.MqttClient = MqttClient\nmodule.exports.Client = MqttClient\nmodule.exports.Store = Store\nmodule.exports.DefaultMessageIdProvider = DefaultMessageIdProvider\nmodule.exports.UniqueMessageIdProvider = UniqueMessageIdProvider\n","import mqtt from 'async-mqtt';\nimport Config from './config.js';\nimport Cache from './cache.js';\nimport { MqttClient } from 'mqtt';\nimport Message from './message.js';\nimport pages from './pages/index.js';\nimport Page from './page.js';\nimport { Vesta } from 'vestaboard-api';\n\nexport default class Vestaboard2MQTT {\n private readonly mqtt: MqttClient;\n private readonly board: Vesta;\n private readonly pageConfig = new Cache('page-config');\n private subscriptionIds?: string[];\n private currentMessage?: {page: Page<unknown>, payload: string};\n private currentTimer?: NodeJS.Timeout;\n\n public static async run(): Promise<Vestaboard2MQTT> {\n await Config.load();\n return new Vestaboard2MQTT();\n }\n\n constructor() {\n this.board = new Vesta({\n apiKey: Config.board.key,\n apiSecret: Config.board.secret\n });\n\n this.mqtt = mqtt.connect(Config.mqtt.url, {\n will: {\n topic: Config.mqtt.prefix + '/status',\n payload: 'offline',\n qos: 0,\n retain: true\n }\n });\n this.mqtt.on('connect', () => {\n this.mqtt.publish(Config.mqtt.prefix + '/status', 'online', {\n retain: true\n });\n\n this.setupBrokerSubscriptions().catch(error => {\n console.error(new Error(`Unable to setup mqtt subscriptions: ${error.stack}`));\n process.exit(1);\n });\n });\n this.mqtt.on('message', (topic, message) => {\n this.handleMessage(topic, message.toString()).catch(error => {\n this.debug(`Unable to handle message: ${error.stack}`);\n });\n });\n }\n\n private async setupBrokerSubscriptions() {\n if(!this.mqtt) {\n throw new Error('Unable to setup subscriptions: client not set.');\n }\n\n await this.mqtt.subscribe(Config.mqtt.prefix + '/#');\n }\n\n private debug(message: Error | string) {\n const msg = String(message);\n this.mqtt.publish(Config.mqtt.prefix + '/debug', msg);\n console.log(msg);\n }\n\n private async handleMessage(topic: string, payload: string): Promise<void> {\n if([Config.mqtt.prefix + '/debug', Config.mqtt.prefix + '/status'].includes(topic)) {\n // just ignore my own events\n }\n else if(topic === Config.mqtt.prefix + '/disabled') {\n const value = ['1', 'true', 'TRUE'].includes(payload);\n await Config.updateDisabled(value);\n if(!value) {\n this.debug('Board not disabled anymore, update with latest message');\n await this.updateCurrentMessage();\n }\n }\n else if(Object.keys(pages).map(id => Config.mqtt.prefix + '/' + id).includes(topic)) {\n const page = pages[ topic.substr(Config.mqtt.prefix.length + 1) ];\n await this.renderMessage(page, payload);\n }\n else {\n const page = Object.entries(pages)\n .find(([id]) => topic.startsWith(Config.mqtt.prefix + '/' + id + '/'));\n\n if(!page) {\n this.debug(`Unknown topic ${topic}, I'm sorry`);\n return;\n }\n\n const key = topic.substr((Config.mqtt.prefix + '/' + page[0] + '/').length);\n const cache = await this.pageConfig.get<Partial<unknown>>(page[0]);\n\n const config = page[1].parseConfig(key, payload, cache || {});\n const newConfig = Object.assign(cache || {}, config);\n await this.pageConfig.set(page[0], newConfig);\n await this.updateCurrentMessage();\n this.debug(`Update config for page module ${page[0]}: ${JSON.stringify(newConfig, null, ' ')}`);\n }\n }\n\n private async updateCurrentMessage() {\n if(this.currentMessage) {\n await this.renderMessage(\n this.currentMessage.page,\n this.currentMessage.payload\n );\n }\n }\n\n private async renderMessage(page: Page<unknown>, payload: string) {\n this.currentMessage = {\n page,\n payload\n };\n\n const pageEntry = Object.entries(pages).find(([,pageInstance]) => pageInstance === page);\n if(Config.board.disabled || !pageEntry) {\n return;\n }\n\n const parsePayload = await page.parsePayload(payload);\n const config = await this.pageConfig.get<Partial<unknown>>(pageEntry[0]);\n\n const response = await page.render(parsePayload, config || {});\n if (response.message) {\n await this.sendMessage(response.message);\n }\n\n if(this.currentTimer) {\n clearTimeout(this.currentTimer);\n delete this.currentTimer;\n }\n if(response.validTill) {\n this.debug(`Set timer for ${response.validTill.toString()} to update message`);\n this.currentTimer = setTimeout(() => {\n this.debug('Here I am again, updating the message now…');\n this.renderMessage(page, payload).catch(error => {\n this.debug(`Unable to update page: ${error}`);\n });\n }, response.validTill.getTime() - new Date().getTime());\n }\n }\n\n private async sendMessage(message: Message = new Message()): Promise<void> {\n const charArray = message.export();\n\n if(!this.subscriptionIds) {\n const subscriptions = await this.board.getSubscriptions();\n this.subscriptionIds = subscriptions.map(i => i._id);\n }\n\n this.debug('Sending Message:\\n\\n' + message.toString());\n\n await Promise.all(this.subscriptionIds.map(id => this.board.postMessage(id, charArray)));\n }\n}\n","import {join} from 'path';\nimport {existsSync} from 'fs';\nimport {promises} from 'fs';\n\ntype CacheData = Record<string, CacheNamespace>;\ntype CacheNamespace = Record<string, CacheItem>;\ntype CacheItem = CacheItemObject | CacheValue;\ntype CacheItemObject = {updated: number, value: CacheValue};\ntype CacheValue = unknown;\n\n// as node@12 has no 'fs/promises'\nconst {readFile, writeFile} = promises;\n\nexport default class Cache {\n private static readonly file: string = join(process.env.HOME || '~', '.vestaboard2mqtt');\n private readonly namespace: string;\n private static currentFetch?: Promise<void>;\n private static currentData?: CacheData = {};\n\n constructor(namespace: string) {\n this.namespace = namespace;\n }\n\n static async fetch(): Promise<void> {\n if(this.currentFetch) {\n return this.currentFetch;\n }\n\n const fetch = this.fetchFromFile();\n this.currentFetch = fetch;\n return fetch;\n }\n\n static async fetchFromFile (): Promise<void> {\n if(!existsSync(this.file)) {\n return;\n }\n\n try {\n const content = await readFile(this.file, {encoding: 'utf8'});\n this.currentData = JSON.parse(content);\n }\n catch(error) {\n console.warn(`Unable to parse cache file: ${error}`);\n }\n }\n\n static isCacheItemObject(obj: CacheItem): obj is CacheItemObject {\n\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n return typeof obj === 'object' && typeof obj.updated === 'number' && typeof obj.value !== 'undefined';\n }\n\n async get<T>(key: string, maxAge = 0): Promise<T | null> {\n await Cache.fetch();\n\n if(\n !Cache.currentData ||\n !Cache.currentData[this.namespace] ||\n !Cache.currentData[this.namespace][key]\n ) {\n return null;\n }\n\n const item = Cache.currentData[this.namespace][key];\n if(!Cache.isCacheItemObject(item) && maxAge > 0) {\n return null;\n }\n if(!Cache.isCacheItemObject(item)) {\n return item as T;\n }\n\n if(maxAge > 0 && new Date().getTime() - item.updated > maxAge) {\n return null;\n }\n\n return item.value as T;\n }\n\n async set(key: string, value: unknown): Promise<void> {\n await Cache.fetch();\n\n if(!Cache.currentData) {\n throw new Error('Unable to set value: currentData is empty!');\n }\n\n Cache.currentData[this.namespace] = Cache.currentData[this.namespace] || {};\n Cache.currentData[this.namespace][key] = {\n updated: new Date().getTime(),\n value\n };\n\n await Cache.save().catch(error => {\n console.warn(`Unable to update cache: ${error}`);\n });\n }\n\n async delete(key: string): Promise<void> {\n if(\n !Cache.currentData ||\n !Cache.currentData[this.namespace]\n ) {\n return;\n }\n\n delete Cache.currentData[this.namespace][key];\n\n if(Object.keys(Cache.currentData[this.namespace]).length === 0) {\n delete Cache.currentData[this.namespace];\n }\n\n await Cache.save().catch(error => {\n console.warn(`Unable to update cache: ${error}`);\n });\n }\n\n static async save(): Promise<void> {\n await writeFile(this.file, JSON.stringify(this.currentData, null, ' '));\n }\n}\n","import Cache from './cache.js';\n\nexport interface ConfigBoardData {\n id: string;\n key: string;\n secret: string;\n disabled: boolean;\n}\n\nexport interface ConfigMQTTData {\n url: string;\n prefix: string;\n}\n\nexport interface ConfigCalendarData {\n urls: Record<string, string>;\n cacheTTL: number;\n}\n\nexport interface ConfigData {\n board: ConfigBoardData;\n mqtt: ConfigMQTTData;\n calendar: ConfigCalendarData;\n}\n\nexport default class Config {\n private static readonly cache = new Cache('config');\n private static data?: ConfigData;\n\n public static get loaded(): boolean {\n return !!this.data && !!this.cache;\n }\n\n public static get board(): ConfigBoardData {\n if(this.loaded && this.data?.board) {\n return this.data.board;\n }\n\n throw new Error('Unable to access board config, is config loaded?');\n }\n\n public static get mqtt(): ConfigMQTTData {\n if(this.loaded && this.data?.mqtt) {\n return this.data.mqtt;\n }\n\n throw new Error('Unable to access mqtt config, is config loaded?');\n }\n\n public static get calendar(): ConfigCalendarData {\n if(this.loaded && this.data?.calendar) {\n return this.data.calendar;\n }\n\n throw new Error('Unable to access calendar config, is config loaded?');\n }\n\n public static async load(): Promise<void> {\n const data = await this.cache.get<ConfigData>('default');\n if(!data) {\n throw new Error('Unable to load configuration, try to run the setup script…');\n }\n\n this.data = data;\n }\n\n public static async save(data: ConfigData): Promise<void> {\n this.data = data;\n await this.cache.set('default', data);\n }\n\n public static async updateDisabled(newValue: boolean): Promise<void> {\n if(newValue === this.data?.board.disabled || !this.loaded || !this.data?.mqtt) {\n return;\n }\n\n this.data.board.disabled = newValue;\n await this.save(this.data);\n }\n}\n","import {type BoardCharArray, characterCode, emptyBoard, LINE_LENGTH} from 'vestaboard-api/lib/cjs/values.js';\n\nexport enum MessageWriteOptionsLine {\n CURRENT = 'CURRENT',\n NEXT = 'NEXT'\n}\n\nexport interface MessageWriteOptions {\n line?: number | MessageWriteOptionsLine;\n row?: number;\n}\n\nexport interface MessageDrawOptions {\n line?: number;\n}\n\n\nconst SPECIAL_CHAR_MAP = [\n ['ä', [1, 5]],\n ['Ä', [1, 5]],\n ['ö', [15, 5]],\n ['Ö', [15, 5]],\n ['ü', [21, 5]],\n ['Ü', [21, 5]],\n ['ß', [19, 19]],\n ['🟥', [63]],\n ['🟧', [64]],\n ['🟨', [65]],\n ['🟩', [66]],\n ['🟦', [67]],\n ['🟪', [68]],\n ['⬜️', [69]],\n ['⬜', [69]],\n ['⬛️', [0]],\n ['⬛', [0]],\n ['﹫', [38]],\n ['@', [38]],\n ['0️⃣', [36]],\n ['1️⃣', [27]],\n ['2️⃣', [28]],\n ['3️⃣', [29]],\n ['4️⃣', [30]],\n ['5️⃣', [31]],\n ['6️⃣', [32]],\n ['7️⃣', [33]],\n ['8️⃣', [34]],\n ['9️⃣', [35]],\n ['❕', [37]],\n ['‼️', [37, 37]],\n ['❗️', [37]],\n ['⁉️', [37, 60]],\n ['⚠️', [65]],\n ['#️⃣', [39]],\n ['💸', [40]],\n ['💲', [40]],\n ['💵', [40]],\n ['💰', [40]],\n ['$', [40]],\n ['﹩', [40]],\n ['$', [40]],\n ['←', [44]],\n ['→', [44]],\n ['➡', [44]],\n ['⬅', [44]],\n ['➔', [44]],\n ['↔', [44]],\n ['–', [44]],\n ['➕', [46]],\n ['+', [46]],\n ['﹪', [54]],\n ['%', [54]],\n ['❓', [60]],\n ['❔', [60]],\n ['℃', [62, 3]],\n ['℉', [62, 6]]\n];\n\n\nexport default class Message {\n private board: BoardCharArray;\n private currentLine: number | null = null;\n private isFilled = false;\n\n constructor(board: BoardCharArray = Message.newBoardCharArray()) {\n this.board = board;\n }\n\n static newBoardCharArray(): BoardCharArray {\n return JSON.parse(JSON.stringify(emptyBoard));\n }\n\n write(text: string, options: MessageWriteOptions = {}) : void{\n let firstLine = 0;\n if(this.isFilled) {\n return;\n }\n\n if(options.line === MessageWriteOptionsLine.CURRENT) {\n firstLine = this.currentLine || 0;\n }\n else if(options.line === MessageWriteOptionsLine.NEXT && this.currentLine === null) {\n this.currentLine = 0;\n firstLine = this.currentLine;\n }\n else if(\n options.line === MessageWriteOptionsLine.NEXT &&\n typeof this.currentLine === 'number' &&\n this.currentLine < this.board.length - 1\n ) {\n // console.log('write() → current line + 1');\n this.currentLine++;\n firstLine = this.currentLine;\n }\n else if(options.line === MessageWriteOptionsLine.NEXT) {\n this.isFilled = true;\n return;\n }\n else if(options.line !== undefined) {\n firstLine = options.line;\n }\n\n const status = {\n firstLine,\n lastLine: this.board.length - 1,\n firstRow: options.row || 0,\n lastRow: LINE_LENGTH - 1\n };\n const pointer = [status.firstRow, status.firstLine];\n\n const words = text.split(/\\s+/);\n words.forEach((word, i) => {\n\n // Space\n if(i !== 0 && pointer[0] !== status.firstRow) {\n this.board[pointer[1]][pointer[0]] = 0;\n pointer[0]++;\n }\n\n let charsLeftInLine = status.lastRow - pointer[0] + 1;\n const chars = Message.word2chars(word);\n // console.log(\n // 'write()',\n // 'chars =', chars,\n // 'left =', charsLeftInLine,\n // `(${status.lastRow} - ${pointer[0]})`,\n // 'pointer =', pointer,\n // 'charsLeftInLine =', charsLeftInLine\n // );\n\n // Unsupported Word / emoji?\n if(chars.filter(c => c === 60).length === chars.length && chars.length > 0) {\n return;\n }\n\n // New Line?\n if(\n chars.length > charsLeftInLine &&\n chars.length <= status.lastRow - status.firstRow + 1 &&\n pointer[1] < status.lastLine\n ) {\n pointer[0] = status.firstRow;\n pointer[1]++;\n charsLeftInLine = status.lastRow - pointer[0];\n // console.log('write() → new line', 'chars =', chars, 'left =', charsLeftInLine, `(${status.lastRow} - ${pointer[0]})`, 'pointer =', pointer);\n }\n\n // Add Word\n if(chars.length <= charsLeftInLine) {\n this.board[pointer[1]].splice(pointer[0], chars.length, ...chars);\n pointer[0] += chars.length;\n }\n else if(chars.length > charsLeftInLine && charsLeftInLine > 5) {\n this.board[pointer[1]].splice(pointer[0], charsLeftInLine, ...chars.slice(0, charsLeftInLine));\n pointer[0] += charsLeftInLine;\n }\n });\n this.currentLine = pointer[1];\n }\n\n static word2chars(word: string): number[] {\n const result: number[] = [];\n for(const char of word) {\n result.push(...this.char2char(char));\n }\n\n return result;\n }\n\n static char2char(char: string): number[] {\n const fromVestaMap = Object.entries(characterCode)\n .find(([key]) => char === key);\n if(fromVestaMap) {\n return [ fromVestaMap[1]] ;\n }\n\n const fromMyMap = SPECIAL_CHAR_MAP\n .find(([mapChar]) => char === mapChar);\n if(fromMyMap && Array.isArray(fromMyMap[1])) {\n return fromMyMap[1];\n }\n\n return [60];\n }\n\n repeat(char: string, options: MessageDrawOptions = {}): void {\n const line = this.board[options.line || 0];\n line.fill(Message.char2char(char)[0]);\n }\n\n centerLines(): void {\n this.board.forEach(line => {\n const space = [line.findIndex(c => c !== 0), line.slice().reverse().findIndex(c => c !== 0)];\n\n // Line is completely full, continue…\n if(space[0] === -1 || space[1] === -1) {\n return;\n }\n\n const content = line.slice(space[0], line.length - space[1]);\n const padding = Math.floor((space[0] + space[1]) / 2);\n\n line.fill(0, 0, padding);\n line.splice(padding, content.length, ...content);\n line.fill(0, padding + content.length);\n });\n }\n\n center(): void {\n const space = [\n this.board.findIndex(l => l.find(c => c !== 0)),\n Math.min(...this.board.map(l => l.find(c => c !== 0) ? l.slice().reverse().findIndex(c => c !== 0) : l.length)),\n this.board.slice().reverse().findIndex(l => l.find(c => c !== 0)),\n Math.min(...this.board.map(l => l.find(c => c !== 0) ? l.findIndex(c => c !== 0) : l.length)),\n ];\n\n const padding = [\n Math.floor((space[0] + space[2]) / 2),\n Math.floor((space[1] + space[3]) / 2)\n ];\n\n // Move up/down\n if(space[0] !== padding[0]) {\n const add = padding[0] - space[0];\n this.board.splice(space[0] < padding[0] ? 0 : this.board.length - add, 0,\n ...this.board.splice(this.board.length - add, add)\n );\n }\n\n // Move left/right\n if(space[3] !== padding[1]) {\n const add = padding[1] - space[3];\n\n this.board.forEach(line => {\n line.splice(space[3] < padding[1] ? 0 : line.length - add, 0,\n ...line.splice(line.length - add, add)\n );\n });\n }\n }\n\n isEmpty (): boolean {\n return !this.board.find(line =>\n line.find(char => char !== 0)\n );\n }\n\n toString(): string {\n return '#=' + '='.repeat(LINE_LENGTH * 2) + '=#\\n' +\n this.board\n .map(line => '# ' + line.map(char => Message.charToString(char)).join('') + ' #\\n')\n .join('') +\n '#=' + '='.repeat(LINE_LENGTH * 2) + '=#\\n';\n }\n\n static charToString(char: number): string {\n const entry = Object.entries(characterCode)\n .filter(([name]) => name.length <= 2)\n .find(([, code]) => code === char);\n\n if (entry) {\n return entry[0].toUpperCase() + ' ';\n }\n\n switch (char) {\n case 63:\n return '🟥';\n case 64:\n return '🟧';\n case 65:\n return '🟨';\n case 66:\n return '🟩';\n case 67:\n return '🟦';\n case 68:\n return '🟪';\n case 69:\n return '⬜️';\n default:\n return ' ';\n }\n }\n\n export(): BoardCharArray {\n return this.board;\n }\n}\n","import Cache from '../cache.js';\nimport Page, { type PageRenderResponse } from '../page.js';\nimport Message, { MessageWriteOptionsLine } from '../message.js';\n\n\nexport default class MessagePage implements Page<string> {\n static readonly cache = new Cache('calendar');\n\n parsePayload(payload: string | null): string {\n return payload || '';\n }\n\n parseConfig(): Partial<Record<string, never>> {\n return {};\n }\n\n public async render (content: string): Promise<PageRenderResponse> {\n const message = new Message();\n\n content.split('\\n').forEach(line => {\n message.write(line, {line: MessageWriteOptionsLine.NEXT});\n });\n\n message.centerLines();\n message.center();\n return {message};\n }\n}\n","import Cache from '../cache.js';\nimport Page, { type PageRenderResponse } from '../page.js';\nimport Message, {MessageWriteOptionsLine } from '../message.js';\nimport ical, { type VEvent } from 'node-ical';\nimport Config from '../config.js';\nimport TodayPage, { type TodayPagePayload } from './today.js';\n\n\nexport interface CalendarPagePayload {\n calendars: string[];\n}\n\nexport type CalendarPageItem = {start: Date, end: Date, summary: string};\n\nexport default class CalendarPage implements Page<CalendarPagePayload> {\n static readonly cache = new Cache('calendar');\n\n public parsePayload(payload: string | null): CalendarPagePayload {\n return {\n calendars: (payload || '').split(',')\n };\n }\n\n parseConfig(): Partial<Record<string, never>> {\n return {};\n }\n\n public async fetchURL(url: string): Promise<CalendarPageItem[]> {\n let preCached = await CalendarPage.cache.get<CalendarPageItem[]>(url, 1000 * 60 * 10);\n if(!preCached) {\n const calendar = await ical.async.fromURL(url);\n const events = Object.values(calendar)\n .filter(entry =>\n entry.type === 'VEVENT' &&\n entry.start &&\n entry.end &&\n entry.summary\n ) as VEvent[];\n preCached = events\n .map(entry => ({\n start: new Date(String(entry.start)),\n end: new Date(String(entry.end)),\n summary: String(entry.summary).trim()\n }))\n .filter(entry => entry.end > new Date())\n .sort((a, b) => a.end.getTime() - b.end.getTime())\n .slice(0, 6);\n\n await CalendarPage.cache.set(url, preCached);\n }\n\n return preCached\n .map(entry => ({\n start: new Date(String(entry.start)),\n end: new Date(String(entry.end)),\n summary: String(entry.summary)\n }))\n .filter(entry =>\n entry.end > new Date()\n );\n }\n\n public static isSameDay (a: Date, b: Date): boolean {\n const result = Boolean(\n a.getFullYear() === b.getFullYear() &&\n a.getMonth() === b.getMonth() &&\n a.getDate() === b.getDate()\n );\n\n return result;\n }\n\n public static isMidnight (date: Date): boolean {\n const result = Boolean(\n !date.getHours() &&\n !date.getMinutes() &&\n !date.getSeconds() &&\n !date.getMilliseconds()\n );\n\n return result;\n }\n\n public async fetchURLs(urls: string[]): Promise<CalendarPageItem[]> {\n const rawResult: {start: Date, end: Date, summary: string}[][] = await Promise.all(urls.map(url => this.fetchURL(url)));\n return ([] as CalendarPageItem[])\n .concat(...rawResult)\n .filter(entry => entry.end > new Date())\n .sort((a, b) => a.end.getTime() - b.end.getTime());\n }\n\n public static getTimeStr (event: CalendarPageItem, oneLine = false): string {\n if(\n this.isMidnight(event.start) &&\n this.isMidnight(event.end) &&\n this.isSameDay(new Date(), event.start)\n ) {\n return 'Heute';\n }\n if(\n this.isMidnight(event.start) &&\n this.isMidnight(event.end) &&\n this.isSameDay(new Date(new Date().getTime() + 1000 * 60 * 60 * 24), event.start)\n ) {\n return oneLine ? 'Morgen' : 'Morgn';\n }\n\n return event.start.getHours().toString().padStart(2, '⬛️') + ':' +\n event.start.getMinutes().toString().padStart(2, '0');\n }\n\n public async render (payload: CalendarPagePayload): Promise<PageRenderResponse> {\n const message = new Message();\n const urls = payload.calendars\n .map(id => Config.calendar.urls[id])\n .filter(Boolean);\n\n const calendar = await this.fetchURLs(urls)\n .then(calendar => calendar.filter(entry => {\n if (CalendarPage.isMidnight(entry.start) && CalendarPage.isMidnight(entry.end)) {\n return CalendarPage.isSameDay(new Date(), entry.start) || (\n new Date().getHours() >= 20 &&\n CalendarPage.isSameDay(new Date(new Date().getTime() + 1000 * 60 * 60 * 24), entry.start)\n );\n } else {\n return entry.start < new Date(new Date().getTime() + (1000 * 60 * 60 * 12));\n }\n }));\n\n if(!calendar.length) {\n const today = new TodayPage();\n const pageConfigCache = new Cache('page-config');\n const config = await pageConfigCache.get<Partial<TodayPagePayload>>('today');\n return today.render({}, config || {});\n }\n\n let validTill = new Date(new Date().getTime() + 1000 * 60 * 10);\n calendar.forEach(event => {\n message.write(\n CalendarPage.getTimeStr(event, calendar.length === 1),\n {line: MessageWriteOptionsLine.NEXT}\n );\n\n message.write(event.summary, {line: MessageWriteOptionsLine.CURRENT, row: 6});\n message.write('', {line: MessageWriteOptionsLine.NEXT});\n\n if(event.end < validTill) {\n validTill = event.end;\n }\n });\n\n message.center();\n return {\n message,\n validTill\n };\n }\n}\n","import Cache from '../cache.js';\nimport Page, { type PageRenderResponse } from '../page.js';\nimport Message, {MessageWriteOptionsLine} from '../message.js';\n\nexport interface TodayPagePayload {\n temp?: [number, number];\n precip?: number;\n locale: string;\n}\n\nexport default class TodayPage implements Page<Partial<TodayPagePayload>, TodayPagePayload> {\n static readonly cache = new Cache('calendar');\n\n parsePayload(payload: string | null): Partial<TodayPagePayload> {\n try {\n return JSON.parse(payload || '') as Partial<TodayPagePayload>;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n catch(error) {\n return {};\n }\n }\n\n parseConfig(key: string, value: string | null, config: Partial<TodayPagePayload>): Partial<TodayPagePayload> {\n const result: Partial<TodayPagePayload> = {};\n console.log('parseConfig', config);\n\n if(key === 'min-temp' && Array.isArray(config.temp)) {\n result.temp = [\n parseInt(value || ''),\n Math.max(...config.temp)\n ];\n }\n else if(key === 'min-temp') {\n result.temp = [\n parseInt(value || ''),\n parseInt(value || '')\n ];\n }\n else if(key === 'max-temp' && Array.isArray(config.temp)) {\n result.temp = [\n Math.min(...config.temp),\n parseInt(value || '')\n ];\n }\n else if(key === 'max-temp') {\n result.temp = [\n parseInt(value || ''),\n parseInt(value || '')\n ];\n }\n else if(key === 'precip') {\n result.precip = parseInt(value || '', 10);\n }\n else if(key === 'locale') {\n result.locale = String(value);\n }\n\n return result;\n }\n\n public async render (payload: Partial<TodayPagePayload>, config: Partial<TodayPagePayload>): Promise<PageRenderResponse> {\n const message = new Message();\n const today = new Date();\n\n const mergedPayload: TodayPagePayload = Object.assign({\n temp: undefined,\n precip: undefined,\n locale: 'en'\n }, config, payload);\n\n message.write(today.toLocaleString(mergedPayload.locale, {weekday: 'long'}));\n message.write(\n today.toLocaleString(mergedPayload.locale, {day: 'numeric', month: 'long'}),\n {line: MessageWriteOptionsLine.NEXT}\n );\n\n message.write('', {line: MessageWriteOptionsLine.NEXT});\n\n const varContent = [];\n if(Array.isArray(mergedPayload.temp)) {\n varContent.push(`${Math.min(...mergedPayload.temp)}-${Math.max(...mergedPayload.temp)}°C`);\n }\n if(typeof mergedPayload.precip === 'number' && mergedPayload.precip > 0) {\n varContent.push(`${mergedPayload.precip}%`);\n }\n if(varContent.length) {\n message.write(varContent.join(', '), {line: MessageWriteOptionsLine.NEXT});\n }\n\n message.center();\n\n const validTill = new Date();\n validTill.setHours(24,0,0,0);\n\n return { message, validTill };\n }\n}\n","import Page from '../page.js';\nimport MessagePage from './message.js';\nimport CalendarPage from './calendar.js';\nimport TodayPage from './today.js';\n\nconst pages: Record<string, Page<unknown, unknown>> = {\n message: new MessagePage(),\n calendar: new CalendarPage(),\n today: new TodayPage()\n};\n\nexport default pages;\n","#!/usr/bin/env node\n'use strict';\n\nimport Vestaboard2MQTT from '../lib/index.js';\n\nVestaboard2MQTT.run().catch(error => {\n console.log(error);\n process.exit(1);\n});\n"],"mappings":"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","names":["require_immutable","__commonJSMin","exports","module","extend","hasOwnProperty","target","i","source","key","require_stream","__commonJSMin","exports","module","require_buffer_list","__commonJSMin","exports","module","ownKeys","object","enumerableOnly","keys","symbols","sym","_objectSpread","target","i","source","key","_defineProperty","obj","value","_classCallCheck","instance","Constructor","_defineProperties","props","descriptor","_createClass","protoProps","staticProps","_require","Buffer","_require2","inspect","custom","copyBuffer","src","offset","BufferList","v","entry","ret","s","p","n","hasStrings","c","str","nb","buf","_","options","require_destroy","__commonJSMin","exports","module","destroy","err","cb","_this","readableDestroyed","writableDestroyed","emitErrorNT","emitCloseNT","emitErrorAndCloseNT","self","undestroy","errorOrDestroy","stream","rState","wState","require_errors","__commonJSMin","exports","module","codes","createErrorType","code","message","Base","getMessage","arg1","arg2","arg3","NodeError","oneOf","expected","thing","len","startsWith","str","search","pos","endsWith","this_len","includes","start","name","value","actual","determiner","msg","type","arg","require_state","__commonJSMin","exports","module","ERR_INVALID_OPT_VALUE","highWaterMarkFrom","options","isDuplex","duplexKey","getHighWaterMark","state","hwm","name","require_inherits_browser","__commonJSMin","exports","module","ctor","superCtor","TempCtor","require_inherits","__commonJSMin","exports","module","util","require_node","__commonJSMin","exports","module","require_stream_writable","__commonJSMin","exports","module","Writable","CorkedRequest","state","_this","onCorkedFinish","Duplex","WritableState","internalUtil","Stream","Buffer","OurUint8Array","_uint8ArrayToBuffer","chunk","_isUint8Array","obj","destroyImpl","_require","getHighWaterMark","_require$codes","ERR_INVALID_ARG_TYPE","ERR_METHOD_NOT_IMPLEMENTED","ERR_MULTIPLE_CALLBACK","ERR_STREAM_CANNOT_PIPE","ERR_STREAM_DESTROYED","ERR_STREAM_NULL_VALUES","ERR_STREAM_WRITE_AFTER_END","ERR_UNKNOWN_ENCODING","errorOrDestroy","nop","options","stream","isDuplex","noDecode","er","onwrite","current","out","realHasInstance","object","writeAfterEnd","cb","validChunk","encoding","ret","isBuf","writeOrBuffer","clearBuffer","decodeChunk","newChunk","len","last","doWrite","writev","onwriteError","sync","finishMaybe","onwriteStateUpdate","finished","needFinish","afterWrite","onwriteDrain","entry","l","buffer","holder","count","allBuffers","endWritable","callFinal","err","prefinish","need","rState","corkReq","value","require_stream_duplex","__commonJSMin","exports","module","objectKeys","obj","keys","key","Duplex","Readable","Writable","v","method","options","onend","onEndNT","self","value","require_safe_buffer","__commonJSMin","exports","module","buffer","Buffer","copyProps","src","dst","key","SafeBuffer","arg","encodingOrOffset","length","size","fill","encoding","buf","require_string_decoder","__commonJSMin","exports","Buffer","isEncoding","encoding","_normalizeEncoding","enc","retried","normalizeEncoding","nenc","StringDecoder","nb","utf16Text","utf16End","utf8FillLast","base64Text","base64End","simpleWrite","simpleEnd","buf","r","i","utf8End","utf8Text","utf8CheckByte","byte","utf8CheckIncomplete","self","j","utf8CheckExtraBytes","p","total","end","c","n","require_end_of_stream","__commonJSMin","exports","module","ERR_STREAM_PREMATURE_CLOSE","once","callback","called","_len","args","_key","noop","isRequest","stream","eos","opts","readable","writable","onlegacyfinish","onfinish","writableEnded","readableEnded","onend","onerror","err","onclose","onrequest","require_async_iterator","__commonJSMin","exports","module","_Object$setPrototypeO","_defineProperty","obj","key","value","finished","kLastResolve","kLastReject","kError","kEnded","kLastPromise","kHandlePromise","kStream","createIterResult","done","readAndResolve","iter","resolve","data","onReadable","wrapForNext","lastPromise","reject","AsyncIteratorPrototype","ReadableStreamAsyncIteratorPrototype","_this","error","promise","_this2","err","createReadableStreamAsyncIterator","stream","_Object$create","iterator","require_from","__commonJSMin","exports","module","asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","_asyncToGenerator","fn","self","args","err","ownKeys","object","enumerableOnly","keys","symbols","sym","_objectSpread","target","i","source","_defineProperty","obj","ERR_INVALID_ARG_TYPE","from","Readable","iterable","opts","iterator","readable","reading","next","_next2","_ref","done","require_stream_readable","__commonJSMin","exports","module","Readable","Duplex","ReadableState","EE","EElistenerCount","emitter","type","Stream","Buffer","OurUint8Array","_uint8ArrayToBuffer","chunk","_isUint8Array","obj","debugUtil","debug","BufferList","destroyImpl","_require","getHighWaterMark","_require$codes","ERR_INVALID_ARG_TYPE","ERR_STREAM_PUSH_AFTER_EOF","ERR_METHOD_NOT_IMPLEMENTED","ERR_STREAM_UNSHIFT_AFTER_END_EVENT","StringDecoder","createReadableStreamAsyncIterator","from","errorOrDestroy","kProxyEvents","prependListener","event","fn","options","stream","isDuplex","value","err","cb","encoding","state","skipChunkCheck","readableAddChunk","addToFront","onEofChunk","er","chunkInvalid","addChunk","maybeReadMore","emitReadable","enc","decoder","p","content","MAX_HWM","computeNewHighWaterMark","n","howMuchToRead","nOrig","endReadable","doRead","ret","fromList","emitReadable_","flow","maybeReadMore_","len","dest","pipeOpts","src","doEnd","endFn","onend","unpipe","onunpipe","readable","unpipeInfo","cleanup","ondrain","pipeOnDrain","cleanedUp","onclose","onfinish","onerror","ondata","indexOf","dests","i","index","ev","res","nReadingNextTick","updateReadableListening","self","resume","resume_","_this","paused","method","endReadableNT","wState","iterable","opts","xs","x","l","require_stream_transform","__commonJSMin","exports","module","Transform","_require$codes","ERR_METHOD_NOT_IMPLEMENTED","ERR_MULTIPLE_CALLBACK","ERR_TRANSFORM_ALREADY_TRANSFORMING","ERR_TRANSFORM_WITH_LENGTH_0","Duplex","afterTransform","er","data","ts","cb","rs","options","prefinish","_this","done","chunk","encoding","n","err","err2","stream","require_stream_passthrough","__commonJSMin","exports","module","PassThrough","Transform","options","chunk","encoding","cb","require_pipeline","__commonJSMin","exports","module","eos","once","callback","called","_require$codes","ERR_MISSING_ARGS","ERR_STREAM_DESTROYED","noop","err","isRequest","stream","destroyer","reading","writing","closed","destroyed","call","fn","pipe","from","to","popCallback","streams","pipeline","_len","_key","error","destroys","i","require_readable","__commonJSMin","exports","module","Stream","require_store","__commonJSMin","exports","module","xtend","Readable","streamsOpts","defaultStoreOptions","Store","options","packet","cb","stream","values","destroyed","value","key","self","require_topic_alias_recv","__commonJSMin","exports","module","TopicAliasRecv","max","topic","alias","require_iterator","__commonJSMin","exports","module","Yallist","walker","require_yallist","__commonJSMin","exports","module","Yallist","Node","list","self","item","i","l","node","next","prev","head","tail","push","unshift","res","fn","thisp","walker","n","initial","acc","arr","from","to","ret","start","deleteCount","nodes","insert","p","value","inserted","require_lru_cache","__commonJSMin","exports","module","Yallist","MAX","LENGTH","LENGTH_CALCULATOR","ALLOW_STALE","MAX_AGE","DISPOSE","NO_DISPOSE_ON_SET","LRU_LIST","CACHE","UPDATE_AGE_ON_GET","naiveLength","LRUCache","options","max","lc","mL","trim","allowStale","mA","lC","hit","fn","thisp","walker","prev","forEachStep","next","k","isStale","h","key","value","maxAge","now","len","del","item","Entry","get","node","arr","l","expiresAt","self","doUse","diff","length","__extends","ContainerIterator","Base","Container","init_ContainerBase","__esmMin","extendStatics","d","b","p","__","iteratorType","_super","__extends","Stack","Stack_default","init_Stack","__esmMin","init_ContainerBase","extendStatics","d","b","p","__","_super","container","_this","element","Base","__extends","SequentialContainer","Base_default","init_Base","__esmMin","init_ContainerBase","extendStatics","d","b","p","__","_super","Container","checkWithinAccessParams","pos","lower","upper","init_checkParams","__esmMin","__extends","RandomIterator","init_RandomIterator","__esmMin","init_checkParams","init_ContainerBase","extendStatics","d","b","p","__","_super","index","size","getElementByPos","setElementByPos","iteratorType","_this","ContainerIterator","checkWithinAccessParams","newValue","obj","__extends","__generator","__read","__spreadArray","DequeIterator","Deque","Deque_default","init_Deque","__esmMin","init_Base","init_checkParams","init_ContainerBase","init_RandomIterator","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","m","r","ar","error","to","from","pack","l","_super","RandomIterator","container","bucketSize","_this","_length","i","needBucketNum","element","newMap","addBucketNum","pos","offset","offsetRemainder","curNodePointerIndex","curNodeBucketIndex","ContainerIterator","callback","checkWithinAccessParams","_a","num","arr","value","iter","node","tmp","index","pre","cur","cmp","Base_default","__extends","Queue","Queue_default","init_Queue","__esmMin","init_Deque","init_ContainerBase","extendStatics","d","b","p","__","_super","container","_this","Deque_default","element","Base","__extends","__read","__spreadArray","PriorityQueue","PriorityQueue_default","init_PriorityQueue","__esmMin","init_ContainerBase","extendStatics","d","b","p","__","o","n","m","r","ar","e","error","to","from","pack","l","_super","container","cmp","copy","_a","x","y","_this","element","parent_1","curParent","curChild","left","right","minChild","parent","_b","curNode","parent_2","last","Base","__extends","__generator","__read","__spreadArray","__values","VectorIterator","Vector","Vector_default","init_Vector","__esmMin","init_Base","init_checkParams","init_ContainerBase","init_RandomIterator","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","m","r","ar","error","to","from","pack","l","s","_super","RandomIterator","container","copy","_this","element","ContainerIterator","callback","pos","checkWithinAccessParams","value","index","i","iter","node","num","_a","cmp","Base_default","__extends","__generator","LinkNode","LinkListIterator","LinkList","LinkList_default","init_LinkList","__esmMin","init_Base","init_checkParams","init_ContainerBase","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","element","_super","node","header","iteratorType","_this","ContainerIterator","newValue","obj","container","callback","curNode","index","pos","checkWithinAccessParams","pre","next","value","iter","newTail","num","i","pHead","pTail","cnt","tmp","tmpNode","cmp","arr","newHead","list","_a","Base_default","TreeNode","TreeNode_default","init_TreeNode","__esmMin","key","value","preNode","pre","nextNode","PP","V","R","F","K","parent","__extends","__read","TreeContainer","Base_default","init_Base","__esmMin","init_TreeNode","init_ContainerBase","init_checkParams","extendStatics","d","b","p","__","o","n","m","r","ar","e","error","_super","cmp","x","y","_this","TreeNode_default","curNode","callback","ifReturn","key","resNode","cmpResult","parentNode","brother","_a","_b","swapNode","grandParent","uncle","GP","value","hint","minNode","compareToMin","maxNode","compareToMax","iterNode","iterCmpRes","preNode","preCmpRes","iter","node","preKey","nextKey","pos","checkWithinAccessParams","index","traversal","Container","__extends","TreeIterator","TreeIterator_default","init_TreeIterator","__esmMin","init_ContainerBase","extendStatics","d","b","p","__","_super","node","header","iteratorType","_this","ContainerIterator","obj","__extends","__generator","__values","OrderedSetIterator","OrderedSet","OrderedSet_default","init_OrderedSet","__esmMin","init_Base","init_ContainerBase","init_checkParams","init_TreeIterator","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","s","m","_super","TreeIterator_default","container","cmp","_this","curNode","_a","element","ContainerIterator","callback","e_1","index","_b","_c","e_1_1","pos","e_2","checkWithinAccessParams","res","e_2_1","key","hint","resNode","other","Base_default","__extends","__generator","__read","__values","OrderedMapIterator","OrderedMap","OrderedMap_default","init_OrderedMap","__esmMin","init_ContainerBase","init_checkParams","init_Base","init_TreeIterator","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","m","r","ar","error","s","_super","_this","props","newValue","TreeIterator_default","container","cmp","curNode","_a","_b","key","value","ContainerIterator","minNode","maxNode","callback","e_1","index","_c","pair","e_1_1","resNode","hint","pos","e_2","checkWithinAccessParams","res","e_2_1","other","Base_default","__extends","HashContainer","Base_default","init_Base","__esmMin","init_ContainerBase","extendStatics","d","b","p","__","_super","initBucketNum","hashFunc","x","str","hashCode","strLength","i","ch","_this","Base","__extends","__generator","__values","HashSet","HashSet_default","init_HashSet","__esmMin","init_Base","init_Vector","init_OrderedSet","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","s","m","_super","container","initBucketNum","hashFunc","_this","element","Base_default","newHashTable","originalBucketNum","keys","keyNums","_loop_1","i","index","this_1","size","Vector_default","lowList","highList","hashCode","OrderedSet_default","callback","containers","containersNum","preSize","curSize","key","container_1","container_1_1","e_1_1","e_1","_a","_b","__extends","__generator","__values","HashMap","HashMap_default","init_HashMap","__esmMin","init_Base","init_Vector","init_OrderedMap","extendStatics","d","b","p","__","thisArg","body","_","t","f","y","g","verb","n","v","step","op","e","o","s","m","_super","container","initBucketNum","hashFunc","_this","element","Base_default","newHashTable","originalBucketNum","keys","keyNums","_loop_1","i","index","this_1","size","Vector_default","lowList","highList","hashCode","OrderedMap_default","callback","containers","containersNum","key","value","e_1","_a","preSize","container_1","container_1_1","pair","e_1_1","curSize","e_2","container_2","container_2_1","e_2_1","e_3","pos","container_3","container_3_1","e_3_1","e_4","container_4","container_4_1","e_4_1","container_5","container_5_1","e_5_1","e_5","_b","esm_exports","__export","Container","ContainerIterator","Deque_default","DequeIterator","Base_default","HashMap_default","HashSet_default","LinkList_default","LinkListIterator","OrderedMap_default","OrderedMapIterator","OrderedSet_default","OrderedSetIterator","PriorityQueue_default","Queue_default","Stack_default","Vector_default","VectorIterator","init_esm","__esmMin","init_Stack","init_Queue","init_PriorityQueue","init_Vector","init_LinkList","init_Deque","init_OrderedSet","init_OrderedMap","init_HashSet","init_HashMap","init_ContainerBase","init_Base","require_ms","__commonJSMin","exports","module","s","m","h","d","w","y","val","options","type","parse","fmtLong","fmtShort","str","match","n","ms","msAbs","plural","name","isPlural","require_common","__commonJSMin","exports","module","setup","env","createDebug","coerce","disable","enable","enabled","destroy","key","selectColor","namespace","hash","i","prevTime","enableOverride","namespacesCache","enabledCache","debug","args","self","curr","ms","index","match","format","formatter","val","extend","v","delimiter","newDebug","namespaces","split","len","toNamespace","name","regexp","require_browser","__commonJSMin","exports","module","formatArgs","save","load","useColors","localstorage","warned","m","args","c","index","lastC","match","namespaces","r","formatters","v","error","require_has_flag","__commonJSMin","exports","module","flag","argv","prefix","position","terminatorPosition","require_supports_color","__commonJSMin","exports","module","os","tty","hasFlag","env","forceColor","translateLevel","level","supportsColor","haveStream","streamIsTTY","min","osRelease","sign","version","getSupportLevel","stream","require_node","__commonJSMin","exports","module","tty","util","init","log","formatArgs","save","load","useColors","supportsColor","key","obj","prop","_","k","val","args","name","c","colorCode","prefix","getDate","namespaces","debug","keys","i","formatters","v","str","require_src","__commonJSMin","exports","module","require_number_allocator","__commonJSMin","exports","module","SortedSet","debugTrace","debugError","Interval","low","high","other","NumberAllocator","min","max","lhs","rhs","it","num","key","rLow","rHigh","lLow","element","require_number_allocator","__commonJSMin","exports","module","NumberAllocator","require_topic_alias_send","__commonJSMin","exports","module","LruMap","NumberAllocator","TopicAliasSend","max","topic","alias","entry","require_BufferList","__commonJSMin","exports","module","Buffer","symbol","BufferList","buf","offset","tot","_t","blOffset","bufferId","index","start","end","dst","dstStart","srcStart","srcEnd","copy","off","len","bytes","bufoff","i","l","startOffset","endOffset","buffers","encoding","search","blIndex","buffOffset","buff","nativeSearchResult","revOffset","searchOffset","methods","m","byteLength","b","require_bl","__commonJSMin","exports","module","DuplexStream","inherits","BufferList","BufferListStream","callback","piper","err","src","buf","encoding","size","chunk","cb","b","require_packet","__commonJSMin","exports","module","Packet","require_constants","__commonJSMin","exports","module","protocol","k","v","prop","id","genHeader","type","qos","dup","retain","buf","require_parser","__commonJSMin","exports","module","bl","EventEmitter","Packet","constants","debug","Parser","_Parser","opt","buf","zero","result","topic","payload","password","username","flags","packet","protocolId","properties","clientId","willProperties","options","qos","rh","rap","nl","subscription","maybeBuffer","length","end","fullInfoFlag","maxBytes","bytes","mul","value","current","padding","type","name","currentUserProperty","currentValue","err","require_numbers","__commonJSMin","exports","module","cache","SubOk","generateBuffer","i","buffer","generateCache","genBufVariableByteInt","num","digit","pos","generate4ByteBuffer","require_process_nextick_args","__commonJSMin","exports","module","nextTick","fn","arg1","arg2","arg3","len","args","i","require_writeToStream","__commonJSMin","exports","module","protocol","empty","zeroBuf","numbers","nextTick","debug","numCache","generateNumber","generateCache","genBufVariableByteInt","generate4ByteBuffer","writeNumber","writeNumberCached","toGenerate","generate","packet","stream","opts","uncork","connect","connack","publish","confirmation","subscribe","suback","unsubscribe","unsuback","emptyPacket","disconnect","auth","value","writeNumberGenerated","settings","protocolId","protocolVersion","will","clean","keepalive","clientId","username","password","properties","length","propertiesData","getProperties","willProperties","providedUsername","isStringOrBuffer","byteLength","writeVarByteInt","writeStringOrBuffer","flags","writeString","version","rc","qos","retain","topic","payload","id","type","dup","reasonCode","getPropertiesByMaximumPacketSize","subs","i","itopic","iqos","rh","result","sub","jtopic","jqos","jnl","jrap","jrh","joptions","granted","unsubs","j","varByteIntCache","num","buffer","string","strlen","writeStringPair","name","number","generatedNumber","write4ByteNumber","generated4ByteBuffer","toWrite","writeProperties","propertiesLength","getLengthProperty","currentValue","currentLength","propName","propLength","propValueLength","propValue","valueIndex","mayEmptyProps","maximumPacketSize","currentMayEmptyProp","writeProperty","bufOrString","field","require_generate","__commonJSMin","exports","module","writeToStream","EventEmitter","generate","packet","opts","stream","Accumulator","chunk","length","lengths","list","pos","i","result","require_mqtt","__commonJSMin","exports","require_default_message_id_provider","__commonJSMin","exports","module","DefaultMessageIdProvider","id","messageId","require_reinterval","__commonJSMin","exports","module","ReInterval","callback","interval","args","self","reInterval","i","require_rfdc","__commonJSMin","exports","module","rfdc","copyBuffer","cur","opts","rfdcCircles","cloneProto","clone","cloneArray","a","fn","keys","a2","i","k","o","o2","refs","refsNew","index","require_default","__commonJSMin","exports","module","require_validations","__commonJSMin","exports","module","validateTopic","topic","parts","i","validateTopics","topics","require_client","__commonJSMin","exports","module","EventEmitter","Store","TopicAliasRecv","TopicAliasSend","mqttPacket","DefaultMessageIdProvider","Writable","inherits","reInterval","clone","validations","xtend","debug","nextTick","callback","setImmediate","defaultConnectOptions","socketErrors","errors","defaultId","applyTopicAlias","client","packet","alias","topic","removeTopicAliasAndRecoverTopicName","sendPacket","cb","result","nop","flush","queue","messageId","flushVolatile","storeAndSend","cbStorePut","storePacket","err","error","MqttClient","streamBuilder","options","k","that","deliver","entry","send","writable","parser","completeParse","packets","nextTickWork","work","done","buf","enc","streamErrorHandler","connectPacket","authPacket","message","opts","publishProc","args","i","subs","obj","resubscribe","version","invalidTopic","defaultOpts","currentOpts","subscribeProc","topics","sub","granted","unsubscribeProc","force","closeStores","e1","e2","finish","f","forced","rc","qos","validReasonCodes","gotTopic","code","type","response","pubackRC","pubrecRC","grantedI","comp","pub","_resubscribeTopicsKeys","topicI","resubscribeTopic","startStreamProcess","outStore","clearStoreProcessing","remove","storeDeliver","status","allProcessed","id","require_tcp","__commonJSMin","exports","module","net","debug","streamBuilder","client","opts","port","host","require_tls","__commonJSMin","exports","module","tls","net","debug","buildBuilder","mqttClient","opts","connection","handleTLSerrors","err","require_wrappy","__commonJSMin","exports","module","wrappy","fn","cb","k","wrapper","args","i","ret","require_once","__commonJSMin","exports","module","wrappy","once","onceStrict","fn","f","name","require_end_of_stream","__commonJSMin","exports","module","once","noop","isRequest","stream","isChildProcess","eos","opts","callback","ws","rs","readable","writable","cancelled","onlegacyfinish","onfinish","onend","onexit","exitCode","onerror","err","onclose","onclosenexttick","onrequest","require_stream_shift","__commonJSMin","exports","module","shift","stream","rs","getStateLength","state","require_duplexify","__commonJSMin","exports","module","stream","eos","inherits","shift","SIGNAL_FLUSH","onuncork","self","fn","autoDestroy","err","destroyer","end","ws","noop","toStreams2","rs","Duplexify","writable","readable","opts","unend","ondrain","clear","onreadable","onend","data","cb","enc","require_wx","__commonJSMin","exports","module","Buffer","Transform","duplexify","socketTask","proxy","stream","buildProxy","chunk","encoding","next","errMsg","done","setDefaultOpts","opts","buildUrl","client","protocol","url","bindEventHandler","res","data","buildStream","websocketSubProtocol","err","cb","destroyRef","self","require_ali","__commonJSMin","exports","module","Buffer","Transform","duplexify","my","proxy","stream","isInitialized","buildProxy","chunk","encoding","next","done","setDefaultOpts","opts","buildUrl","client","protocol","url","bindEventHandler","res","buffer","reader","data","buildStream","websocketSubProtocol","require_constants","__commonJSMin","exports","module","require_buffer_util","__commonJSMin","exports","module","EMPTY_BUFFER","concat","list","totalLength","target","offset","i","buf","_mask","source","mask","output","length","_unmask","buffer","toArrayBuffer","toBuffer","data","bufferUtil","bu","require_limiter","__commonJSMin","exports","module","kDone","kRun","Limiter","concurrency","job","require_permessage_deflate","__commonJSMin","exports","module","zlib","bufferUtil","Limiter","kStatusCode","NOOP","TRAILER","kPerMessageDeflate","kTotalLength","kCallback","kBuffers","kError","zlibLimiter","PerMessageDeflate","options","isServer","maxPayload","concurrency","params","configurations","callback","offers","opts","accepted","response","key","value","num","data","fin","done","err","result","endpoint","windowBits","inflateOnError","inflateOnData","deflateOnData","chunk","require_validation","__commonJSMin","exports","module","isValidStatusCode","code","_isValidUTF8","buf","len","i","isValidUTF8","require_receiver","__commonJSMin","exports","module","Writable","PerMessageDeflate","BINARY_TYPES","EMPTY_BUFFER","kStatusCode","kWebSocket","concat","toArrayBuffer","unmask","isValidStatusCode","isValidUTF8","GET_INFO","GET_PAYLOAD_LENGTH_16","GET_PAYLOAD_LENGTH_64","GET_MASK","GET_DATA","INFLATING","Receiver","binaryType","extensions","isServer","maxPayload","chunk","encoding","cb","n","buf","dst","offset","err","error","compressed","num","data","er","messageLength","fragments","code","ErrorCtor","message","prefix","statusCode","errorCode","require_sender","__commonJSMin","exports","module","net","tls","randomFillSync","PerMessageDeflate","EMPTY_BUFFER","isValidStatusCode","applyMask","toBuffer","mask","Sender","_Sender","socket","extensions","data","options","merge","offset","payloadLength","target","code","cb","buf","length","readOnly","perMessageDeflate","opcode","rsv1","opts","compress","_","err","i","callback","params","list","require_event_target","__commonJSMin","exports","module","Event","type","target","MessageEvent","data","CloseEvent","code","reason","OpenEvent","ErrorEvent","error","EventTarget","listener","options","onMessage","onClose","message","onError","onOpen","method","listeners","require_extension","__commonJSMin","exports","module","tokenChars","push","dest","name","elem","parse","header","offers","params","mustUnescape","isEscaping","inQuotes","extensionName","paramName","start","end","i","code","value","token","format","extensions","extension","configurations","k","values","v","require_websocket","__commonJSMin","exports","module","EventEmitter","https","http","net","tls","randomBytes","createHash","Readable","URL","PerMessageDeflate","Receiver","Sender","BINARY_TYPES","EMPTY_BUFFER","GUID","kStatusCode","kWebSocket","NOOP","addEventListener","removeEventListener","format","parse","toBuffer","readyStates","protocolVersions","closeTimeout","WebSocket","_WebSocket","address","protocols","options","initAsClient","type","listener","socket","head","maxPayload","receiver","receiverOnConclude","receiverOnDrain","receiverOnError","receiverOnMessage","receiverOnPing","receiverOnPong","socketOnClose","socketOnData","socketOnEnd","socketOnError","code","data","abortHandshake","err","mask","cb","sendAfterClose","opts","property","method","listeners","i","websocket","parsedUrl","isUnixSocket","emitErrorAndClose","isSecure","defaultPort","key","get","perMessageDeflate","tlsConnect","netConnect","parts","headers","value","isSameHost","req","res","location","statusCode","addr","digest","serverProt","protList","protError","secWebSocketExtensions","extensions","extensionNames","stream","message","length","reason","resume","receiverOnFinish","chunk","require_stream","__commonJSMin","exports","module","Duplex","emitClose","stream","duplexOnEnd","duplexOnError","err","createWebSocketStream","ws","options","resumeOnReceiverDrain","terminateOnDestroy","receiverOnDrain","duplex","msg","callback","called","chunk","encoding","require_websocket_server","__commonJSMin","exports","module","EventEmitter","http","https","net","tls","createHash","PerMessageDeflate","WebSocket","format","parse","GUID","kWebSocket","keyRegex","RUNNING","CLOSING","CLOSED","WebSocketServer","options","callback","req","res","body","emitConnection","addListeners","socket","head","cb","emitClose","client","server","index","socketOnError","key","version","extensions","abortHandshake","perMessageDeflate","offers","info","verified","code","message","headers","ws","protocol","trim","params","value","map","event","h","str","require_ws","__commonJSMin","exports","module","WebSocket","require_ws","__commonJSMin","exports","module","Buffer","WS","debug","duplexify","Transform","WSS_OPTIONS","IS_BROWSER","buildUrl","opts","client","url","setDefaultOpts","options","prop","setDefaultBrowserOpts","parsed","createWebSocket","websocketSubProtocol","createBrowserWebSocket","socket","streamBuilder","webSocketStream","browserStreamBuilder","stream","bufferSize","bufferTimeout","coerceToBuffer","proxy","buildProxy","socketWriteBrowser","socketEndBrowser","writev","eventListenerSupport","onopen","onclose","onerror","onmessage","socketWrite","socketEnd","err","event","data","chunks","cb","buffers","i","chunk","enc","next","done","require_connect","__commonJSMin","exports","module","MqttClient","Store","url","xtend","debug","protocols","parseAuthOptions","opts","matches","connect","brokerUrl","parsed","isSecure","key","index","wrapper","client","require_unique_message_id_provider","__commonJSMin","exports","module","NumberAllocator","UniqueMessageIdProvider","messageId","require_mqtt","__commonJSMin","exports","module","MqttClient","connect","Store","DefaultMessageIdProvider","UniqueMessageIdProvider","import_async_mqtt","import_path","import_fs","readFile","writeFile","Cache","_Cache","namespace","fetch","content","error","obj","key","maxAge","item","value","Config","Cache","data","newValue","import_mqtt","import_values","SPECIAL_CHAR_MAP","Message","_Message","board","text","options","firstLine","status","pointer","word","i","charsLeftInLine","chars","c","result","char","fromVestaMap","key","fromMyMap","mapChar","line","space","content","padding","l","add","entry","name","code","MessagePage","Cache","payload","content","message","Message","line","import_node_ical","TodayPage","Cache","payload","key","value","config","result","message","Message","today","mergedPayload","varContent","validTill","CalendarPage","_CalendarPage","Cache","payload","url","preCached","calendar","ical","entry","a","b","date","urls","rawResult","event","oneLine","message","Message","id","Config","today","TodayPage","config","validTill","pages","MessagePage","CalendarPage","TodayPage","pages_default","import_vestaboard_api","Vestaboard2MQTT","_Vestaboard2MQTT","Cache","Config","mqtt","error","topic","message","msg","payload","value","pages_default","id","page","key","cache","config","newConfig","pageEntry","pageInstance","parsePayload","response","Message","charArray","subscriptions","i","Vestaboard2MQTT","error"]}