[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-7774":3},{"id":4,"name":5,"fullName":6,"owner":5,"repo":5,"description":7,"homepage":8,"htmlUrl":9,"language":10,"languages":9,"totalLinesOfCode":9,"stars":11,"forks":12,"watchers":13,"openIssues":14,"contributorsCount":15,"subscribersCount":15,"size":15,"stars1d":15,"stars7d":16,"stars30d":16,"stars90d":15,"forks30d":15,"starsTrendScore":16,"compositeScore":17,"rankGlobal":9,"rankLanguage":9,"license":18,"archived":19,"fork":19,"defaultBranch":20,"hasWiki":21,"hasPages":21,"topics":22,"createdAt":9,"pushedAt":9,"updatedAt":27,"readmeContent":28,"aiSummary":29,"trendingCount":15,"starSnapshotCount":15,"syncStatus":30,"lastSyncTime":31,"discoverSource":32},7774,"errbit","errbit\u002Ferrbit","The open source error catcher that's Airbrake API compliant :ukraine:","http:\u002F\u002Ferrbit.github.com\u002Ferrbit\u002F",null,"Ruby",4269,992,79,77,0,1,30.99,"MIT License",false,"main",true,[23,24,25,26],"airbrake","crash-reporting","error-monitoring","ruby","2026-06-12 02:01:44","# Errbit\n\n[![RSpec](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Factions\u002Fworkflows\u002Frspec.yml\u002Fbadge.svg)](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Factions\u002Fworkflows\u002Frspec.yml)\n[![Ruby Style Guide](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fcode_style-standard-brightgreen.svg)](https:\u002F\u002Fgithub.com\u002Fstandardrb\u002Fstandard)\n\n[![Deploy](https:\u002F\u002Fwww.herokucdn.com\u002Fdeploy\u002Fbutton.svg)](https:\u002F\u002Fheroku.com\u002Fdeploy?template=https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Ftree\u002Fmain)\n\n## The open source, self-hosted error catcher\n\nErrbit is a tool for collecting and managing errors from other applications.\nIt is [Airbrake](https:\u002F\u002Fwww.airbrake.io) API compliant, so you can just\npoint the `airbrake` gem to your Errbit server (see\n[howto](app\u002Fviews\u002Fapps\u002F_configuration_instructions.html.erb)).\n\n\u003Ctable>\n  \u003Ctr>\n    \u003Ctd align=\"center\">\n      \u003Ca href=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Fapps.png\" target=\"_blank\" title=\"Apps\">\n        \u003Cimg src=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Fapps_thumb.png\" alt=\"Apps\">\n      \u003C\u002Fa>\n      \u003Cbr>\n      \u003Cem>Apps\u003C\u002Fem>\n    \u003C\u002Ftd>\n    \u003Ctd align=\"center\">\n      \u003Ca href=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Fapp_errors.png\" target=\"_blank\" title=\"Errors\">\n        \u003Cimg src=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Fapp_errors_thumb.png\" alt=\"Errors\">\n      \u003C\u002Fa>\n      \u003Cbr>\n      \u003Cem>Errors\u003C\u002Fem>\n    \u003C\u002Ftd>\n    \u003Ctd align=\"center\">\n      \u003Ca href=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Ferror_summary.png\" target=\"_blank\" title=\"Error Summary\">\n        \u003Cimg src=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Ferror_summary_thumb.png\" alt=\"Error Summary\">\n      \u003C\u002Fa>\n      \u003Cbr>\n      \u003Cem>Error Summary\u003C\u002Fem>\n    \u003C\u002Ftd>\n    \u003Ctd align=\"center\">\n      \u003Ca href=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Ferror_backtrace.png\" target=\"_blank\" title=\"Error Backtraces\">\n        \u003Cimg src=\"https:\u002F\u002Ferrbit.com\u002Fimages\u002Ferror_backtrace_thumb.png\" alt=\"Error Backtraces\">\n      \u003C\u002Fa>\n      \u003Cbr>\n      \u003Cem>Error Backtraces\u003C\u002Fem>\n    \u003C\u002Ftd>\n  \u003C\u002Ftr>\n\u003C\u002Ftable>\n\n## Mailing List\n\nJoin the [Google Group](https:\u002F\u002Fgroups.google.com\u002Fgroup\u002Ferrbit) to receive\nupdates and notifications.\n\n## Requirements\n\nThe list of requirements to install Errbit are:\n\n* Ruby 4.0\n* MongoDB >= 7.0\n\n## Installation\n\n*Note*: This app is intended for people with experience deploying and maintaining\nRails applications.\n\n* [Install MongoDB](https:\u002F\u002Fwww.mongodb.org\u002Fdownloads)\n* `git clone https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit.git`\n* `bundle install`\n* `bundle exec rails errbit:bootstrap`\n* `bundle exec rails server`\n\n## Configuration\n\nErrbit configuration is done entirely through environment variables. See\n[configuration](docs\u002Fconfiguration.md)\n\n## Deployment\n\nSee [notes on deployment](docs\u002Fdeployment.md)\n\n## Notice Grouping\n\nThe way Errbit arranges notices into error groups is configurable. By default,\nErrbit uses the notice's error class, error message, complete backtrace,\ncomponent (or controller), action and environment name to generate a unique\nfingerprint for every notice. Notices with identical fingerprints appear in\nthe UI as different occurrences of the same error and notices with differing\nfingerprints are displayed as separate errors.\n\nChanging the fingerprinter (under the \"Config\" menu) applies to all apps and\nthe change affects only notices that arrive after the change. If you want to\nrefingerprint old notices, you can run\n`bundle exec rails errbit:notice_refingerprint`.\n\nSince version 0.7.0, the notice grouping can be separately configured for each\napp (under the \"edit\" menu).\n\n## Managing apps\n\nAn Errbit app is a place to collect error notifications from your external\napplication deployments.\n\nSee [apps](docs\u002Fapps.md)\n\n## Authentication\n\n### Configuring GitHub authentication\n\n* Set `GITHUB_AUTHENTICATION=true`\n* Register your instance of Errbit at https:\u002F\u002Fgithub.com\u002Fsettings\u002Fapplications\u002Fnew\n\nIf you host Errbit at `errbit.example.com`, you would fill in:\n\n\u003Cdl>\n  \u003Cdt>URL\u003C\u002Fdt>\n  \u003Cdd>https:\u002F\u002Ferrbit.example.com\u003C\u002Fdd>\n  \u003Cdt>Callback URL\u003C\u002Fdt>\n  \u003Cdd>https:\u002F\u002Ferrbit.example.com\u002Fusers\u002Fauth\u002Fgithub\u002Fcallback\u003C\u002Fdd>\n\u003C\u002Fdl>\n\n* After you have registered your app, set `GITHUB_CLIENT_ID` and `GITHUB_SECRET`\n  with your app's Client ID and Secret key.\n\nWhen you start your application, you should see the option to **Sign in with\nGitHub** on the Login page. You will also be able to link your GitHub profile\nto your user account on your **Edit profile** page.\n\nIf you have signed in with GitHub, or linked your GitHub profile, and you're\nworking with an App that has a GitHub repo configured, then you will be able to\ncreate issues on GitHub. If you use another issue tracker, see [Issue\nTrackers](#issue-trackers).\n\nYou can change the OAuth scope Errbit requests from GitHub by setting\n`GITHUB_ACCESS_SCOPE`. The default `['repo']` is very permissive, but there are a\nfew others that could make sense for your needs:\n\n\u003Cdl>\n  \u003Cdt>GITHUB_ACCESS_SCOPE=\"['repo']\"\u003C\u002Fdt>\n  \u003Cdd>Allow creating issues for public and private repos\u003C\u002Fdd>\n  \u003Cdt>GITHUB_ACCESS_SCOPE=\"['public_repo']\"\u003C\u002Fdt>\n  \u003Cdd>Allow creating issues for public repos only\u003C\u002Fdd>\n  \u003Cdt>GITHUB_ACCESS_SCOPE=\"[]\"\u003C\u002Fdt>\n  \u003Cdd>No permissions at all, but allows Errbit login through GitHub\u003C\u002Fdd>\n\u003C\u002Fdl>\n\n* `GITHUB_ORG_ID` is an optional environment variable you can set to your own\n  GitHub organization id. If set, only users of the specified GitHub\n  organization can log in to Errbit through GitHub. Errbit will provision\n  accounts for new users.\n\n### Configuring Google authentication\n\n* Set `GOOGLE_AUTHENTICATION=true`\n* Register your instance of Errbit at https:\u002F\u002Fconsole.developers.google.com\u002Fapis\u002Fapi\u002Fplus\u002Foverview\n\nIf you host Errbit at `errbit.example.com`, you would fill in:\n\n| Parameter    | Value                                                          |\n|--------------|----------------------------------------------------------------|\n| URL          | `https:\u002F\u002Ferrbit.example.com`                                   |\n| Callback URL | `https:\u002F\u002Ferrbit.example.com\u002Fusers\u002Fauth\u002Fgoogle_oauth2\u002Fcallback` |\n\n* After you have registered your app, set `GOOGLE_CLIENT_ID` and `GOOGLE_SECRET`\n  with your app's Client ID and Secret key.\n\nWhen you start your application, you should see the option to **Sign in with\nGoogle** on the Login page. You will also be able to link your Google profile\nto your user account on your **Edit profile** page.\n\n### Configuring LDAP authentication\n\n* Set `ERRBIT_USER_HAS_USERNAME=true`\n* Follow the [devise_ldap_authenticatable setup instructions](https:\u002F\u002Fgithub.com\u002Fcschiewek\u002Fdevise_ldap_authenticatable).\n* Set `config.ldap_create_user = true` in `config\u002Finitializers\u002Fdevise.rb`, this enables creating the users from LDAP, otherwise login will not work.\n* Create a new initializer (e.g. `config\u002Finitializers\u002Fdevise_ldap.rb`) and add the following code to enable ldap authentication in the User-model:\n\n```ruby\nErrbit::Config.devise_modules \u003C\u003C :ldap_authenticatable\n```\n\n* If you are authenticating by `username`, you will need to set the user's\n  email manually before authentication. You must add the following lines to\n  `app\u002Fmodels\u002Fuser.rb`:\n\n```ruby\ndef ldap_before_save\n  name = Devise::LDAP::Adapter.get_ldap_param(self.username, \"givenName\")\n  surname = Devise::LDAP::Adapter.get_ldap_param(self.username, \"sn\")\n  mail = Devise::LDAP::Adapter.get_ldap_param(self.username, \"mail\")\n\n  self.name = (name + surname).join(\" \")\n  self.email = mail.first\nend\n```\n\n* Now login with your user from LDAP, this will create a user in the database\n* Open a `bundle exec rails console` and set the admin flag for your user:\n\n```ruby\nuser = User.first\nuser.admin = true\nuser.save!\n```\n\n## Upgrading\n\nWhen upgrading Errbit, please run:\n\n```shell\ngit pull origin main # assuming origin is the github.com\u002Ferrbit\u002Ferrbit repo\nbundle install\nbundle exec rails db:migrate\nbundle exec rails db:mongoid:remove_undefined_indexes\nbundle exec rails db:mongoid:create_indexes\nbundle exec rails assets:precompile\n```\n\nThis will ensure that your application stays up to date with any schema changes.\n\nThere are additional steps if you are [upgrading from a version prior to v0.4.0](docs\u002Fupgrading.md).\n\n## User information in error reports\n\nErrbit can now display information about the user who experienced an error.\nThis gives you the ability to ask the user for more information,\nand let them know when you've fixed the bug.\n\nThe Airbrake gem will look for `current_user` or `current_member`. By default,\nit will only send the `id` of the user, to specify other attributes you can\nset `config.user_attributes`. See [the Airbrake wiki for more information](https:\u002F\u002Fgithub.com\u002Fairbrake\u002Fairbrake\u002Fwiki\u002FSending-current-user-information).\n\nIf user information is received with an error report,\nit will be displayed under the *User Details* tab:\n\n![User details tab](https:\u002F\u002Ferrbit.com\u002Fimages\u002Ferror_user_information.png)\n\nThis tab will be hidden if no user information is available.\n\n## Configuration\n\nhttps:\u002F\u002Fgithub.com\u002Fairbrake\u002Fairbrake\n\n## Javascript error notifications\n\nYou can log javascript errors that occur in your application by including the\n[airbrake-js](https:\u002F\u002Fgithub.com\u002Fairbrake\u002Fairbrake-js) javascript library.\n\nInstall airbrake-js according to the docs at and set your project and host as\nsoon as you want to start reporting errors. Then follow along with the\ndocumentation at https:\u002F\u002Fgithub.com\u002Fairbrake\u002Fairbrake-js\u002Fblob\u002Fmaster\u002FREADME.md\n\n```javascript\nvar airbrake = new airbrakeJs.Client({\n  projectId: 'ERRBIT API KEY',\n  projectKey: 'ERRBIT API KEY (again)',\n  reporter: 'xhr',\n  remoteConfig: false,\n  host: 'https:\u002F\u002Fmyerrbit.com'\n});\n```\n\n## Plugins and Integrations\n\nYou can extend Errbit by adding Ruby gems and plugins which are typically gems.\nIt's nice to keep track of which gems are core Errbit dependencies and which\ngems are your own dependencies. If you want to add gems to your own Errbit,\nplace them in a new file called `UserGemfile` and Errbit will treat that file\nas an additional Gemfile. If you want to use `errbit_jira_plugin`, just add it\nto `UserGemfile`:\n\n```shell\necho \"gem 'errbit_jira_plugin'\" > UserGemfile\nbundle install\n```\n\n## Issue Trackers\n\nEach issue tracker integration is implemented as a gem that depends on\n[errbit_plugin](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit_plugin). The only officially\nsupported issue tracker plugin is\n[errbit_github_plugin](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit_github_plugin).\n\nIf you want to implement your own issue tracker plugin, read the README.md file\nat [errbit_plugin](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit_plugin).\n\n## If Errbit has an error\n\nErrbit will log its own errors to an internal app named **Self.Errbit**.  The\n**Self.Errbit** app is automatically created when the first error happens.\n\nIf your Errbit instance has logged an error, we would appreciate a bug report\non GitHub Issues. You can post this manually at\n[https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Fissues](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Fissues),\nor you can set up the GitHub Issues tracker for your **Self.Errbit** app:\n\n* Go to the **Self.Errbit** app's edit page. If that app does not exist yet,\n  go to the apps page and click **Add a new App** to create it. (You can also\n  create it by running `bundle exec rails airbrake:test`.)\n* In the **Issue Tracker** section, click **GitHub Issues**.\n* Fill in the **Account\u002FRepository** field with **errbit\u002Ferrbit**.\n* Fill in the **Username** field with your GitHub username.\n* If you are logged in on [GitHub](https:\u002F\u002Fgithub.com), you can find your\n  **API Token** on this page:\n  [https:\u002F\u002Fgithub.com\u002Faccount\u002Fadmin](https:\u002F\u002Fgithub.com\u002Faccount\u002Fadmin).\n* Save the settings by clicking **Update App** (or **Add App**)\n* You can now easily post bug reports to GitHub Issues by clicking the\n  **Create Issue** button on a **Self.Errbit** error.\n\n## Getting Help\n\nIf you need help, try asking your question on StackOverflow using the\ntag errbit:\nhttps:\u002F\u002Fstackoverflow.com\u002Fquestions\u002Ftagged\u002Ferrbit\n\n## Use Errbit with applications written in other languages\n\nIn theory, any Airbrake-compatible error catcher for other languages should work with Errbit.\nSolutions known to work are listed below:\n\n| Language            | Project                                                             |\n|---------------------|---------------------------------------------------------------------|\n| PHP (&gt;= 5.3)     | [wasilak\u002Ferrbit-php](https:\u002F\u002Fgithub.com\u002Fwasilak\u002Ferrbit-php)         |\n| OOP PHP (&gt;= 5.3) | [emgiezet\u002FerrbitPHP](https:\u002F\u002Fgithub.com\u002Femgiezet\u002FerrbitPHP)         |\n| Python              | [mkorenkov\u002Ferrbit.py](https:\u002F\u002Fgithub.com\u002Fmkorenkov\u002Ferrbit.py)       |\n| Python              | [pulseenergy\u002Fairbrakepy](https:\u002F\u002Fgithub.com\u002Fpulseenergy\u002Fairbrakepy) |\n\n## People using Errbit\n\nSee our wiki page for a [list of people and companies around the world who use\nErrbit](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Fwiki\u002FPeople-using-Errbit). You may\n[edit this\npage](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Fwiki\u002FPeople-using-Errbit\u002F_edit), and add\nyour name and country to the list if you are using Errbit.\n\n## Special Thanks\n\n* [Michael Parenteau](http:\u002F\u002Fmichaelparenteau.com) - For rocking the Errbit design and providing a great user experience.\n* [Nick Recobra (@oruen)](https:\u002F\u002Fgithub.com\u002Foruen) - Nick is Errbit's first core contributor. He's been working hard at making Errbit more awesome.\n* [Nathan Broadbent (@ndbroadbent)](https:\u002F\u002Fgithub.com\u002Fndbroadbent) - Maintaining Errbit and contributing many features\n* [Vasiliy Ermolovich (@nashby)](https:\u002F\u002Fgithub.com\u002Fnashby) - Contributing and helping to resolve issues and pull requests\n* [Marcin Ciunelis (@martinciu)](https:\u002F\u002Fgithub.com\u002Fmartinciu) - Helping to improve Errbit's architecture\n* [Cyril Mougel (@shingara)](https:\u002F\u002Fgithub.com\u002Fshingara) - Maintaining Errbit and contributing many features\n* [Relevance](http:\u002F\u002Fthinkrelevance.com) - For giving me Open-source Fridays to work on Errbit and all my awesome co-workers for giving feedback and inspiration.\n* [Thoughtbot](https:\u002F\u002Fthoughtbot.com) - For being great open-source advocates and setting the bar with [Airbrake](https:\u002F\u002Fwww.airbrake.io).\n\nSee the [contributors graph](https:\u002F\u002Fgithub.com\u002Ferrbit\u002Ferrbit\u002Fgraphs\u002Fcontributors) for more details.\n\n## Contributing to Errbit\n\nSee the [contribution guidelines](CONTRIBUTING.md)\n\n## Running tests\n\nCheck the [.github\u002Fworkflows\u002Frspec.yml](.github\u002Fworkflows\u002Frspec.yml) file to see how tests are run\n\n## License\n\nErrbit is available as open source under the terms of the [MIT License](http:\u002F\u002Fopensource.org\u002Flicenses\u002FMIT).\n\n## Copyright\n\nCopyright &copy; 2010-2025 Errbit Team\n","Errbit 是一个开源的错误捕获工具，兼容Airbrake API，适用于收集和管理其他应用程序中的错误。它使用Ruby语言开发，具有强大的错误监控与报告功能，能够提供详细的错误摘要、回溯信息，并支持通过环境变量进行配置。此外，Errbit允许用户自定义错误分组规则，以更灵活地管理和查看错误。此项目适合需要自托管解决方案来追踪和解决软件错误的企业或个人开发者使用，在确保数据安全的同时提供了高度可定制化的错误处理机制。",2,"2026-06-11 03:14:18","top_language"]