RESTinio
try_parse_field.hpp
Go to the documentation of this file.
1/*
2 * RESTinio
3 */
4
12#pragma once
13
15
18#include <restinio/variant.hpp>
19
20#include <iostream>
21
22namespace restinio
23{
24
25namespace http_field_parsers
26{
27
28//
29// field_not_found_t
30//
38
39namespace try_extract_field_details
40{
41
42//
43// result_variant_t
44//
51template< typename Parsed_Field_Type >
53 Parsed_Field_Type,
56
57//
58// valid_field_type
59//
60template< typename, typename = restinio::utils::metaprogramming::void_t<> >
62
63template< typename T >
65 T,
67 std::enable_if_t<
68 std::is_same<
69 expected_t< T, restinio::easy_parser::parse_error_t >,
70 decltype(T::try_parse(std::declval<string_view_t>()))
71 >::value,
72 bool
73 >
74 >
75 > : public std::true_type
76{};
77
78//
79// try_extract_field_value_from
80//
81template< typename Parsed_Field_Type >
86 string_view_t default_value )
87{
89 "Parsed_Field_Type should have static try_parse method that "
90 "accepts string_view_t and returns "
91 "expected_t<Parsed_Field_Type, parse_error_t>" );
92
93 if( !opt_value && default_value.empty() )
94 return { field_not_found_t{} };
95
96 string_view_t content = opt_value ? *opt_value : default_value;
97
98 auto parse_result = Parsed_Field_Type::try_parse( content );
99 if( parse_result )
100 return { std::move(*parse_result) };
101 else
102 return { parse_result.error() };
103}
104
105} /* namespace try_extract_field_details */
106
107//
108// try_parse_field
109//
148template< typename Parsed_Field_Type, typename Extra_Data >
150auto
155 string_view_t field_name,
159 string_view_t default_value = string_view_t{} )
160{
161 using namespace try_extract_field_details;
162
163 return try_extract_field_value_from< Parsed_Field_Type >(
164 req.header().opt_value_of( field_name ),
165 default_value );
166}
167
206template< typename Parsed_Field_Type, typename Extra_Data >
208auto
213 http_field_t field_id,
217 string_view_t default_value = string_view_t{} )
218{
219 using namespace try_extract_field_details;
220
221 return try_extract_field_value_from< Parsed_Field_Type >(
222 req.header().opt_value_of( field_id ),
223 default_value );
224}
225
226} /* namespace http_field_parsers */
227
228} /* namespace restinio */
229
Information about parsing error.
Definition: easy_parser.hpp:93
const http_request_header_t & header() const noexcept
Get request header.
optional_t< string_view_t > opt_value_of(string_view_t name) const noexcept
Get optional value of a field.
#define RESTINIO_NODISCARD
An very small, simple and somewhat limited implementation of recursive-descent parser.
bool_constant< false > false_type
Definition: optional.hpp:460
bool_constant< true > true_type
Definition: optional.hpp:459
RESTINIO_NODISCARD expected_t< typename Producer::result_type, parse_error_t > try_parse(string_view_t from, Producer producer)
Perform the parsing of the specified content by using specified value producer.
RESTINIO_NODISCARD result_variant_t< Parsed_Field_Type > try_extract_field_value_from(optional_t< string_view_t > opt_value, string_view_t default_value)
RESTINIO_NODISCARD auto try_parse_field(const generic_request_t< Extra_Data > &req, string_view_t field_name, string_view_t default_value=string_view_t{})
A helper function for extraction and parsing a value of HTTP-field.
typename make_void< Ts... >::type void_t
nonstd::string_view string_view_t
Definition: string_view.hpp:19
std::enable_if< std::is_same< Parameter_Container, query_string_params_t >::value||std::is_same< Parameter_Container, router::route_params_t >::value, optional_t< Value_Type > >::type opt_value(const Parameter_Container &params, string_view_t key)
Gets the value of a parameter specified by key wrapped in optional_t<Value_Type> if parameter exists ...
Definition: value_or.hpp:64
http_field_t
C++ enum that repeats nodejs c-style enum.
A special type to be returned in the case if HTTP-field isn't found in a request.