using afIoc::Injectusing afIoc::Registryusing afIoc::ThreadStashusing afIoc::ThreadStashManagerusing web::Cookieusing web::WebRequsing web::WebRes** An injectable 'const' version of [WebRes]`web::WebRes`.** ** This is proxied and will always refers to the current web response.constmixin HttpResponse {** Get / set the HTTP status code for this response.** Setter throws Err if response is already committed.** ** @see `web::WebRes.statusCode`abstract Int statusCode** Map of HTTP response headers. You must set all headers before you access out() for the ** first time, which commits the response. Throws Err if response is already committed. ** ** @see ** - `web::WebRes.headers`** - `http://en.wikipedia.org/wiki/List_of_HTTP_header_fields#Responses`abstract HttpResponseHeaders headers()** Get the list of cookies to set via header fields. ** Add a Cookie to this list to set a cookie. ** Throws Err if response is already committed.**** Example:** res.cookies.add(Cookie("foo", "123"))** res.cookies.add(Cookie("persistent", "some val") { maxAge = 3day })** ** @see `web::WebRes.cookies`abstract Cookie[] cookies()** Return true if this response has been commmited. A committed response has written its ** response headers, and can no longer modify its status code or headers. A response is ** committed the first time that `out` is called.** ** @see `web::WebRes.isCommitted`abstract Bool isCommitted()** Returns the 'OutStream' for this response. ** Should current settings allow, the 'OutStream' is automatically gzipped.** ** @see `web::WebRes.out`abstract OutStream out()** Set to 'true' to disable gzip compression for this response.** ** @see `GzipOutStream`abstract Bool disableGzip** Set to 'true' to disable buffering for this response.** ** @see `BufferedOutStream`abstract Bool disableBuffering** Directs the client to display a 'save as' dialog. ** Sets the 'Content-Disposition' http response header. ** ** Don't forget to set the 'Content-Type' header too!** ** @see `HttpResponseHeaders.contentDisposition`abstract Void saveAsAttachment(Str fileName)}** Wraps a given `HttpResponse`, delegating all its methods. ** You may find it handy to use when contributing to the 'HttpResponse' delegate chain.@NoDocconstclass HttpResponseWrapper : HttpResponse {const HttpResponse resnew make(HttpResponse res){this.res = res }override HttpResponseHeaders headers(){ res.headers }override Cookie[] cookies(){ res.cookies }override Bool isCommitted(){ res.isCommitted }override OutStream out(){ res.out }override Void saveAsAttachment(Str fileName){ res.saveAsAttachment(fileName)}override Bool disableGzip { get { res.disableGzip } set { res.disableGzip = it}}override Bool disableBuffering { get { res.disableBuffering } set { res.disableBuffering = it}}override Int statusCode { get { res.statusCode } set { res.statusCode = it}}}internalconstclass HttpResponseImpl : HttpResponse { @Inject privateconst Registry registryprivateconst ThreadStash threadStashnew make(ThreadStashManager threadStashManager, |This|in){ in(this) threadStash = threadStashManager.createStash("HttpResponse")}override Bool disableGzip { get { threadStash["disableGzip"] ?: false} set { threadStash["disableGzip"] = it}}override Bool disableBuffering { get { threadStash["disableBuffering"] ?: false} set { threadStash["disableBuffering"] = it}}override Int statusCode { get { webRes.statusCode } set { webRes.statusCode = it}}override HttpResponseHeaders headers(){ threadStash.get("headers") |->Obj| { HttpResponseHeaders(webRes.headers)}}override Cookie[] cookies(){ webRes.cookies}override Bool isCommitted(){ webRes.isCommitted}override OutStream out(){ registry.serviceById("HttpOutStream")}override Void saveAsAttachment(Str fileName){ headers.contentDisposition = "Attachment; filename=${fileName}"}private WebRes webRes(){ registry.dependencyByType(WebRes#)}}