You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

437 lines
17 KiB

4 years ago
4 years ago
4 years ago
5 years ago
6 years ago
6 years ago
6 years ago
  1. # Changelog
  2. All notable changes to this project will be documented in this file.
  3. ## v1.25.0 - Unreleased
  4. ### Improvements
  5. - Implement Pushover emergency alert cancellation when check goes up
  6. ## v1.24.1 - 2021-11-10
  7. ### Bug Fixes
  8. - Fix Dockerfile for arm/v7 - install all dependencies from piwheels
  9. ## v1.24.0 - 2021-11-10
  10. ### Improvements
  11. - Switch from croniter to cronsim
  12. - Change outgoing webhook timeout to 10s, but cap the total time to 20s
  13. - Implement automatic `api_ping` and `api_notification` pruning (#556)
  14. - Update Dockerfile to install apprise (#581)
  15. - Improve period and grace controls, allow up to 365 day periods (#281)
  16. - Add SIGTERM handling in sendalerts and sendreports
  17. - Remove the "welcome" landing page, direct users to the sign in form instead
  18. ### Bug Fixes
  19. - Fix hc.api.views.ping to handle non-utf8 data in request body (#574)
  20. - Fix a crash when hc.api.views.pause receives a single integer in request body
  21. ## v1.23.1 - 2021-10-13
  22. ### Bug Fixes
  23. - Fix missing uwsgi dependencies in arm/v7 Docker image
  24. ## v1.23.0 - 2021-10-13
  25. ### Improvements
  26. - Add /api/v1/badges/ endpoint (#552)
  27. - Add ability to edit existing email, Signal, SMS, WhatsApp integrations
  28. - Add new ping URL format: /{ping_key}/{slug} (#491)
  29. - Reduce Docker image size by using slim base image and multi-stage Dockerfile
  30. - Upgrade to Bootstrap 3.4.1
  31. - Upgrade to jQuery 3.6.0
  32. ### Bug Fixes
  33. - Add handling for non-latin-1 characters in webhook headers
  34. - Fix dark mode bug in selectpicker widgets
  35. - Fix a crash during login when user's profile does not exist (#77)
  36. - Drop API support for GET, DELETE requests with a request body
  37. - Add missing @csrf_exempt annotations in API views
  38. - Fix the ping handler to reject status codes > 255
  39. - Add 'schemaVersion' field in the shields.io endpoint (#566)
  40. ## v1.22.0 - 2021-08-06
  41. ### Improvements
  42. - Use multicolor channel icons for better appearance in the dark mode
  43. - Add SITE_LOGO_URL setting (#323)
  44. - Add admin action to log in as any user
  45. - Add a "Manager" role (#484)
  46. - Add support for 2FA using TOTP (#354)
  47. - Add Whitenoise (#548)
  48. ### Bug Fixes
  49. - Fix dark mode styling issues in Cron Syntax Cheatsheet
  50. - Fix a 403 when transferring a project to a read-only team member
  51. - Security: fix allow_redirect function to reject absolute URLs
  52. ## v1.21.0 - 2021-07-02
  53. ### Improvements
  54. - Increase "Success / Failure Keywords" field lengths to 200
  55. - Django 3.2.4
  56. - Improve the handling of unknown email addresses in the Sign In form
  57. - Add support for "... is UP" SMS notifications
  58. - Add an option for weekly reports (in addition to monthly)
  59. - Implement PagerDuty Simple Install Flow, remove PD Connect
  60. - Implement dark mode
  61. ### Bug Fixes
  62. - Fix off-by-one-month error in monthly reports, downtime columns (#539)
  63. ## v1.20.0 - 2021-04-22
  64. ### Improvements
  65. - Django 3.2
  66. - Rename VictorOps -> Splunk On-Call
  67. - Implement email body decoding in the "Ping Details" dialog
  68. - Add a "Subject" field in the "Ping Details" dialog
  69. - Improve HTML email display in the "Ping Details" dialog
  70. - Add a link to check's details page in Slack notifications
  71. - Replace details_url with cloaked_url in email and chat notifications
  72. - In the "My Projects" page, show projects with failing checks first
  73. ### Bug Fixes
  74. - Fix downtime summary to handle months when the check didn't exist yet (#472)
  75. - Relax cron expression validation: accept all expressions that croniter accepts
  76. - Fix sendalerts to clear Profile.next_nag_date if all checks up
  77. - Fix the pause action to clear Profile.next_nag_date if all checks up
  78. - Fix the "Email Reports" screen to clear Profile.next_nag_date if all checks up
  79. - Fix the month boundary calculation in monthly reports (#497)
  80. ## v1.19.0 - 2021-02-03
  81. ### Improvements
  82. - Add tighter parameter checks in hc.front.views.serve_doc
  83. - Update OpsGenie instructions (#450)
  84. - Update the email notification template to include more check and last ping details
  85. - Improve the crontab snippet in the "Check Details" page (#465)
  86. - Add Signal integration (#428)
  87. - Change Zulip onboarding, ask for the zuliprc file (#202)
  88. - Add a section in Docs about running self-hosted instances
  89. - Add experimental Dockerfile and docker-compose.yml
  90. - Add rate limiting for Pushover notifications (6 notifications / user / minute)
  91. - Add support for disabling specific integration types (#471)
  92. ### Bug Fixes
  93. - Fix unwanted HTML escaping in SMS and WhatsApp notifications
  94. - Fix a crash when adding an integration for an empty Trello account
  95. - Change icon CSS class prefix to 'ic-' to work around Fanboy's filter list
  96. ## v1.18.0 - 2020-12-09
  97. ### Improvements
  98. - Add a tooltip to the 'confirmation link' label (#436)
  99. - Update API to allow specifying channels by names (#440)
  100. - When saving a phone number, remove any invisible unicode characers
  101. - Update the read-only dashboard's CSS for better mobile support (#442)
  102. - Reduce the number of SQL queries used in the "Get Checks" API call
  103. - Add support for script's exit status in ping URLs (#429)
  104. - Improve phone number sanitization: remove spaces and hyphens
  105. - Change the "Test Integration" behavior for webhooks: don't retry failed requests
  106. - Add retries to the the email sending logic
  107. - Require confirmation codes (sent to email) before sensitive actions
  108. - Implement WebAuthn two-factor authentication
  109. - Implement badge mode (up/down vs up/late/down) selector (#282)
  110. - Add Ping.exitstatus field, store client's reported exit status values (#455)
  111. - Implement header-based authentication (#457)
  112. - Add a "Lost password?" link with instructions in the Sign In page
  113. ### Bug Fixes
  114. - Fix db field overflow when copying a check with a long name
  115. ## v1.17.0 - 2020-10-14
  116. ### Improvements
  117. - Django 3.1
  118. - Handle status callbacks from Twilio, show delivery failures in Integrations
  119. - Removing unused /api/v1/notifications/{uuid}/bounce endpoint
  120. - Less verbose output in the `senddeletionnotices` command
  121. - Host a read-only dashboard (from github.com/healthchecks/dashboard/)
  122. - LINE Notify integration (#412)
  123. - Read-only team members
  124. - API support for setting the allowed HTTP methods for making ping requests
  125. ### Bug Fixes
  126. - Handle excessively long email addresses in the signup form
  127. - Handle excessively long email addresses in the team member invite form
  128. - Don't allow duplicate team memberships
  129. - When copying a check, copy all fields from the "Filtering Rules" dialog (#417)
  130. - Fix missing Resume button (#421)
  131. - When decoding inbound emails, decode encoded headers (#420)
  132. - Escape markdown in MS Teams notifications (#426)
  133. - Set the "title" and "summary" fields in MS Teams notifications (#435)
  134. ## v1.16.0 - 2020-08-04
  135. ### Improvements
  136. - Paused ping handling can be controlled via API (#376)
  137. - Add "Get a list of checks's logged pings" API call (#371)
  138. - The /api/v1/checks/ endpoint now accepts either UUID or `unique_key` (#370)
  139. - Added /api/v1/checks/uuid/flips/ endpoint (#349)
  140. - In the cron expression dialog, show a human-friendly version of the expression
  141. - Indicate a started check with a progress spinner under status icon (#338)
  142. - Added "Docs > Reliability Tips" page
  143. - Spike.sh integration (#402)
  144. - Updated Discord integration to use discord.com instead of discordapp.com
  145. - Add "Failure Keyword" filtering for inbound emails (#396)
  146. - Add support for multiple, comma-separated keywords (#396)
  147. - New integration: phone calls (#403)
  148. ### Bug Fixes
  149. - Removing Pager Team integration, project appears to be discontinued
  150. - Sending a test notification updates Channel.last_error (#391)
  151. - Handle HTTP 429 responses from Matrix server when joining a Matrix room
  152. ## v1.15.0 - 2020-06-04
  153. ### Improvements
  154. - Rate limiting for Telegram notifications (10 notifications per chat per minute)
  155. - Use Slack V2 OAuth flow
  156. - Users can edit their existing webhook integrations (#176)
  157. - Add a "Transfer Ownership" feature in Project Settings
  158. - In checks list, the pause button asks for confirmation (#356)
  159. - Added /api/v1/metrics/ endpoint, useful for monitoring the service itself
  160. - Added "When paused, ignore pings" option in the Filtering Rules dialog (#369)
  161. ### Bug Fixes
  162. - "Get a single check" API call now supports read-only API keys (#346)
  163. - Don't escape HTML in the subject line of notification emails
  164. - Don't let users clone checks if the account is at check limit
  165. ## v1.14.0 - 2020-03-23
  166. ### Improvements
  167. - Improved UI to invite users from account's other projects (#258)
  168. - Experimental Prometheus metrics endpoint (#300)
  169. - Don't store user's current project in DB, put it explicitly in page URLs (#336)
  170. - API reference in Markdown
  171. - Use Selectize.js for entering tags (#324)
  172. - Zulip integration (#202)
  173. - OpsGenie integration returns more detailed error messages
  174. - Telegram integration returns more detailed error messages
  175. - Added the "Get a single check" API call (#337)
  176. - Display project name in Slack notifications (#342)
  177. ### Bug Fixes
  178. - The "render_docs" command checks if markdown and pygments is installed (#329)
  179. - The team size limit is applied to the n. of distinct users across all projects (#332)
  180. - API: don't let SuspiciousOperation bubble up when validating channel ids
  181. - API security: check channel ownership when setting check's channels
  182. - API: update check's "alert_after" field when changing schedule
  183. - API: validate channel identifiers before creating/updating a check (#335)
  184. - Fix redirect after login when adding Telegram integration
  185. ## v1.13.0 - 2020-02-13
  186. ### Improvements
  187. - Show a red "!" in project's top navigation if any integration is not working
  188. - createsuperuser management command requires an unique email address (#318)
  189. - For superusers, show "Site Administration" in top navigation, note in README (#317)
  190. - Make Ping.body size limit configurable (#301)
  191. - Show sub-second durations with higher precision, 2 digits after decimal point (#321)
  192. - Replace the gear icon with three horizontal dots icon (#322)
  193. - Add a Pause button in the checks list (#312)
  194. - Documentation in Markdown
  195. - Added an example of capturing and submitting log output (#315)
  196. - The sendalerts commands measures dwell time and reports it over statsd protocol
  197. - Django 3.0.3
  198. - Show a warning in top navigation if the project has no integrations (#327)
  199. ### Bug Fixes
  200. - Increase the allowable length of Matrix room alias to 100 (#320)
  201. - Make sure Check.last_ping and Ping.created timestamps match exactly
  202. - Don't trigger "down" notifications when changing schedule interactively in web UI
  203. - Fix sendalerts crash loop when encountering a bad cron schedule
  204. - Stricter cron validation, reject schedules like "At midnight of February 31"
  205. - In hc.front.views.ping_details, if a ping does not exist, return a friendly message
  206. ## v1.12.0 - 2020-01-02
  207. ### Improvements
  208. - Django 3.0
  209. - "Filtering Rules" dialog, an option to require HTTP POST (#297)
  210. - Show Healthchecks version in Django admin header (#306)
  211. - Added JSON endpoint for Shields.io (#304)
  212. - `senddeletionnotices` command skips profiles with recent last_active_date
  213. - The "Update Check" API call can update check's description (#311)
  214. ### Bug Fixes
  215. - Don't set CSRF cookie on first visit. Signup is exempt from CSRF protection
  216. - Fix List-Unsubscribe email header value: add angle brackets
  217. - Unsubscribe links serve a form, and require HTTP POST to actually unsubscribe
  218. - For webhook integration, validate each header line separately
  219. - Fix "Send Test Notification" for webhooks that only fire on checks going up
  220. - Don't allow adding webhook integrations with both URLs blank
  221. - Don't allow adding email integrations with both "up" and "down" unchecked
  222. ## v1.11.0 - 2019-11-22
  223. ### Improvements
  224. - In monthly reports, no downtime stats for the current month (month has just started)
  225. - Add Microsoft Teams integration (#135)
  226. - Add Profile.last_active_date field for more accurate inactive user detection
  227. - Add "Shell Commands" integration (#302)
  228. - PagerDuty integration works with or without PD_VENDOR_KEY (#303)
  229. ### Bug Fixes
  230. - On mobile, "My Checks" page, always show the gear (Details) button (#286)
  231. - Make log events fit better on mobile screens
  232. ## v1.10.0 - 2019-10-21
  233. ### Improvements
  234. - Add the "Last Duration" field in the "My Checks" page (#257)
  235. - Add "last_duration" attribute to the Check API resource (#257)
  236. - Upgrade to psycopg2 2.8.3
  237. - Add Go usage example
  238. - Send monthly reports on 1st of every month, not randomly during the month
  239. - Signup form sets the "auto-login" cookie to avoid an extra click during first login
  240. - Autofocus the email field in the signup form, and submit on enter key
  241. - Add support for OpsGenie EU region (#294)
  242. - Update OpsGenie logo and setup illustrations
  243. - Add a "Create a Copy" function for cloning checks (#288)
  244. - Send email notification when monthly SMS sending limit is reached (#292)
  245. ### Bug Fixes
  246. - Prevent double-clicking the submit button in signup form
  247. - Upgrade to Django 2.2.6 – fixes sqlite migrations (#284)
  248. ## v1.9.0 - 2019-09-03
  249. ### Improvements
  250. - Show the number of downtimes and total downtime minutes in monthly reports (#104)
  251. - Show the number of downtimes and total downtime minutes in "Check Details" page
  252. - Add the `pruneflips` management command
  253. - Add Mattermost integration (#276)
  254. - Three choices in timezone switcher (UTC / check's timezone / browser's timezone) (#278)
  255. - After adding a new check redirect to the "Check Details" page
  256. ### Bug Fixes
  257. - Fix javascript code to construct correct URLs when running from a subdirectory (#273)
  258. - Don't show the "Sign Up" link in the login page if registration is closed (#280)
  259. ## v1.8.0 - 2019-07-08
  260. ### Improvements
  261. - Add the `prunetokenbucket` management command
  262. - Show check counts in JSON "badges" (#251)
  263. - Webhooks support HTTP PUT (#249)
  264. - Webhooks can use different req. bodies and headers for "up" and "down" events (#249)
  265. - Show check's code instead of full URL on 992px - 1200px wide screens (#253)
  266. - Add WhatsApp integration (uses Twilio same as the SMS integration)
  267. - Webhooks support the $TAGS placeholder
  268. - Don't include ping URLs in API responses when the read-only key is used
  269. ### Bug Fixes
  270. - Fix badges for tags containing special characters (#240, #237)
  271. - Fix the "Integrations" page for when the user has no active project
  272. - Prevent email clients from opening the one-time login links (#255)
  273. - Fix `prunepings` and `prunepingsslow`, they got broken when adding Projects (#264)
  274. ## v1.7.0 - 2019-05-02
  275. ### Improvements
  276. - Add the EMAIL_USE_VERIFICATION configuration setting (#232)
  277. - Show "Badges" and "Settings" in top navigation (#234)
  278. - Upgrade to Django 2.2
  279. - Can configure the email integration to only report the "down" events (#231)
  280. - Add "Test!" function in the Integrations page (#207)
  281. - Rate limiting for the log in attempts
  282. - Password strength meter and length check in the "Set Password" form
  283. - Show the Description section even if the description is missing. (#246)
  284. - Include the description in email alerts. (#247)
  285. ## v1.6.0 - 2019-04-01
  286. ### Improvements
  287. - Add the "desc" field (check's description) to API responses
  288. - Add maxlength attribute to HTML input=text elements
  289. - Improved logic for displaying job execution times in log (#219)
  290. - Add Matrix integration
  291. - Add Pager Team integration
  292. - Add a management command for sending inactive account notifications
  293. ### Bug Fixes
  294. - Fix refreshing of the checks page filtered by tags (#221)
  295. - Escape asterisks in Slack messages (#223)
  296. - Fix a "invalid time format" in front.views.status_single on Windows hosts
  297. ## v1.5.0 - 2019-02-04
  298. ### Improvements
  299. - Database schema: add uniqueness constraint to Check.code
  300. - Database schema: add Ping.kind field. Remove "start" and "fail" fields
  301. - Add "Email Settings..." dialog and "Subject Must Contain" setting
  302. - Database schema: add the Project model
  303. - Move project-specific settings to a new "Project Settings" page
  304. - Add a "Transfer to Another Project..." dialog
  305. - Add the "My Projects" page
  306. ## v1.4.0 - 2018-12-25
  307. ### Improvements
  308. - Set Pushover alert priorities for "down" and "up" events separately
  309. - Additional python usage examples
  310. - Allow simultaneous access to checks from different teams
  311. - Add CORS support to API endpoints
  312. - Flip model, for tracking status changes of the Check objects
  313. - Add `/ping/<code>/start` API endpoint
  314. - When using the `/start` endpoint, show elapsed times in ping log
  315. ### Bug Fixes
  316. - Fix after-login redirects (the "?next=" query parameter)
  317. - Update Check.status field when user edits timeout & grace settings
  318. - Use timezone-aware datetimes with croniter, avoid ambiguities around DST
  319. - Validate and reject cron schedules with six components
  320. ## v1.3.0 - 2018-11-21
  321. ### Improvements
  322. - Load settings from environment variables
  323. - Add "List-Unsubscribe" header to alert and report emails
  324. - Don't send monthly reports to inactive accounts (no pings in 6 months)
  325. - Add search box in the "My Checks" page
  326. - Add read-only API key support
  327. - Remove Profile.bill_to field (obsolete)
  328. - Show a warning when running with DEBUG=True
  329. - Add "channels" attribute to the Check API resource
  330. - Can specify channel codes when updating a check via API
  331. - Add a workaround for email agents automatically opening "Unsubscribe" links
  332. - Add Channel.name field, users can now name integrations
  333. - Add "Get a List of Existing Integrations" API call
  334. ### Bug Fixes
  335. - During DST transition, handle ambiguous dates as pre-transition
  336. ## v1.2.0 - 2018-10-20
  337. ### Improvements
  338. - Content updates in the "Welcome" page.
  339. - Added "Docs > Third-Party Resources" page.
  340. - Improved layout and styling in "Login" page.
  341. - Separate "Sign Up" and "Log In" forms.
  342. - "My Checks" page: support filtering checks by query string parameters.
  343. - Added Trello integration
  344. ### Bug Fixes
  345. - Timezones were missing in the "Change Schedule" dialog, fixed.
  346. - Fix hamburger menu button in "Login" page.
  347. ## v1.1.0 - 2018-08-20
  348. ### Improvements
  349. - A new "Check Details" page.
  350. - Updated django-compressor, psycopg2, pytz, requests package versions.
  351. - C# usage example.
  352. - Checks have a "Description" field.