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 :
|