The blog.
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.
 
 
 
 

119 lines
6.1 KiB

  1. ---
  2. title: "Crash Dumps: Do I submit them?"
  3. description: >
  4. TL;DR: No, they collect too much and aren't handled safely.
  5. created: !!timestamp '2018-10-23'
  6. time: 3:54 PM
  7. tags:
  8. - security
  9. ---
  10. TL;DR: No, do not submit your crash dumps. Consumers: No company has
  11. sane crash dump policies to ensure your privacy and PII is protected,
  12. minimized and secured. Companies: You need to ensure that crash dumps
  13. are handled in a secure manner and that crash dumps are just that: a
  14. crash dump. Anything not directly related to a crash dump should be
  15. excluded. Usage statistics and the like do not belong in crash reports.
  16. ## Why Not Send Dumps?
  17. There is a long history of companies failing to minimize the data and
  18. to protect it. Microsoft for years sent crash dumps over the internet
  19. in the clear
  20. ([WER & Privacy conerns](https://en.wikipedia.org/wiki/Windows_Error_Reporting#Privacy_concerns_and_use_by_the_NSA)).
  21. This allowed the NSA to harvest them, and develop 0-days for issues that
  22. MS failed to fix. Google's Chrome would send a screencap of the entire
  23. Desktop along with it's crash dumps
  24. ([link](https://twitter.com/vmjulix/status/857482886097715200)). It
  25. previously would only send the window, but now sends the entire screen.
  26. Though they provide a preview, there is no way to see exactly what
  27. information will be sent.
  28. I do not relish in advising people to not submit crash dumps as this
  29. will impact developers ability to fix bugs. But as with all aspects of
  30. security, companies continue to demonstrate that they are not willing
  31. to do the work that is necessary to protect user's data and their
  32. privacy.
  33. ## Communication
  34. You need to communicate to your users how crash dumps are handled. Just
  35. saying, trust us, does not inspire confidence, as there are a large
  36. number of cases of data breaches where the company has said exactly that
  37. leading up to leaks. The policy is the first step to demonstrating that
  38. you have thought about user's concerns and decided how you will handle
  39. their personal and sensitive data.
  40. The policy also helps shape how employees will treat the data too. By
  41. having the policy, it is a reiteration to the employees that user data
  42. isn't simply chaff, but that it needs to be protected and handled with
  43. care.
  44. Just saying that it's protected by a privacy policy isn't enough. For
  45. example, Google Chrome's Report an Issue says that the information is
  46. protected by their privacy policy, but if you read the Chrome browser
  47. Privacy Policy, there is nothing in there that says how the data is
  48. handled. That it is handled like the rest of the data collected does
  49. not inspire confidence that the possibly confidential data that may be
  50. included will be handled with greater care.
  51. ## How to handle dumps
  52. The first step is to ensure that what is collected in the dump has
  53. minimum information needed to debug issues. Code paths (back traces)
  54. are likely to be safe. Data, such as arguments to functions, may include
  55. user data and needs to be carefully examined. There are many different
  56. types of data that can be released from embarrassing (what website was
  57. visited), to security breach (including cookies/tokens for web sites
  58. that may not be yours), to confidential intellectual property leaking
  59. (source code, designs, etc). Each of these may have different impact on
  60. the user, but should never happen.
  61. Second, crash dumps need to be transmitted confidentially. This means
  62. either using TLS or encrypting the dumps with a tool like GPG before
  63. sending. This ensures that unauthorized parties are unable to view the
  64. contents. The NSA used the dumps to gather information for their
  65. operations, which if Microsoft had properly protected their user's data,
  66. this would not have happened.
  67. Third, they need to be stored in a secure manner and able to be
  68. expunged. It should even be possible for the user to remove the crash
  69. dump if they discover that information was shared when it should not have
  70. been. The life time that a company keeps the dumps should be limited.
  71. If you haven't fixed a bug from five years ago, how do you know you can
  72. reproduce it, or that if you are able to reproduce it, that the code is
  73. still present in your current software? It the crash is a major issue,
  74. it is likely that you'll have more recent dumps that exhibit the same
  75. issue if it is a problem, so old dumps are just not as useful compared
  76. to the data that may be present.
  77. As crash data needs to be deleted, almost any cloud service is immediately
  78. excluded unless other precautions are used, such as encryption. With
  79. the cloud, you have zero visibility into how the data is managed and how
  80. or when it is backed up. Cloud providers rarely tell you their retention
  81. policies on back ups, and other policies that may keep data around. Do
  82. they securely remove your VM's storage when they migrate it? Do they
  83. ensure that storage is deleted from all clones, shards, servers and
  84. backups when you delete it? If not, how long will that data stay around
  85. before it is finally expunged.
  86. Fourth, access to dumps need to be controlled. Auditing is a good first
  87. step to know who is accessing the data, but additional measures like
  88. limiting who has access needs to be used. Not everyone on the team needs
  89. access to them. As they are classified, they can be assigned to teams
  90. or people that need access to the data in them. This helps make sure
  91. that an employee isn't trolling for nudes or other confidential
  92. information. It should also limit how easy data is copied out of the
  93. archive. How these controls are put in place will vary by company.
  94. Edit: Case in point: I recently opened a support case with Apple.
  95. Apple provides a program to collect data to send to them to help trouble
  96. shoot the issue. The program collected 280 MB of data. When uploading
  97. the data, Apple informs the user that it is their responsibility to NOT
  98. submit any personal information that they don't want. There is no way
  99. most people are qualified to look at the data, and even redact it
  100. properly. I
  101. [attempted to do so](https://twitter.com/encthenet/status/1057445997373087744),
  102. and it took a very long time, and I'm not sure that I got everything.
  103. Expecting a normal computer user to be able to do this is insane.