$91 GRAYBYTE WORDPRESS FILE MANAGER $51

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/cpanel/ea-nodejs22/lib/node_modules/npm/lib/utils/

HOME
Current File : /opt/cpanel/ea-nodejs22/lib/node_modules/npm/lib/utils//timers.js
const EE = require('node:events')
const fs = require('node:fs')
const { log, time } = require('proc-log')

const INITIAL_TIMER = 'npm'

class Timers extends EE {
  #file
  #timing

  #unfinished = new Map()
  #finished = {}

  constructor () {
    super()
    this.on()
    time.start(INITIAL_TIMER)
    this.started = this.#unfinished.get(INITIAL_TIMER)
  }

  on () {
    process.on('time', this.#timeHandler)
  }

  off () {
    process.off('time', this.#timeHandler)
  }

  load ({ path, timing } = {}) {
    this.#timing = timing
    this.#file = `${path}timing.json`
  }

  finish (metadata) {
    time.end(INITIAL_TIMER)

    for (const [name, timer] of this.#unfinished) {
      log.silly('unfinished npm timer', name, timer)
    }

    if (!this.#timing) {
      // Not in timing mode, nothing else to do here
      return
    }

    try {
      this.#writeFile(metadata)
      log.info('timing', `Timing info written to: ${this.#file}`)
    } catch (e) {
      log.warn('timing', `could not write timing file: ${e}`)
    }
  }

  #writeFile (metadata) {
    const globalStart = this.started
    const globalEnd = this.#finished[INITIAL_TIMER]
    const content = {
      metadata,
      timers: this.#finished,
      // add any unfinished timers with their relative start/end
      unfinishedTimers: [...this.#unfinished.entries()].reduce((acc, [name, start]) => {
        acc[name] = [start - globalStart, globalEnd - globalStart]
        return acc
      }, {}),
    }
    fs.writeFileSync(this.#file, JSON.stringify(content) + '\n')
  }

  #timeHandler = (level, name) => {
    const now = Date.now()
    switch (level) {
      case time.KEYS.start:
        this.#unfinished.set(name, now)
        break
      case time.KEYS.end: {
        if (this.#unfinished.has(name)) {
          const ms = now - this.#unfinished.get(name)
          this.#finished[name] = ms
          this.#unfinished.delete(name)
          log.timing(name, `Completed in ${ms}ms`)
        } else {
          log.silly('timing', `Tried to end timer that doesn't exist: ${name}`)
        }
      }
    }
  }
}

module.exports = Timers

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
16 Mar 2026 5.04 PM
root / root
0755
audit-error.js
1.021 KB
17 Jan 2026 1.16 AM
root / root
0644
auth.js
3.214 KB
17 Jan 2026 1.16 AM
root / root
0644
cmd-list.js
2.89 KB
17 Jan 2026 1.16 AM
root / root
0644
completion.fish
1.559 KB
17 Jan 2026 1.16 AM
root / root
0644
completion.sh
1.854 KB
17 Jan 2026 1.16 AM
root / root
0755
did-you-mean.js
1.16 KB
17 Jan 2026 1.16 AM
root / root
0644
display.js
15.38 KB
17 Jan 2026 1.16 AM
root / root
0644
error-message.js
14.795 KB
17 Jan 2026 1.16 AM
root / root
0644
explain-dep.js
3.03 KB
17 Jan 2026 1.16 AM
root / root
0644
explain-eresolve.js
2.556 KB
17 Jan 2026 1.16 AM
root / root
0644
format-bytes.js
0.614 KB
17 Jan 2026 1.16 AM
root / root
0644
format-search-stream.js
4.695 KB
17 Jan 2026 1.16 AM
root / root
0644
format.js
1.911 KB
17 Jan 2026 1.16 AM
root / root
0644
get-identity.js
0.783 KB
17 Jan 2026 1.16 AM
root / root
0644
get-workspaces.js
1.707 KB
17 Jan 2026 1.16 AM
root / root
0644
installed-deep.js
1.103 KB
17 Jan 2026 1.16 AM
root / root
0644
installed-shallow.js
0.569 KB
17 Jan 2026 1.16 AM
root / root
0644
is-windows.js
0.173 KB
17 Jan 2026 1.16 AM
root / root
0644
log-file.js
7.784 KB
17 Jan 2026 1.16 AM
root / root
0644
npm-usage.js
2.016 KB
17 Jan 2026 1.16 AM
root / root
0644
open-url.js
2.357 KB
17 Jan 2026 1.16 AM
root / root
0644
output-error.js
0.749 KB
17 Jan 2026 1.16 AM
root / root
0644
ping.js
0.256 KB
17 Jan 2026 1.16 AM
root / root
0644
queryable.js
9.556 KB
17 Jan 2026 1.16 AM
root / root
0644
read-user-info.js
1.91 KB
17 Jan 2026 1.16 AM
root / root
0644
reify-finish.js
0.865 KB
17 Jan 2026 1.16 AM
root / root
0644
reify-output.js
5.652 KB
17 Jan 2026 1.16 AM
root / root
0644
sbom-cyclonedx.js
5.206 KB
17 Jan 2026 1.16 AM
root / root
0644
sbom-spdx.js
4.586 KB
17 Jan 2026 1.16 AM
root / root
0644
tar.js
3.469 KB
17 Jan 2026 1.16 AM
root / root
0644
timers.js
2.07 KB
17 Jan 2026 1.16 AM
root / root
0644
update-workspaces.js
0.989 KB
17 Jan 2026 1.16 AM
root / root
0644
validate-lockfile.js
0.999 KB
17 Jan 2026 1.16 AM
root / root
0644
verify-signatures.js
11.939 KB
17 Jan 2026 1.16 AM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF