{"id":20138470,"url":"https://github.com/thiagobarradas/nancy-serilog","last_synced_at":"2026-03-07T23:01:20.820Z","repository":{"id":33201072,"uuid":"149186313","full_name":"ThiagoBarradas/nancy-serilog","owner":"ThiagoBarradas","description":"Nancy Serilog component for help you log all request/response and exceptions.","archived":false,"fork":false,"pushed_at":"2022-12-08T01:27:54.000Z","size":57,"stargazers_count":2,"open_issues_count":2,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2024-08-31T19:21:25.195Z","etag":null,"topics":["csharp","dotnet","dotnet-core","dotnet-standard","log","logger","nancy","nancy-fx","nancyfx","serilog","web"],"latest_commit_sha":null,"homepage":"https://www.nuget.org/packages/Nancy.Serilog.Simple/","language":"C#","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ThiagoBarradas.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-09-17T20:49:20.000Z","updated_at":"2020-06-12T18:11:26.000Z","dependencies_parsed_at":"2023-01-14T23:53:20.386Z","dependency_job_id":null,"html_url":"https://github.com/ThiagoBarradas/nancy-serilog","commit_stats":null,"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ThiagoBarradas%2Fnancy-serilog","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ThiagoBarradas%2Fnancy-serilog/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ThiagoBarradas%2Fnancy-serilog/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ThiagoBarradas%2Fnancy-serilog/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ThiagoBarradas","download_url":"https://codeload.github.com/ThiagoBarradas/nancy-serilog/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":224529396,"owners_count":17326531,"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":["csharp","dotnet","dotnet-core","dotnet-standard","log","logger","nancy","nancy-fx","nancyfx","serilog","web"],"created_at":"2024-11-13T21:38:15.928Z","updated_at":"2026-03-07T23:01:20.757Z","avatar_url":"https://github.com/ThiagoBarradas.png","language":"C#","funding_links":[],"categories":[],"sub_categories":[],"readme":"[![Build Status](https://barradas.visualstudio.com/Contributions/_apis/build/status/ThiagoBarradas.nancy-serilog?branchName=master)](https://barradas.visualstudio.com/Contributions/_build/latest?definitionId=11\u0026branchName=master)\n[![NuGet Downloads](https://img.shields.io/nuget/dt/Nancy.Serilog.Simple.svg)](https://www.nuget.org/packages/Nancy.Serilog.Simple/)\n[![NuGet Version](https://img.shields.io/nuget/v/Nancy.Serilog.Simple.svg)](https://www.nuget.org/packages/Nancy.Serilog.Simple/)\n[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=ThiagoBarradas_nancy-serilog\u0026metric=alert_status)](https://sonarcloud.io/dashboard?id=ThiagoBarradas_nancy-serilog)\n[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=ThiagoBarradas_nancy-serilog\u0026metric=coverage)](https://sonarcloud.io/dashboard?id=ThiagoBarradas_nancy-serilog)\n\n# Nancy.Serilog.Simple\n\nSerilog logger for Nancy web applications. Handler request, response and exceptions.\n\n## Install via NuGet\n\n```\nPM\u003e Install-Package Nancy.Serilog.Simple\n```\n\n# Sample\n\nConfigure service in statup\n```c#\n// Startup.cs\n\npublic void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)\n{\n    loggerFactory.AddSerilog();\n}\n\n```\n\nResolve dependency and setup pipelines\n```c#\n// Bootstrapper.cs\n\nprotected override void ConfigureApplicationContainer(TinyIoCContainer container)\n{\n    var jsonSerializerSettings = new JsonSerializerSettings\n    {\n    \tContractResolver = new CamelCasePropertyNamesContractResolver()\n    };\n\n    container.Register\u003cJsonSerializerSettings\u003e(jsonSerializerSettings);\n    container.Register\u003cICommunicationLogger, CommunicationLogger\u003e().AsSingleton();\n    \n    base.ConfigureApplicationContainer(container);\n}\n\nprotected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)\n{\n\t// you must setup logger pipeline in application startup\n\tpipelines.AddLogPipelines(container); \n}\n\n```\n\nReady! That way all request/response will be sended to serilog.\n\nYou can custom information title / error title and Serilog Logger using NancySerilogConfiguration in constructor. By default, global serilog logger will be used.\n\nYou can disable logging on success using DisableSerilogExtension in your action:\n\n```c#\n\npublic object Home()\n{\n\tthis.DisableLogging();\n\t...\n}\n\n```\n\nAdditional Property\n\n```\ncontext.Items[\"NancySerilogAdditionalInfo\"] = new AdditionalInfo\n{\n    Data = new Dictionary\u003cstring, object\u003e\n    {\n        { \"SomeProperty\", \"HERE_SOMEPROPERTY\" }\n    }\n};\n```\n\n## Properties \n\n* `RequestBody`\n* `Method`\n* `Path`\n* `Host`\n* `Port`\n* `Url`\n* `QueryString`\n* `Query`\n* `RequestHeaders`\n* `Ip`\n* `IsSuccessful`\n* `StatusCode`\n* `StatusDescription`\n* `StatusCodeFamily`\n* `ProtocolVersion`\n* `ErrorException`\n* `ErrorMessage`\n* `ResponseContent`\n* `ContentType`\n* `ContentLength`\n* `ResponseHeaders`\n* `ElapsedMilliseconds`\n* `RequestKey`\n\nYou can use this propeties with serilog log context to build log messages. `HTTP {Method} {Path} {...}`.\n\n## Setup global max length for exception properties\n\nUse env var to change default value\n\n- `SERILOG_ERROR_MESSAGE_MAX_LENGTH` default value 256;\n- `SERILOG_ERROR_EXCEPTION_MAX_LENGTH` default value 1024;\n\n## How can I contribute?\n\nPlease, refer to [CONTRIBUTING](.github/CONTRIBUTING.md)\n\n## Found something strange or need a new feature?\n\nOpen a new Issue following our issue template [ISSUE_TEMPLATE](.github/ISSUE_TEMPLATE.md)\n\n## Changelog\n\nSee in [nuget version history](https://www.nuget.org/packages/Nancy.Serilog.Simple)\n\n## Did you like it? Please, make a donate :)\n\nif you liked this project, please make a contribution and help to keep this and other initiatives, send me some Satochis.\n\nBTC Wallet: `1G535x1rYdMo9CNdTGK3eG6XJddBHdaqfX`\n\n![1G535x1rYdMo9CNdTGK3eG6XJddBHdaqfX](https://i.imgur.com/mN7ueoE.png)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fthiagobarradas%2Fnancy-serilog","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fthiagobarradas%2Fnancy-serilog","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fthiagobarradas%2Fnancy-serilog/lists"}