Browse Source
web_backend: fix a regression introduced in
web_backend: fix a regression introduced in 16de0a6
* A regression was in 16de0a6 and token verification function was
broken.
* The reason being `httplib` now requires OpenSSL 1.1+ API while
LibreSSL 2.x provided OpenSSL 1.0 compatible API.
* The bundled LibreSSL has been updated to 3.2.2 so it now provides
OpenSSL 1.1 compatible API now.
* Also the path hint has been added so that it will find the correct
path to the CA certs on *nix systems.
* An option is provided so that *nix system distributions/providers can
use their own SSL implementations when compiling Yuzu/Citra to
(hopefully) complies with their maintenance guidelines.
* LURLParse is also removed since `httplib` can handle
`scheme:host:port` string itself now.
nce_cpp
9 changed files with 19 additions and 402 deletions
-
2CMakeLists.txt
-
25externals/CMakeLists.txt
-
2externals/libressl
-
8externals/lurlparser/CMakeLists.txt
-
265externals/lurlparser/LUrlParser.cpp
-
78externals/lurlparser/LUrlParser.h
-
19externals/lurlparser/README.md
-
2src/web_service/CMakeLists.txt
-
20src/web_service/web_backend.cpp
@ -1 +1 @@ |
|||||
Subproject commit 7d01cb01cb1a926ecb4c9c98b107ef3c26f59dfb |
|
||||
|
Subproject commit 8289d0d07de6553bf4b900bf60e808ea3f7f59da |
||||
@ -1,8 +0,0 @@ |
|||||
add_library(lurlparser |
|
||||
LUrlParser.cpp |
|
||||
LUrlParser.h |
|
||||
) |
|
||||
|
|
||||
create_target_directory_groups(lurlparser) |
|
||||
|
|
||||
target_include_directories(lurlparser INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}) |
|
||||
@ -1,265 +0,0 @@ |
|||||
/*
|
|
||||
* Lightweight URL & URI parser (RFC 1738, RFC 3986) |
|
||||
* https://github.com/corporateshark/LUrlParser
|
|
||||
* |
|
||||
* The MIT License (MIT) |
|
||||
* |
|
||||
* Copyright (C) 2015 Sergey Kosarevsky (sk@linderdaum.com) |
|
||||
* |
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy |
|
||||
* of this software and associated documentation files (the "Software"), to deal |
|
||||
* in the Software without restriction, including without limitation the rights |
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
|
||||
* copies of the Software, and to permit persons to whom the Software is |
|
||||
* furnished to do so, subject to the following conditions: |
|
||||
* |
|
||||
* The above copyright notice and this permission notice shall be included in all |
|
||||
* copies or substantial portions of the Software. |
|
||||
* |
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
|
||||
* SOFTWARE. |
|
||||
*/ |
|
||||
|
|
||||
#include "LUrlParser.h"
|
|
||||
|
|
||||
#include <algorithm>
|
|
||||
#include <cstring>
|
|
||||
#include <stdlib.h>
|
|
||||
|
|
||||
// check if the scheme name is valid
|
|
||||
static bool IsSchemeValid( const std::string& SchemeName ) |
|
||||
{ |
|
||||
for ( auto c : SchemeName ) |
|
||||
{ |
|
||||
if ( !isalpha( c ) && c != '+' && c != '-' && c != '.' ) return false; |
|
||||
} |
|
||||
|
|
||||
return true; |
|
||||
} |
|
||||
|
|
||||
bool LUrlParser::clParseURL::GetPort( int* OutPort ) const |
|
||||
{ |
|
||||
if ( !IsValid() ) { return false; } |
|
||||
|
|
||||
int Port = atoi( m_Port.c_str() ); |
|
||||
|
|
||||
if ( Port <= 0 || Port > 65535 ) { return false; } |
|
||||
|
|
||||
if ( OutPort ) { *OutPort = Port; } |
|
||||
|
|
||||
return true; |
|
||||
} |
|
||||
|
|
||||
// based on RFC 1738 and RFC 3986
|
|
||||
LUrlParser::clParseURL LUrlParser::clParseURL::ParseURL( const std::string& URL ) |
|
||||
{ |
|
||||
LUrlParser::clParseURL Result; |
|
||||
|
|
||||
const char* CurrentString = URL.c_str(); |
|
||||
|
|
||||
/*
|
|
||||
* <scheme>:<scheme-specific-part> |
|
||||
* <scheme> := [a-z\+\-\.]+ |
|
||||
* For resiliency, programs interpreting URLs should treat upper case letters as equivalent to lower case in scheme names |
|
||||
*/ |
|
||||
|
|
||||
// try to read scheme
|
|
||||
{ |
|
||||
const char* LocalString = strchr( CurrentString, ':' ); |
|
||||
|
|
||||
if ( !LocalString ) |
|
||||
{ |
|
||||
return clParseURL( LUrlParserError_NoUrlCharacter ); |
|
||||
} |
|
||||
|
|
||||
// save the scheme name
|
|
||||
Result.m_Scheme = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
if ( !IsSchemeValid( Result.m_Scheme ) ) |
|
||||
{ |
|
||||
return clParseURL( LUrlParserError_InvalidSchemeName ); |
|
||||
} |
|
||||
|
|
||||
// scheme should be lowercase
|
|
||||
std::transform( Result.m_Scheme.begin(), Result.m_Scheme.end(), Result.m_Scheme.begin(), ::tolower ); |
|
||||
|
|
||||
// skip ':'
|
|
||||
CurrentString = LocalString+1; |
|
||||
} |
|
||||
|
|
||||
/*
|
|
||||
* //<user>:<password>@<host>:<port>/<url-path>
|
|
||||
* any ":", "@" and "/" must be normalized |
|
||||
*/ |
|
||||
|
|
||||
// skip "//"
|
|
||||
if ( *CurrentString++ != '/' ) return clParseURL( LUrlParserError_NoDoubleSlash ); |
|
||||
if ( *CurrentString++ != '/' ) return clParseURL( LUrlParserError_NoDoubleSlash ); |
|
||||
|
|
||||
// check if the user name and password are specified
|
|
||||
bool bHasUserName = false; |
|
||||
|
|
||||
const char* LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString ) |
|
||||
{ |
|
||||
if ( *LocalString == '@' ) |
|
||||
{ |
|
||||
// user name and password are specified
|
|
||||
bHasUserName = true; |
|
||||
break; |
|
||||
} |
|
||||
else if ( *LocalString == '/' ) |
|
||||
{ |
|
||||
// end of <host>:<port> specification
|
|
||||
bHasUserName = false; |
|
||||
break; |
|
||||
} |
|
||||
|
|
||||
LocalString++; |
|
||||
} |
|
||||
|
|
||||
// user name and password
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
if ( bHasUserName ) |
|
||||
{ |
|
||||
// read user name
|
|
||||
while ( *LocalString && *LocalString != ':' && *LocalString != '@' ) LocalString++; |
|
||||
|
|
||||
Result.m_UserName = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
// proceed with the current pointer
|
|
||||
CurrentString = LocalString; |
|
||||
|
|
||||
if ( *CurrentString == ':' ) |
|
||||
{ |
|
||||
// skip ':'
|
|
||||
CurrentString++; |
|
||||
|
|
||||
// read password
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString && *LocalString != '@' ) LocalString++; |
|
||||
|
|
||||
Result.m_Password = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
} |
|
||||
|
|
||||
// skip '@'
|
|
||||
if ( *CurrentString != '@' ) |
|
||||
{ |
|
||||
return clParseURL( LUrlParserError_NoAtSign ); |
|
||||
} |
|
||||
|
|
||||
CurrentString++; |
|
||||
} |
|
||||
|
|
||||
bool bHasBracket = ( *CurrentString == '[' ); |
|
||||
|
|
||||
// go ahead, read the host name
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString ) |
|
||||
{ |
|
||||
if ( bHasBracket && *LocalString == ']' ) |
|
||||
{ |
|
||||
// end of IPv6 address
|
|
||||
LocalString++; |
|
||||
break; |
|
||||
} |
|
||||
else if ( !bHasBracket && ( *LocalString == ':' || *LocalString == '/' ) ) |
|
||||
{ |
|
||||
// port number is specified
|
|
||||
break; |
|
||||
} |
|
||||
|
|
||||
LocalString++; |
|
||||
} |
|
||||
|
|
||||
Result.m_Host = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
|
|
||||
// is port number specified?
|
|
||||
if ( *CurrentString == ':' ) |
|
||||
{ |
|
||||
CurrentString++; |
|
||||
|
|
||||
// read port number
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString && *LocalString != '/' ) LocalString++; |
|
||||
|
|
||||
Result.m_Port = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
} |
|
||||
|
|
||||
// end of string
|
|
||||
if ( !*CurrentString ) |
|
||||
{ |
|
||||
Result.m_ErrorCode = LUrlParserError_Ok; |
|
||||
|
|
||||
return Result; |
|
||||
} |
|
||||
|
|
||||
// skip '/'
|
|
||||
if ( *CurrentString != '/' ) |
|
||||
{ |
|
||||
return clParseURL( LUrlParserError_NoSlash ); |
|
||||
} |
|
||||
|
|
||||
CurrentString++; |
|
||||
|
|
||||
// parse the path
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString && *LocalString != '#' && *LocalString != '?' ) LocalString++; |
|
||||
|
|
||||
Result.m_Path = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
|
|
||||
// check for query
|
|
||||
if ( *CurrentString == '?' ) |
|
||||
{ |
|
||||
// skip '?'
|
|
||||
CurrentString++; |
|
||||
|
|
||||
// read query
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString && *LocalString != '#' ) LocalString++; |
|
||||
|
|
||||
Result.m_Query = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
} |
|
||||
|
|
||||
// check for fragment
|
|
||||
if ( *CurrentString == '#' ) |
|
||||
{ |
|
||||
// skip '#'
|
|
||||
CurrentString++; |
|
||||
|
|
||||
// read fragment
|
|
||||
LocalString = CurrentString; |
|
||||
|
|
||||
while ( *LocalString ) LocalString++; |
|
||||
|
|
||||
Result.m_Fragment = std::string( CurrentString, LocalString - CurrentString ); |
|
||||
|
|
||||
CurrentString = LocalString; |
|
||||
} |
|
||||
|
|
||||
Result.m_ErrorCode = LUrlParserError_Ok; |
|
||||
|
|
||||
return Result; |
|
||||
} |
|
||||
@ -1,78 +0,0 @@ |
|||||
/* |
|
||||
* Lightweight URL & URI parser (RFC 1738, RFC 3986) |
|
||||
* https://github.com/corporateshark/LUrlParser |
|
||||
* |
|
||||
* The MIT License (MIT) |
|
||||
* |
|
||||
* Copyright (C) 2015 Sergey Kosarevsky (sk@linderdaum.com) |
|
||||
* |
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy |
|
||||
* of this software and associated documentation files (the "Software"), to deal |
|
||||
* in the Software without restriction, including without limitation the rights |
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
|
||||
* copies of the Software, and to permit persons to whom the Software is |
|
||||
* furnished to do so, subject to the following conditions: |
|
||||
* |
|
||||
* The above copyright notice and this permission notice shall be included in all |
|
||||
* copies or substantial portions of the Software. |
|
||||
* |
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
|
||||
* SOFTWARE. |
|
||||
*/ |
|
||||
|
|
||||
#pragma once |
|
||||
|
|
||||
#include <string> |
|
||||
|
|
||||
namespace LUrlParser |
|
||||
{ |
|
||||
enum LUrlParserError |
|
||||
{ |
|
||||
LUrlParserError_Ok = 0, |
|
||||
LUrlParserError_Uninitialized = 1, |
|
||||
LUrlParserError_NoUrlCharacter = 2, |
|
||||
LUrlParserError_InvalidSchemeName = 3, |
|
||||
LUrlParserError_NoDoubleSlash = 4, |
|
||||
LUrlParserError_NoAtSign = 5, |
|
||||
LUrlParserError_UnexpectedEndOfLine = 6, |
|
||||
LUrlParserError_NoSlash = 7, |
|
||||
}; |
|
||||
|
|
||||
class clParseURL |
|
||||
{ |
|
||||
public: |
|
||||
LUrlParserError m_ErrorCode; |
|
||||
std::string m_Scheme; |
|
||||
std::string m_Host; |
|
||||
std::string m_Port; |
|
||||
std::string m_Path; |
|
||||
std::string m_Query; |
|
||||
std::string m_Fragment; |
|
||||
std::string m_UserName; |
|
||||
std::string m_Password; |
|
||||
|
|
||||
clParseURL() |
|
||||
: m_ErrorCode( LUrlParserError_Uninitialized ) |
|
||||
{} |
|
||||
|
|
||||
/// return 'true' if the parsing was successful |
|
||||
bool IsValid() const { return m_ErrorCode == LUrlParserError_Ok; } |
|
||||
|
|
||||
/// helper to convert the port number to int, return 'true' if the port is valid (within the 0..65535 range) |
|
||||
bool GetPort( int* OutPort ) const; |
|
||||
|
|
||||
/// parse the URL |
|
||||
static clParseURL ParseURL( const std::string& URL ); |
|
||||
|
|
||||
private: |
|
||||
explicit clParseURL( LUrlParserError ErrorCode ) |
|
||||
: m_ErrorCode( ErrorCode ) |
|
||||
{} |
|
||||
}; |
|
||||
|
|
||||
} // namespace LUrlParser |
|
||||
@ -1,19 +0,0 @@ |
|||||
From https://github.com/corporateshark/LUrlParser/commit/455d5e2d27e3946f11ad0328fee9ee2628e6a8e2 |
|
||||
|
|
||||
MIT License |
|
||||
|
|
||||
=== |
|
||||
|
|
||||
Lightweight URL & URI parser (RFC 1738, RFC 3986) |
|
||||
|
|
||||
(C) Sergey Kosarevsky, 2015 |
|
||||
|
|
||||
@corporateshark sk@linderdaum.com |
|
||||
|
|
||||
http://www.linderdaum.com |
|
||||
|
|
||||
http://blog.linderdaum.com |
|
||||
|
|
||||
============================= |
|
||||
|
|
||||
A tiny and lightweight URL & URI parser (RFC 1738, RFC 3986) written in C++. |
|
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue