| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| #ifndef PAGESPEED_APACHE_APACHE_WRITER_H_ |
| #define PAGESPEED_APACHE_APACHE_WRITER_H_ |
| |
| #include "pagespeed/kernel/base/basictypes.h" |
| #include "pagespeed/kernel/base/scoped_ptr.h" |
| #include "pagespeed/kernel/base/string_util.h" |
| #include "pagespeed/kernel/base/thread_system.h" |
| #include "pagespeed/kernel/base/writer.h" |
| |
| struct request_rec; |
| |
| namespace net_instaweb { |
| |
| class MessageHandler; |
| class ResponseHeaders; |
| |
| // Writer object that writes to an Apache Request stream. Should only be used |
| // from a single apache request thread, not from a rewrite thread or anything |
| // else. |
| class ApacheWriter : public Writer { |
| public: |
| ApacheWriter(request_rec* r, ThreadSystem* thread_system); |
| ~ApacheWriter() override; |
| |
| bool Write(const StringPiece& str, MessageHandler* handler) override; |
| bool Flush(MessageHandler* handler) override; |
| |
| // Copies the contents of the specified response_headers to the Apache |
| // headers_out structure. This must be done before any bytes are flushed. |
| // |
| // Note: if strip_cokies is set, the cookies will be stripped here. |
| // |
| // If set_content_length was previously called, this will set a |
| // content length to avoid chunked encoding, otherwise it will clear |
| // any content-length specified in the response headers. |
| void OutputHeaders(ResponseHeaders* response_headers); |
| void set_content_length(int64 x) { content_length_ = x; } |
| |
| // Disables mod_expires and mod_headers to allow the headers to |
| // be under control of mod_pagespeed. Default is false. |
| void set_disable_downstream_header_filters(bool x) { |
| disable_downstream_header_filters_ = x; |
| } |
| |
| // Removes 'Set-Cookie' and 'Set-Cookie2' from the response headers |
| // once they are complete. Default is false. |
| // TODO(jefftk): Doesn't actually do anything, because of an old bug. |
| void set_strip_cookies(bool x) { strip_cookies_ = x; } |
| |
| private: |
| request_rec* request_; |
| bool headers_out_; |
| bool disable_downstream_header_filters_; |
| bool strip_cookies_; |
| int64 content_length_; |
| ThreadSystem* thread_system_; |
| std::unique_ptr<ThreadSystem::ThreadId> apache_request_thread_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ApacheWriter); |
| }; |
| |
| } // namespace net_instaweb |
| |
| #endif // PAGESPEED_APACHE_APACHE_WRITER_H_ |