https://github.com/vtex/pino-splunk-events
  
  
     
    https://github.com/vtex/pino-splunk-events
  
        Last synced: 26 days ago 
        JSON representation
    
- Host: GitHub
- URL: https://github.com/vtex/pino-splunk-events
- Owner: vtex
- License: mit
- Created: 2021-05-20T15:37:10.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-07-19T02:36:12.000Z (over 2 years ago)
- Last Synced: 2025-09-23T03:39:12.093Z (about 1 month ago)
- Language: TypeScript
- Size: 2.63 MB
- Stars: 1
- Watchers: 13
- Forks: 4
- Open Issues: 16
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
 
Awesome Lists containing this project
README
          [](https://www.npmjs.com/package/pino-splunk-events)
[](https://conventionalcommits.org)

---
# pino-splunk-events
### Install
```bash
$ npm install pino-splunk-events
```
### Usage
```bash
$ node app.js | npx pino-splunk-events --endpoint=YOUR_SPLUNK_ENDPOINT --token=YOUR_SPLUNK_TOKEN
```
#### Node (development mode)
```ts
import { PrettyConsole } from 'pino-splunk-events/lib/core/PrettyConsole'
const logger = pino({
  prettyPrint: {
    messageFormat: PrettyConsole.messageFormat,
  },
})
```
#### Browser (production mode)
```ts
import { getPinoBrowserWriteLog } from 'pino-splunk-events/lib/browser'
import SplunkEvents from 'splunk-events'
import pino from 'pino'
const splunk = new SplunkEvents({
  endpoint: process.env.SPLUNK_ENDPOINT,
  token: process.env.SPLUNK_TOKEN,
  // IMPORTANT! You need to set this flag
  // to permit send nested data to splunk
  // otherwise it will fails when try to
  // send some log with nested data
  shouldParseEventData: false,
})
const logger = pino({
  browser: {
    write: getPinoBrowserWriteLog(splunk),
  },
})
```
#### Browser (development mode)
```ts
import { PrettyConsole } from 'pino-splunk-events/lib/core/PrettyConsole'
import pino from 'pino'
const logger = pino({
  browser: {
    write: PrettyConsole.print,
  },
})
```
### Table logs level to splunk
| Log Level | Splunk Query               |
| --------- | -------------------------- |
| trace     | level=Debug type=Info      |
| debug     | level=Debug type=Info      |
| info      | level=Important type=Info  |
| warn      | level=Important type=Warn  |
| error     | level=Important type=Error |
| fatal     | level=Critical type=Error  |
### Running example
```bash
# terminal 1
$ yarn install
$ cd example && yarn install
# starts fake splunk server
$ yarn server:start
# terminal 2
# sends events to fake splunk server
$ yarn logger:start
```
### Deploy / Release new tags
Use `npx chan added|fixed|etc "my change"`
And after setting a changelog, run:
```shell
yarn release
```
## License
Released under [MIT License](./LICENSE).