{"id":23640930,"url":"https://github.com/gallolabs/logger","last_synced_at":"2025-09-05T01:41:35.324Z","repository":{"id":212983335,"uuid":"732755502","full_name":"gallolabs/logger","owner":"gallolabs","description":"Simple and powerfull javascript logger","archived":false,"fork":false,"pushed_at":"2025-07-21T13:22:09.000Z","size":355,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-07-21T15:27:30.788Z","etag":null,"topics":["javascript-library","logger"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/gallolabs.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2023-12-17T18:14:35.000Z","updated_at":"2025-07-21T13:22:13.000Z","dependencies_parsed_at":"2023-12-23T00:52:14.210Z","dependency_job_id":"817e71eb-0684-428d-9279-3521ab2db1c8","html_url":"https://github.com/gallolabs/logger","commit_stats":null,"previous_names":["gallolabs/logger"],"tags_count":4,"template":false,"template_full_name":null,"purl":"pkg:github/gallolabs/logger","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gallolabs%2Flogger","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gallolabs%2Flogger/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gallolabs%2Flogger/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gallolabs%2Flogger/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/gallolabs","download_url":"https://codeload.github.com/gallolabs/logger/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/gallolabs%2Flogger/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273699719,"owners_count":25152285,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-04T02:00:08.968Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["javascript-library","logger"],"created_at":"2024-12-28T09:53:22.987Z","updated_at":"2025-09-05T01:41:30.309Z","avatar_url":"https://github.com/gallolabs.png","language":"TypeScript","readme":"\u003cp align=\"center\"\u003e\n    \u003cimg height=\"200\" src=\"https://raw.githubusercontent.com/gallolabs/logger/main/logo_w200.jpeg\"\u003e\n  \u003cp align=\"center\"\u003e\u003cstrong\u003eGallo logger\u003c/strong\u003e\u003c/p\u003e\n\u003c/p\u003e\n\nSimple logger:\n- [x] log -\u003e processors -\u003e obfuscation -\u003e handlers (own processors + format + transport)\n- [x] Advanced childs (not only id and metadata but also own processors and handlers stack), siblings, and extends\n- [x] Default simple JSON console logging\n- [x] logfmt formatter available\n- [x] BreadCrumb handler (like Monolog Fingers crossed handler) : keep some verbose logs in memory until an error-like log is logged. Kept verbose logs are flushed with it. Verbose logs are kept on a logger chain (parent/child) to flush only (as possible) relevant logs.\n- [x] Error handler\n- [x] Idle wait method\n- [ ] Move filter (level) logic to logger ? Create intermediate handler ? Create a mapping filter\u003c-\u003ehandler with potentially advanced filters (on metadata etc) ?\n- [ ] Reduce complexity as remote-ee with only 1 root instance and others child instances, and change onError by events ?\n\n```typescript\n\nconst logger = createLogger({...})\n\n// loggerId can be any type\nconst child = logger.child({ component: 'http-server', alias: 'public-server' })\nconst child = logger.child('public-server', {child: true})\n\nchild.info('My log', {password: 'secret'})\n\n// Will log {level: 'info', message: 'My log', password: '***', child: true, timestamp: '(date)', logger: 'public-server'}\n\n```","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgallolabs%2Flogger","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgallolabs%2Flogger","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgallolabs%2Flogger/lists"}