Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v0.17.0 #567

Merged
merged 90 commits into from
Jan 9, 2023
Merged
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
5e40248
update ffmpeg submodules (#565)
ReenigneArcher Dec 15, 2022
a4a5d30
AMD encoder improvements (#480)
psyke83 Dec 15, 2022
cb406bc
Video: revert software bitrate change & use more conservative bufsize…
psyke83 Dec 15, 2022
3fd38b3
video: reduce nvenc delay/async_depth to 0 (#507)
psyke83 Dec 15, 2022
5e6a42a
Migrate to upstream Simple-Web-Server submodule (#517)
cgutman Dec 15, 2022
a1d07ff
Bump third-party/TPCircularBuffer from `bce9170` to `8833b3a` (#555)
dependabot[bot] Dec 15, 2022
63c105b
Bump third-party/moonlight-common-c from `8169a31` to `9da6329` (#559)
dependabot[bot] Dec 15, 2022
a54830c
video: vaapi: reduce async_depth to 1 (#545)
psyke83 Dec 16, 2022
f4edce3
Avoid using functions deprecated in OpenSSL 3.0 (#515)
cgutman Dec 16, 2022
66f46ab
Send valid frame type value in frame header (#516)
cgutman Dec 16, 2022
633f003
Send a valid PTS in the RTP video header (#529)
cgutman Dec 16, 2022
223e87f
set submodule branches (#570)
ReenigneArcher Dec 16, 2022
66f1ac6
Bump third-party/miniupnp from `6f848ae` to `207cf44` (#557)
dependabot[bot] Dec 16, 2022
302bf58
CMakeLists: win32: fix build against boost 1.81.0-1+ (#576)
psyke83 Dec 17, 2022
7a23d6a
macOS arm64 (#591)
brad-richardson Dec 20, 2022
dfb8d9d
Fix PATH environment variable handling on Windows
cgutman Dec 21, 2022
6c5a323
Use the proper environment variable for the Program Files (x86) folder
cgutman Dec 21, 2022
b1ac4bc
Merge pull request #599 from cgutman/path_env
ReenigneArcher Dec 21, 2022
8a99187
Fix SunshineSvc hanging if an error occurs during startup (#598)
cgutman Dec 21, 2022
2b1514b
Bump ffmpeg (#603)
LizardByte-bot Dec 22, 2022
1041f87
Spawn Sunshine.exe in a job object, so it is terminated if SunshineSv…
cgutman Dec 22, 2022
bb092c0
Fix streaming with non-B8G8R8A8 desktop mode (#609)
cgutman Dec 23, 2022
1e037db
Fix pixel pitch handling for DXGI_FORMAT_R16G16B16A16_FLOAT (#605)
cgutman Dec 23, 2022
5adbd29
ci: update global workflows (#613)
LizardByte-bot Dec 23, 2022
c3ec53c
CMake: win32: further fix for boost linker incompatibility (#632)
psyke83 Dec 27, 2022
cbb5ec3
Remove duplicate boost port (#630)
brad-richardson Dec 27, 2022
95437d1
FFmpeg 5 and pre-built CBS (#509)
brad-richardson Dec 27, 2022
d69d540
Bump ffmpeg (#631)
LizardByte-bot Dec 27, 2022
c0b042f
windows/vram: fix fringing in NV12 colour conversion (#622)
psyke83 Dec 27, 2022
c1f0daa
fix npm path (#635)
ReenigneArcher Dec 27, 2022
05f5370
Launch games under the correct user account on Windows (#600)
cgutman Dec 27, 2022
215c864
nvenc, amdvce: rework all user presets/options (#623)
psyke83 Dec 28, 2022
c7fe8f6
windows: Fix audio when host is not using 48 KHz sample rate (#640)
cgutman Dec 28, 2022
f4a48f4
Rework audio bitrate and quality handling (#642)
cgutman Dec 28, 2022
ad20572
ci: update global workflows (#643)
LizardByte-bot Dec 28, 2022
a996902
Generate certificates with unique serial numbers (#645)
cgutman Dec 28, 2022
2791969
CMake: NSIS: improve user upgrade experience (#587)
psyke83 Dec 28, 2022
88a450b
update docs (#574)
ReenigneArcher Dec 28, 2022
dc5571b
add cmake-lint action (#646)
ReenigneArcher Dec 29, 2022
8ad7af8
Graceful termination on shutdown, logoff, and service stop (#647)
cgutman Dec 29, 2022
d6db10a
Remove/fix calls to std::abort() (#648)
cgutman Dec 29, 2022
a95a553
Remove prompt to press enter after Sunshine exits
cgutman Dec 29, 2022
e00aa4f
Make log priority consistent for execution messages
cgutman Dec 29, 2022
8b3b000
Merge pull request #650 from cgutman/term_logging_feedback
ReenigneArcher Dec 29, 2022
8aaf9fd
remove automatic desktop entry (#652)
ReenigneArcher Dec 30, 2022
2dc1507
Bump third-party/ViGEmClient from `f719a1d` to `9e842ba` (#558)
dependabot[bot] Dec 30, 2022
3b53734
Bump sphinx from 5.3.0 to 6.0.0 (#653)
dependabot[bot] Dec 30, 2022
91f4f15
set concurrency limit for CI workflow (#657)
ReenigneArcher Dec 30, 2022
03b6273
Convert keyboard input to scancodes using the US English layout (#651)
cgutman Dec 30, 2022
0c6d0ed
Dynamic capture format selection (IDXGIOutput5) (#654)
cgutman Dec 31, 2022
248b1bf
Fix launching apps when Sunshine is running as admin (#659)
cgutman Jan 1, 2023
a5213c6
Logs inside the WebUI (#634)
TheElixZammuto Jan 1, 2023
17cd230
ci: update global workflows (#661)
LizardByte-bot Jan 1, 2023
e5dedbb
ci: update global python (#662)
LizardByte-bot Jan 1, 2023
9ae46e1
ci: update global docker (#663)
LizardByte-bot Jan 1, 2023
97b1790
ci: update release notifier (#665)
LizardByte-bot Jan 1, 2023
cfe7129
windows: pin libpsl version (#669)
ReenigneArcher Jan 2, 2023
a7a9df3
ci: update global workflows (#673)
LizardByte-bot Jan 2, 2023
f9963ed
update clang-format (#666)
ReenigneArcher Jan 2, 2023
76ffa2a
Fix unexpected format switching in display_vram (#667)
cgutman Jan 2, 2023
0439d7a
Use separate encoding and capture devices to enable parallel encoding…
cgutman Jan 2, 2023
952e142
fix aur publish trigger event (#680)
ReenigneArcher Jan 2, 2023
12efe96
fix docs badges for epub (#679)
ReenigneArcher Jan 2, 2023
052297a
Update app id on edit (#670)
brad-richardson Jan 3, 2023
30a790b
Fix UPnP IGD detection (#689)
BigBrainAFK Jan 3, 2023
e410426
Bump bootstrap from 5.0.0 to 5.2.3 (#638)
dependabot[bot] Jan 4, 2023
997e8c6
Bump @fortawesome/fontawesome-free from 6.2.0 to 6.2.1 (#639)
dependabot[bot] Jan 4, 2023
cc688c7
Implement process and thread priority adjustments (#691)
cgutman Jan 4, 2023
a3922d9
Bump third-party/moonlight-common-c from `9da6329` to `ef9ad52` (#690)
dependabot[bot] Jan 4, 2023
ff88305
Fix wayland capture on nvidia (#649)
jhgarner Jan 4, 2023
1c1a7fa
Fix 7.1 surround channel mapping (#694)
cgutman Jan 4, 2023
76896eb
Fix NVENC profile values not applying (#695)
cgutman Jan 4, 2023
c72aeef
Only increase rc_buffer_size when software encoding with more than on…
cgutman Jan 4, 2023
1a929cc
Fix origin_web_ui_allowed binding (#697)
d-s-x Jan 4, 2023
08cb5fc
Minor UI fixes (#696)
cgutman Jan 4, 2023
f1c225f
Terminate Sunshine if a session doesn't terminate for more than 10 se…
cgutman Jan 5, 2023
00aa23b
Fix hang on stream termination if no frames can be captured (#709)
cgutman Jan 5, 2023
5980e52
Improve robustness of encoder selection (#710)
cgutman Jan 5, 2023
65574a0
Add an Apply button to the Web UI when running as a Win32 Service (#700)
cgutman Jan 5, 2023
effa98f
Bump sphinx from 6.0.0 to 6.1.1 (#713)
dependabot[bot] Jan 6, 2023
9b6d0b7
Generated app id with hashed input data (#715)
brad-richardson Jan 7, 2023
c95f54f
Migrate Windows config files into specific config directory (#716)
cgutman Jan 7, 2023
e2fce25
Fix Windows masked cursor blending with GPU encoders (#720)
cgutman Jan 7, 2023
7770b5f
Enable Mouse Keys while streaming for systems with no mouse plugged i…
cgutman Jan 7, 2023
77d3a7e
Color conversion fixes and BT.2020 support (#723)
cgutman Jan 8, 2023
6607062
Fix divisor for YUV range (#728)
cgutman Jan 8, 2023
a26877a
fix submodule names (#725)
ReenigneArcher Jan 8, 2023
d51afbe
CMake: win32: fix API version, disable boost-cmake detection (#732)
psyke83 Jan 9, 2023
23ef231
revert windows build libpsl version lock (#729)
ReenigneArcher Jan 9, 2023
009975d
prepare v0.17.0 (#708)
ReenigneArcher Jan 9, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 14 additions & 4 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -1,21 +1,27 @@
[submodule "moonlight-common-c"]
path = third-party/moonlight-common-c
url = https://github.com/moonlight-stream/moonlight-common-c.git
branch = master
[submodule "Simple-Web-Server"]
path = third-party/Simple-Web-Server
url = https://github.com/loki-47-6F-64/Simple-Web-Server.git
url = https://gitlab.com/eidheim/Simple-Web-Server.git
branch = master
[submodule "ViGEmClient"]
path = third-party/ViGEmClient
url = https://github.com/ViGEm/ViGEmClient
[submodule "third-party/miniupnp"]
branch = master
[submodule "miniupnp"]
path = third-party/miniupnp
url = https://github.com/miniupnp/miniupnp
[submodule "third-party/nv-codec-headers"]
branch = master
[submodule "nv-codec-headers"]
path = third-party/nv-codec-headers
url = https://github.com/FFmpeg/nv-codec-headers
[submodule "third-party/TPCircularBuffer"]
branch = sdk/11.1
[submodule "TPCircularBuffer"]
path = third-party/TPCircularBuffer
url = https://github.com/michaeltyson/TPCircularBuffer
branch = master
[submodule "ffmpeg-windows-x86_64"]
path = third-party/ffmpeg-windows-x86_64
url = https://github.com/LizardByte/build-deps
Expand All @@ -32,3 +38,7 @@
path = third-party/ffmpeg-linux-aarch64
url = https://github.com/LizardByte/build-deps
branch = ffmpeg-linux-aarch64
[submodule "ffmpeg-macos-aarch64"]
path = third-party/ffmpeg-macos-aarch64
url = https://github.com/LizardByte/build-deps
branch = ffmpeg-macos-aarch64
12 changes: 7 additions & 5 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ set(UPNPC_BUILD_TESTS OFF CACHE BOOL "Don't build tests for miniupnpc")
set(UPNPC_BUILD_SAMPLE OFF CACHE BOOL "Don't build samples for miniupnpc")
set(UPNPC_NO_INSTALL ON CACHE BOOL "Don't install any libraries build for miniupnpc")
add_subdirectory(third-party/miniupnp/miniupnpc)
include_directories(third-party/miniupnp)
include_directories(third-party/miniupnp/miniupnpc/include)

find_package(Threads REQUIRED)
find_package(OpenSSL REQUIRED)
Expand All @@ -78,9 +78,6 @@ if(WIN32)
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -static")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CURL_STATIC_LDFLAGS} ${CURL_STATIC_CFLAGS}")

# Restrict Boost WinAPI version to work around 1.80 linker errors
ADD_DEFINITIONS(-DBOOST_USE_WINAPI_VERSION=BOOST_WINAPI_VERSION_WIN7)

add_compile_definitions(SUNSHINE_PLATFORM="windows")
add_subdirectory(tools) # This is temporary, only tools for Windows are needed, for now

Expand Down Expand Up @@ -121,6 +118,7 @@ if(WIN32)
d3d11 dxgi D3DCompiler
setupapi
dwmapi
synchronization.lib
${CURL_STATIC_LIBRARIES}
)

Expand Down Expand Up @@ -377,7 +375,11 @@ if(WIN32)
set(FFMPEG_PREPARED_BINARIES "${CMAKE_CURRENT_SOURCE_DIR}/third-party/ffmpeg-windows-x86_64")
set(FFMPEG_PLATFORM_LIBRARIES mfplat ole32 strmiids mfuuid)
elseif(APPLE)
set(FFMPEG_PREPARED_BINARIES "${CMAKE_CURRENT_SOURCE_DIR}/third-party/ffmpeg-macos-x86_64")
if (CMAKE_SYSTEM_PROCESSOR STREQUAL "arm64")
set(FFMPEG_PREPARED_BINARIES "${CMAKE_CURRENT_SOURCE_DIR}/third-party/ffmpeg-macos-aarch64")
else()
set(FFMPEG_PREPARED_BINARIES "${CMAKE_CURRENT_SOURCE_DIR}/third-party/ffmpeg-macos-x86_64")
endif()
else()
if (CMAKE_SYSTEM_PROCESSOR STREQUAL "aarch64")
set(FFMPEG_PREPARED_BINARIES "${CMAKE_CURRENT_SOURCE_DIR}/third-party/ffmpeg-linux-aarch64")
Expand Down
2 changes: 1 addition & 1 deletion docs/source/building/macos.rst
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ MacPorts
Install Requirements
.. code-block:: bash

sudo port install boost cmake libopus npm9
sudo port install avahi boost180 cmake curl libopus npm9 pkgconfig

Homebrew
""""""""
Expand Down
1 change: 1 addition & 0 deletions packaging/macos/Portfile
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ post-fetch {
}

depends_lib port:avahi \
port:boost180 \
port:curl \
port:libopus \
port:npm9 \
Expand Down
29 changes: 9 additions & 20 deletions src/confighttp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ void print_req(const req_https_t &request) {
}

void send_unauthorized(resp_https_t response, req_https_t request) {
auto address = request->remote_endpoint_address();
auto address = request->remote_endpoint().address().to_string();
BOOST_LOG(info) << "Web UI: ["sv << address << "] -- not authorized"sv;
const SimpleWeb::CaseInsensitiveMultimap headers {
{ "WWW-Authenticate", R"(Basic realm="Sunshine Gamestream Host", charset="UTF-8")" }
Expand All @@ -77,7 +77,7 @@ void send_unauthorized(resp_https_t response, req_https_t request) {
}

void send_redirect(resp_https_t response, req_https_t request, const char *path) {
auto address = request->remote_endpoint_address();
auto address = request->remote_endpoint().address().to_string();
BOOST_LOG(info) << "Web UI: ["sv << address << "] -- not authorized"sv;
const SimpleWeb::CaseInsensitiveMultimap headers {
{ "Location", path }
Expand All @@ -86,7 +86,7 @@ void send_redirect(resp_https_t response, req_https_t request, const char *path)
}

bool authenticate(resp_https_t response, req_https_t request) {
auto address = request->remote_endpoint_address();
auto address = request->remote_endpoint().address().to_string();
auto ip_type = net::from_address(address);

if(ip_type > http::origin_web_ui_allowed) {
Expand Down Expand Up @@ -636,11 +636,8 @@ void start() {

auto port_https = map_port(PORT_HTTPS);

auto ctx = std::make_shared<boost::asio::ssl::context>(boost::asio::ssl::context::tls);
ctx->use_certificate_chain_file(config::nvhttp.cert);
ctx->use_private_key_file(config::nvhttp.pkey, boost::asio::ssl::context::pem);
https_server_t server { ctx, 0 };
server.default_resource = not_found;
https_server_t server { config::nvhttp.cert, config::nvhttp.pkey };
server.default_resource["GET"] = not_found;
server.resource["^/$"]["GET"] = getIndexPage;
server.resource["^/pin$"]["GET"] = getPinPage;
server.resource["^/apps$"]["GET"] = getAppsPage;
Expand All @@ -666,27 +663,19 @@ void start() {
server.config.address = "0.0.0.0"s;
server.config.port = port_https;

try {
server.bind();
BOOST_LOG(info) << "Configuration UI available at [https://localhost:"sv << port_https << "]";
}
catch(boost::system::system_error &err) {
BOOST_LOG(fatal) << "Couldn't bind http server to ports ["sv << port_https << "]: "sv << err.what();

shutdown_event->raise(true);
return;
}
auto accept_and_run = [&](auto *server) {
try {
server->accept_and_run();
server->start([](unsigned short port) {
BOOST_LOG(info) << "Configuration UI available at [https://localhost:"sv << port << "]";
});
}
catch(boost::system::system_error &err) {
// It's possible the exception gets thrown after calling server->stop() from a different thread
if(shutdown_event->peek()) {
return;
}

BOOST_LOG(fatal) << "Couldn't start Configuration HTTPS server to port ["sv << port_https << "]: "sv << err.what();
BOOST_LOG(fatal) << "Couldn't start Configuration HTTPS server on port ["sv << port_https << "]: "sv << err.what();
shutdown_event->raise(true);
return;
}
Expand Down
21 changes: 6 additions & 15 deletions src/crypto.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@
#include <openssl/pem.h>

namespace crypto {
using big_num_t = util::safe_ptr<BIGNUM, BN_free>;
// using rsa_t = util::safe_ptr<RSA, RSA_free>;
using asn1_string_t = util::safe_ptr<ASN1_STRING, ASN1_STRING_free>;

cert_chain_t::cert_chain_t() : _certs {}, _cert_ctx { X509_STORE_CTX_new() } {}
Expand Down Expand Up @@ -315,12 +313,7 @@ aes_t gen_aes_key(const std::array<uint8_t, 16> &salt, const std::string_view &p

sha256_t hash(const std::string_view &plaintext) {
sha256_t hsh;

SHA256_CTX sha256;
SHA256_Init(&sha256);
SHA256_Update(&sha256, plaintext.data(), plaintext.size());
SHA256_Final(hsh.data(), &sha256);

EVP_Digest(plaintext.data(), plaintext.size(), hsh.data(), nullptr, EVP_sha256(), nullptr);
return hsh;
}

Expand Down Expand Up @@ -409,14 +402,12 @@ std::vector<uint8_t> sign(const pkey_t &pkey, const std::string_view &data, cons

creds_t gen_creds(const std::string_view &cn, std::uint32_t key_bits) {
x509_t x509 { X509_new() };
pkey_t pkey { EVP_PKEY_new() };

big_num_t big_num { BN_new() };
BN_set_word(big_num.get(), RSA_F4);
pkey_ctx_t ctx { EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, nullptr) };
pkey_t pkey;

auto rsa = RSA_new();
RSA_generate_key_ex(rsa, key_bits, big_num.get(), nullptr);
EVP_PKEY_assign_RSA(pkey.get(), rsa);
EVP_PKEY_keygen_init(ctx.get());
EVP_PKEY_CTX_set_rsa_keygen_bits(ctx.get(), key_bits);
EVP_PKEY_keygen(ctx.get(), &pkey);

X509_set_version(x509.get(), 2);
ASN1_INTEGER_set(X509_get_serialNumber(x509.get()), 0);
Expand Down
1 change: 1 addition & 0 deletions src/crypto.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ using cipher_ctx_t = util::safe_ptr<EVP_CIPHER_CTX, EVP_CIPHER_CTX_free>;
using md_ctx_t = util::safe_ptr<EVP_MD_CTX, md_ctx_destroy>;
using bio_t = util::safe_ptr<BIO, BIO_free_all>;
using pkey_t = util::safe_ptr<EVP_PKEY, EVP_PKEY_free>;
using pkey_ctx_t = util::safe_ptr<EVP_PKEY_CTX, EVP_PKEY_CTX_free>;

sha256_t hash(const std::string_view &plaintext);

Expand Down
Loading