include/cripts/Bundles/Headers.hpp (79 lines of code) (raw):

/* 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. */ #pragma once // Bundle for common header operations // Bundle::Headers::activate().rm_headers("Client::Request", ["X-ATS-Request-ID", "X-ATS-Request-Start", "X-ATS-Request-End"]) // .set_headers("Client::Response", {{"X-Foo", "bar", {"X-Fie", "fum"}}); #include "cripts/Lulu.hpp" #include "cripts/Instance.hpp" #include "cripts/Bundle.hpp" namespace detail { class HRWBridge { using self_type = HRWBridge; public: HRWBridge() = delete; HRWBridge(const self_type &) = delete; void operator=(const self_type &) = delete; HRWBridge(const cripts::string_view &str) : _value(str) {} virtual ~HRWBridge() = default; virtual cripts::string_view value(cripts::Context * /* context ATS_UNUSED */) { return _value; } protected: cripts::string _value; }; // class HRWBridge // We support 4 different type of header operations, so isolate the common code class HeadersType { using self_type = HeadersType; public: using HeaderList = std::vector<cripts::string>; using HeaderValueList = std::vector<std::pair<const cripts::string, detail::HRWBridge *>>; HeadersType() = default; HeadersType(const self_type &) = delete; void operator=(const self_type &) = delete; ~HeadersType() { for (auto &header : set_headers) { delete header.second; } } HeaderList rm_headers; HeaderValueList set_headers; }; } // namespace detail namespace cripts::Bundle { class Headers : public cripts::Bundle::Base { using super_type = cripts::Bundle::Base; using self_type = Headers; public: using HeaderList = std::vector<cripts::string>; using HeaderValueList = std::vector<std::pair<const cripts::string, const cripts::string>>; using super_type::Base; // This is the factory to create an instance of this bundle static self_type & _activate(cripts::Instance &inst) { auto *entry = new self_type(); inst.AddBundle(entry); return *entry; } [[nodiscard]] const cripts::string & Name() const override { return _name; } static detail::HRWBridge *BridgeFactory(const cripts::string &source); self_type &rm_headers(const cripts::string_view target, const HeaderList &headers); self_type &set_headers(const cripts::string_view target, const HeaderValueList &headers); void doRemap(cripts::Context *context) override; void doSendResponse(cripts::Context *context) override; void doSendRequest(cripts::Context *context) override; void doReadResponse(cripts::Context *context) override; private: static const cripts::string _name; detail::HeadersType _client_request; detail::HeadersType _client_response; detail::HeadersType _server_request; detail::HeadersType _server_response; }; } // namespace cripts::Bundle