Commit 6559413
authored
Serve _upload files with content-disposition: attachment (#6303)
* Serve _upload files with content-disposition: attachment
* All files served from the /_upload endpoint will now trigger download
* PDF files are exempt, but they will always be served with the content-type set
* If an application needs some other behavior, they are encouraged to mount
their own StaticFiles instance to handle it.
* remove stray breakpoint
* test_upload: assert that files are properly downloaded
* Do not add or replace Content-Type header
If the Content-Type is missing or not application/pdf, then we serve the file
with Content-Disposition: attachment.
Iterate through the headers in a way that avoids adding duplicate headers.1 parent 8fb2fb4 commit 6559413
File tree
5 files changed
+241
-41
lines changed- packages
- reflex-base/src/reflex_base/constants
- reflex-components-core/src/reflex_components_core/core
- reflex
- tests/integration
5 files changed
+241
-41
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
114 | 114 | | |
115 | 115 | | |
116 | 116 | | |
| 117 | + | |
117 | 118 | | |
118 | 119 | | |
119 | 120 | | |
| |||
Lines changed: 59 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
9 | | - | |
| 9 | + | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| 26 | + | |
| 27 | + | |
26 | 28 | | |
27 | 29 | | |
28 | 30 | | |
| |||
575 | 577 | | |
576 | 578 | | |
577 | 579 | | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
| 605 | + | |
| 606 | + | |
| 607 | + | |
| 608 | + | |
| 609 | + | |
| 610 | + | |
| 611 | + | |
| 612 | + | |
| 613 | + | |
| 614 | + | |
| 615 | + | |
| 616 | + | |
| 617 | + | |
| 618 | + | |
| 619 | + | |
| 620 | + | |
| 621 | + | |
| 622 | + | |
| 623 | + | |
| 624 | + | |
| 625 | + | |
| 626 | + | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
578 | 636 | | |
579 | 637 | | |
580 | 638 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
68 | 68 | | |
69 | 69 | | |
70 | 70 | | |
| 71 | + | |
71 | 72 | | |
72 | | - | |
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
| |||
714 | 714 | | |
715 | 715 | | |
716 | 716 | | |
717 | | - | |
| 717 | + | |
718 | 718 | | |
719 | 719 | | |
720 | 720 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
55 | 55 | | |
56 | 56 | | |
57 | 57 | | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
58 | 67 | | |
59 | 68 | | |
60 | 69 | | |
| |||
72 | 81 | | |
73 | 82 | | |
74 | 83 | | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
75 | 89 | | |
76 | 90 | | |
77 | 91 | | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
78 | 118 | | |
79 | | - | |
| 119 | + | |
80 | 120 | | |
81 | 121 | | |
82 | 122 | | |
83 | 123 | | |
| 124 | + | |
84 | 125 | | |
85 | 126 | | |
86 | 127 | | |
87 | 128 | | |
| 129 | + | |
| 130 | + | |
88 | 131 | | |
89 | 132 | | |
90 | 133 | | |
| |||
116 | 159 | | |
117 | 160 | | |
118 | 161 | | |
119 | | - | |
120 | | - | |
121 | | - | |
122 | | - | |
123 | | - | |
124 | | - | |
125 | | - | |
126 | | - | |
127 | | - | |
128 | | - | |
| 162 | + | |
129 | 163 | | |
130 | 164 | | |
131 | 165 | | |
132 | 166 | | |
133 | | - | |
| 167 | + | |
134 | 168 | | |
135 | 169 | | |
136 | 170 | | |
137 | 171 | | |
138 | | - | |
| 172 | + | |
139 | 173 | | |
140 | 174 | | |
141 | 175 | | |
142 | 176 | | |
143 | | - | |
| 177 | + | |
144 | 178 | | |
145 | 179 | | |
146 | 180 | | |
147 | 181 | | |
148 | | - | |
| 182 | + | |
149 | 183 | | |
150 | 184 | | |
151 | 185 | | |
152 | 186 | | |
153 | | - | |
| 187 | + | |
154 | 188 | | |
155 | 189 | | |
156 | 190 | | |
157 | 191 | | |
158 | | - | |
| 192 | + | |
159 | 193 | | |
160 | 194 | | |
161 | 195 | | |
162 | 196 | | |
163 | | - | |
164 | | - | |
165 | | - | |
166 | | - | |
167 | | - | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
0 commit comments