Incident Report on Memory Leak Triggered
Jasmin Lothian edited this page 1 month ago


Final Friday, Tavis Ormandy from Google’s Venture Zero contacted Cloudflare to report a security problem with our edge servers. He was seeing corrupted internet pages being returned by some HTTP requests run via Cloudflare. It turned out that in some unusual circumstances, which I’ll element below, our edge servers have been working previous the end of a buffer and returning memory that contained private information reminiscent of HTTP cookies, authentication tokens, HTTP Submit bodies, and other sensitive information. And some of that knowledge had been cached by engines like google. For Memory Wave the avoidance of doubt, Cloudflare customer SSL private keys were not leaked. Cloudflare has at all times terminated SSL connections by way of an remoted occasion of NGINX that was not affected by this bug. We quickly recognized the problem and turned off three minor Cloudflare options (e-mail obfuscation, Server-aspect Excludes and Automated HTTPS Rewrites) that had been all utilizing the identical HTML parser chain that was causing the leakage. At that point it was no longer possible for memory to be returned in an HTTP response.


Because of the seriousness of such a bug, a cross-useful crew from software engineering, infosec and operations formed in San Francisco and London to totally understand the underlying trigger, Memory Wave to understand the impact of the memory leakage, and to work with Google and other serps to take away any cached HTTP responses. Having a world workforce meant that, at 12 hour intervals, work was handed over between places of work enabling workers to work on the problem 24 hours a day. The workforce has labored continuously to make sure that this bug and its penalties are fully dealt with. Considered one of some great benefits of being a service is that bugs can go from reported to fixed in minutes to hours as a substitute of months. The trade commonplace time allowed to deploy a fix for a bug like that is usually three months