LCOV - code coverage report
Current view: top level - model - AdminServerProvisionData.hpp (source / functions) Coverage Total Hit
Test: final-coverage.info Lines: 100.0 % 3 3
Test Date: 2025-02-14 17:40:40 Functions: 100.0 % 2 2

            Line data    Source code
       1              : /*
       2              :  ___________________________________________
       3              : |    _     ___                        _     |
       4              : |   | |   |__ \                      | |    |
       5              : |   | |__    ) |__ _  __ _  ___ _ __ | |_   |
       6              : |   | '_ \  / // _` |/ _` |/ _ \ '_ \| __|  |  HTTP/2 AGENT FOR MOCK TESTING
       7              : |   | | | |/ /| (_| | (_| |  __/ | | | |_   |  Version 0.0.z
       8              : |   |_| |_|____\__,_|\__, |\___|_| |_|\__|  |  https://github.com/testillano/h2agent
       9              : |                     __/ |                 |
      10              : |                    |___/                  |
      11              : |___________________________________________|
      12              : 
      13              : Licensed under the MIT License <http://opensource.org/licenses/MIT>.
      14              : SPDX-License-Identifier: MIT
      15              : Copyright (c) 2021 Eduardo Ramos
      16              : 
      17              : Permission is hereby  granted, free of charge, to any  person obtaining a copy
      18              : of this software and associated  documentation files (the "Software"), to deal
      19              : in the Software  without restriction, including without  limitation the rights
      20              : to  use, copy,  modify, merge,  publish, distribute,  sublicense, and/or  sell
      21              : copies  of  the Software,  and  to  permit persons  to  whom  the Software  is
      22              : furnished to do so, subject to the following conditions:
      23              : 
      24              : The above copyright notice and this permission notice shall be included in all
      25              : copies or substantial portions of the Software.
      26              : 
      27              : THE SOFTWARE  IS PROVIDED "AS  IS", WITHOUT WARRANTY  OF ANY KIND,  EXPRESS OR
      28              : IMPLIED,  INCLUDING BUT  NOT  LIMITED TO  THE  WARRANTIES OF  MERCHANTABILITY,
      29              : FITNESS FOR  A PARTICULAR PURPOSE AND  NONINFRINGEMENT. IN NO EVENT  SHALL THE
      30              : AUTHORS  OR COPYRIGHT  HOLDERS  BE  LIABLE FOR  ANY  CLAIM,  DAMAGES OR  OTHER
      31              : LIABILITY, WHETHER IN AN ACTION OF  CONTRACT, TORT OR OTHERWISE, ARISING FROM,
      32              : OUT OF OR IN CONNECTION WITH THE SOFTWARE  OR THE USE OR OTHER DEALINGS IN THE
      33              : SOFTWARE.
      34              : */
      35              : 
      36              : #pragma once
      37              : 
      38              : #include <vector>
      39              : #include <string>
      40              : #include <mutex>
      41              : #include <shared_mutex>
      42              : 
      43              : #include <nlohmann/json.hpp>
      44              : 
      45              : #include <Map.hpp>
      46              : #include <AdminServerProvision.hpp>
      47              : 
      48              : #include <JsonSchema.hpp>
      49              : #include <AdminSchemas.hpp>
      50              : 
      51              : 
      52              : namespace h2agent
      53              : {
      54              : namespace model
      55              : {
      56              : 
      57              : // Map key will be string which has a hash function.
      58              : // We will agregate method and uri in a single string for that.
      59              : class AdminServerProvisionData : public Map<admin_server_provision_key_t, std::shared_ptr<AdminServerProvision>>
      60              : {
      61              : public:
      62              :     AdminServerProvisionData();
      63          154 :     ~AdminServerProvisionData() = default;
      64              : 
      65              :     // Load result
      66              :     enum LoadResult { Success = 0, BadSchema, BadContent };
      67              : 
      68              :     /**
      69              :      * Json string representation for class information (json array)
      70              :      *
      71              :      * @param ordered Print json array elements following the insertion order (false by default)
      72              :      * @param getUnused Print json array elements which was not used (false by default)
      73              :      *
      74              :      * @return Json string representation ('[]' for empty array).
      75              :      */
      76              :     std::string asJsonString(bool ordered = false, bool getUnused = false) const;
      77              : 
      78              :     /**
      79              :      * Loads server provision operation data
      80              :      *
      81              :      * @param j json document from operation body request
      82              :      * @param regexMatchingConfigured provision load depends on matching configuration (priority regexp)
      83              :      * @param cr common resources references (general configuration, global variables, file manager, mock server events data)
      84              :      *
      85              :      * @return Load operation result
      86              :      */
      87              :     LoadResult load(const nlohmann::json &j, bool regexMatchingConfigured, const common_resources_t &cr);
      88              : 
      89              :     /** Clears internal data (map and ordered keys vector)
      90              :      *
      91              :      * @return True if something was removed, false if already empty
      92              :      */
      93              :     bool clear();
      94              : 
      95              :     /**
      96              :      * Finds provision item for traffic reception. Previously, mock dynamic data should be checked to
      97              :      * know if current state exists for the reception.
      98              :      *
      99              :      * @param inState Request input state if proceeed
     100              :      * @param method Request method received
     101              :      * @param uri Request URI path received
     102              :      *
     103              :      * @return Provision information or null if missing
     104              :      */
     105              :     std::shared_ptr<AdminServerProvision> find(const std::string &inState, const std::string &method, const std::string &uri) const;
     106              : 
     107              :     /**
     108              :     * Finds provision item for traffic reception. Previously, mock dynamic data should be checked to
     109              :     * know if current state exists for the reception.
     110              :     * The algorithm is RegexMatching, so ordered search is applied.
     111              :     *
     112              :     * @param inState Request input state if proceeed
     113              :     * @param method Request method received
     114              :     * @param uri Request URI path received
     115              :     *
     116              :     * @return Provision information or null if missing
     117              :     */
     118              :     std::shared_ptr<AdminServerProvision> findRegexMatching(const std::string &inState, const std::string &method, const std::string &uri) const;
     119              : 
     120              :     /**
     121              :     * Gets provision schema
     122              :     */
     123            1 :     const h2agent::jsonschema::JsonSchema& getSchema() const {
     124            1 :         return server_provision_schema_;
     125              :     }
     126              : 
     127              : private:
     128              : 
     129              :     std::vector<admin_server_provision_key_t> ordered_keys_{}; // this is used to keep the insertion order which shall be used in RegexMatching algorithm
     130              :     h2agent::jsonschema::JsonSchema server_provision_schema_{};
     131              : 
     132              :     LoadResult loadSingle(const nlohmann::json &j, bool regexMatchingConfigured, const common_resources_t &cr);
     133              : 
     134              :     mutable mutex_t rw_mutex_{};
     135              : };
     136              : 
     137              : }
     138              : }
     139              : 
        

Generated by: LCOV version 2.0-1