{"id":17037559,"url":"https://github.com/seyfer/zendpsrlogger","last_synced_at":"2025-07-11T15:18:02.712Z","repository":{"id":17984818,"uuid":"20991290","full_name":"seyfer/ZendPsrLogger","owner":"seyfer","description":"This is module that implement PSR-3 log interface with Zend\\log component. Also implement Doctrine log writer.","archived":false,"fork":false,"pushed_at":"2019-06-16T19:17:48.000Z","size":91,"stargazers_count":6,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-04-12T13:45:20.716Z","etag":null,"topics":["doctrine-log-writer","entity","php","zend-framework2","zend-framework3"],"latest_commit_sha":null,"homepage":"https://packagist.org/packages/seyfer/zend-psr-logger","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/seyfer.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2014-06-19T07:10:51.000Z","updated_at":"2025-01-24T03:36:19.000Z","dependencies_parsed_at":"2022-09-12T07:21:30.943Z","dependency_job_id":null,"html_url":"https://github.com/seyfer/ZendPsrLogger","commit_stats":null,"previous_names":[],"tags_count":6,"template":false,"template_full_name":null,"purl":"pkg:github/seyfer/ZendPsrLogger","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seyfer%2FZendPsrLogger","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seyfer%2FZendPsrLogger/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seyfer%2FZendPsrLogger/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seyfer%2FZendPsrLogger/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/seyfer","download_url":"https://codeload.github.com/seyfer/ZendPsrLogger/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/seyfer%2FZendPsrLogger/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":264837995,"owners_count":23671134,"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","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":["doctrine-log-writer","entity","php","zend-framework2","zend-framework3"],"created_at":"2024-10-14T08:54:20.067Z","updated_at":"2025-07-11T15:18:02.680Z","avatar_url":"https://github.com/seyfer.png","language":"PHP","readme":"ZendPsrLogger\n=============\n\nThis is module that implement PSR-3 log interface with Zend\\log component.\nAlso implement Doctrine log writer.\n\nInstallation\n------------\n\nGet from packagist or github.\n\n`require \"seyfer/zend-psr-logger\": \"dev-master\"`\n\nhttp://modules.zendframework.com/seyfer/ZendPsrLogger\n\nIf using Zend2, than enable in application.config.php,\nadd 'ZendPsrLogger' to modules.\n\nConfiguration\n-------------\n\nExtra column mapping and Entity name in module.config.php.\nExtra column `ipaddress` for example.\n\n```\n'logger'        =\u003e array(\n        'registeredLoggers' =\u003e array(\n            'DefaultLogger' =\u003e array(\n                'entityClassName' =\u003e '\\ZendPsrLogger\\Entity\\DefaultLog',\n                'columnMap'       =\u003e array(\n                    'timestamp'    =\u003e 'timestamp',\n                    'priority'     =\u003e 'priority',\n                    'priorityName' =\u003e 'priorityName',\n                    'message'      =\u003e 'message',\n                    'extra'        =\u003e array(\n                        'ipaddress' =\u003e 'ipaddress',\n                    ),\n                )\n            ),\n            'ElseDefaultLogger' =\u003e array(\n                'entityClassName' =\u003e '\\ZendPsrLogger\\Entity\\ElseDefaultLog',\n                'columnMap'       =\u003e array(\n                    'timestamp'    =\u003e 'timestamp',\n                    'priority'     =\u003e 'priority',\n                    'priorityName' =\u003e 'priorityName',\n                    'message'      =\u003e 'message',\n                    'extra'        =\u003e array(\n                        'fileName' =\u003e 'fileName',\n                    ),\n                )\n            )\n        ),\n    ),\n```\n\nThan set abstract factory with your module logger custom name in Module.php\n\n```\npublic function getServiceConfig()\n    {\n        return array(\n            'abstract_factories' =\u003e array(\n                'DefaultLogger' =\u003e '\\ZendPsrLogger\\Service\\AbstractLoggerFactory',\n                'ElseDefaultLogger' =\u003e '\\ZendPsrLogger\\Service\\AbstractLoggerFactory',\n            ),\n        );\n    }\n```\n\nFactory will use your module.config.php `logger` config.\nYou can implement your factory and using writers,\nthat implement Zend\\Log\\Writer\\AbstractWriter.\n\nTo implement your Doctrine log entity you can extend it from\n`Logger\\Entity\\BaseLog` and just add your extra column mapping.\n\n```\n\u003c?php\n\nnamespace MyModule\\Entity\\Log;\n\nuse Doctrine\\ORM\\Mapping as ORM;\nuse Logger\\Entity\\BaseLog;\n\n/**\n * @ORM\\Entity\n * @ORM\\Table(name=\"parser_log\")\n */\nclass MyModuleLog extends BaseLog\n{\n\n    /**\n     * @var string\n     * @ORM\\Column(type=\"string\", name=\"file_name\", nullable=true)\n     */\n    protected $fileName;\n\n}\n\n```\n\nAnd than register your logger in your Module and add config like in example.\n\n\nUsage\n-----\n\nFirst init logger\n\n```\nuse ZendPsrLogger\\LoggerInterface;\nuse ZendPsrLogger\\NullLogger;\n...\n\n/** @var type LoggerInterface */\n$this-\u003elogger\n...\n\nif ($this-\u003egetServiceLocator()-\u003ehas($myLoggerName)) {\n    $logger = $this-\u003egetServiceLocator()-\u003eget($myLoggerName);\n} else {\n    $logger = new NullLogger();\n}\n\n$this-\u003elogger = $logger;\n```\n\nThan use it's level function\n\n```\n$this-\u003elogger-\u003eaddExtra(['ipaddress' =\u003e '11.22.33.44']);\n$this-\u003elogger-\u003edebug(\"test\");\n```\n\nOr log directly using \\Psr\\Log\\LogLevel constants for level parameter.\n\n```\n$this-\u003elogger-\u003elog(\\Psr\\Log\\LogLevel::DEBUG, \"test\", ['ipaddress' =\u003e '11.22.33.44']);\n```\n\nLicense\n-------\n\nGPL. If you want implement more writers or other improvements - you're welcome!\n\nChange Log\n----------\n\nv1.1.0\n- use AbstractLoggerFactory and new config structure for multiple logger creation\n\nv1.0.1\n- implement Doctrine writer\n- use LoggerFactory for logger creation","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fseyfer%2Fzendpsrlogger","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fseyfer%2Fzendpsrlogger","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fseyfer%2Fzendpsrlogger/lists"}