Commit Graph

619 Commits

Author SHA1 Message Date
Timur Pocheptsov bba15a7cf5 QHttpServer auto-tests: use a function provided by QTest
Instead of having code-duplicates.

Pick-to: 6.9 6.8
Task-number: QTBUG-132645
Change-Id: I6976ae44a0ab14857d71d1cd6eef3cc09e40db34
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2025-02-18 16:51:37 +01:00
Lena Biliaieva 2d9e986800 Add support for IP address whitelist and blacklist in QHttpServer
- Added methods for setting a whitelist and a blacklist in the
QHttpServerConfiguration class.
- Implemented IP address filtering in QHttpServer based on the
configuration.

Task-number: QTBUG-75087
Change-Id: I2b630bb15e34aa2f0633f64331bcc558bd5a1809
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2025-02-11 11:43:26 +01:00
Tasuku Suzuki eb6e4d157a Fix documentation of new API
Pick-to: 6.8 6.9
Change-Id: I1b65972892a7f113a7539729ee551260b5588e3e
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
2025-02-11 08:21:03 +09:00
Ivan Solovev d48f398a1a Do not export QESDP<QHttpServerConfigurationPrivate> destructor
It's not needed, cf. QTBUG-128656 and
qtgraphs/6ae7164a5432bc49d7e9688dfd79c20515dd9333.

Amends c43b2f7a84.

Found in Qt 6.9 API review.

Pick-to: 6.9
Change-Id: I67de329f798b658df2c163c38773a5cb66ad7701
Reviewed-by: Marc Mutz <marc.mutz@qt.io>
2025-01-30 11:46:39 +00:00
Qt Submodule Update Bot e7a3142793 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I329ff0068ffab5b185812bc773e1ec490d604e12
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-01-23 21:20:03 +00:00
Ivan Solovev 417492b803 Document QAbstractHttpServer::(set)Configuration
Amends c43b2f7a84.

Found in Qt 6.9 API review.

Pick-to: 6.9
Change-Id: I8a1a62cf84c57c9b4ab1374e569d23f3ac318c96
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
Reviewed-by: Lena Biliaieva <lena.biliaieva@qt.io>
2025-01-22 16:42:29 +01:00
Qt Submodule Update Bot 80b4a18076 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I7cab6eddfa4091233d82677465262f9247a7eaee
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-01-20 14:37:58 +00:00
Volker Hilsheimer 4fb4bb7168 API review: replace `unsigned` with `quint32` in public API
Pick-to: 6.9
Change-Id: I417d82b47fb211d013f24a2702d42a7126461355
Reviewed-by: Ivan Solovev <ivan.solovev@qt.io>
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
2025-01-15 15:11:04 +01:00
Qt Submodule Update Bot 28fca6956d Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I71ddb79e50a5b2f5b5e3c893813490679c794da9
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-01-14 19:29:12 +00:00
Øystein Heskestad de5c25580c Add missing include guards for localserver
Add missing include guards for localserver to make QtHttpServer compile
on VxWorks where localserver is disabled.

Fixes: QTBUG-132517
Pick-to: 6.9
Change-Id: Icc5ea506ebc2e34249d5ed6416080ad96814f332
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
Reviewed-by: Lena Biliaieva <lena.biliaieva@qt.io>
2025-01-14 17:15:13 +01:00
Ivan Solovev 2dadae11ec Do not export QHttpServerConfiguration wholesale
This is a non-polymorphic class, so explicitly export only the
out-of-line methods.

Amends c43b2f7a84.

Found in Qt 6.9 API review.

Pick-to: 6.9
Change-Id: I028478c491513bb4b9e79c959812f7842c927043
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
Reviewed-by: Lena Biliaieva <lena.biliaieva@qt.io>
2025-01-14 16:03:09 +01:00
Volker Hilsheimer 1b007190ee QHttpServerConfiguration: use comparison operator macro
to implement operator==/!= the idiomatic way.

Addresses header-review comment, amends
c43b2f7a84

Pick-to: 6.9
Task-number: QTBUG-132090
Change-Id: I81473494c6c4c7b54c136580659db731c7e8bea0
Reviewed-by: Ivan Solovev <ivan.solovev@qt.io>
Reviewed-by: Lena Biliaieva <lena.biliaieva@qt.io>
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
2025-01-14 09:49:06 +01:00
Timur Pocheptsov ac66fc9a48 httpabstractserver: do not block when accessing a keychain
Similar to httpserver test.

Task-number: QTBUG-130500
Pick-to: 6.8 6.9
Change-Id: I3597d982c523980745fb6f08659c39a17a317780
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
Reviewed-by: Jesus Fernandez <jsfdez@gmail.com>
2025-01-07 11:13:35 +01:00
Timur Pocheptsov 89546a6a1e httpserver (multithreaded) do not block the test on keychain access
Similar to httpserver.

Task-number: QTBUG-130500
Pick-to: 6.9 6.8
Change-Id: Ia93c03db5ee4f7c549a37c60db639bc7f47b8c9b
Reviewed-by: Jesus Fernandez <jsfdez@gmail.com>
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
2025-01-07 11:13:33 +01:00
Qt Submodule Update Bot 160b37bdad Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Iff768af7ad6b6033f573428d60f2a9f5d97bc1d0
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-01-03 15:19:01 +00:00
Jani Heikkinen 47b365fc6f Bump version to 6.10.0
Change-Id: I117be0f5cf2e4797b2aa39bbe287447bd9348445
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2025-01-03 15:19:00 +00:00
Qt Submodule Update Bot b3dddd1f6b Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I89714d16fdab2e7f599602ade5ae7739dd8581c5
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-12-08 17:26:42 +00:00
Qt Submodule Update Bot c9447eb04d Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I8dbb7645e3a518ffcaab32f2038796dda5809412
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-12-08 04:11:29 +00:00
Lena Biliaieva c43b2f7a84 Add request rate limiting for QHttpServer
Added QHttpServerConfiguration class to pass general configuration
settings to QHttpServer.
Implemented request rate limiting per IP.

Task-number: QTBUG-75087
Change-Id: Iedd670d3cd9adddec22077fe0625fdd3fc818004
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2024-12-05 17:48:25 +01:00
Qt Submodule Update Bot 45c60e30e0 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Idd95be77cad5ac71b1d64e3f8936a9f2ce6fff5c
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-12-03 14:32:12 +00:00
Qt Submodule Update Bot 466953b0fa Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ia49bdaddd291ec0629bbeda65d85ec228bfe6245
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-12-02 18:22:41 +00:00
Qt Submodule Update Bot 154de75542 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I4534bffaae0b6184261fb00f75cf5c376c7c4b43
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-28 13:01:58 +00:00
Qt Submodule Update Bot 4f9e275f2b Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ic1da5b13b599fe9a5c4e43c0baf9423343753501
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-26 16:00:04 +00:00
Qt Submodule Update Bot 68f807f1e6 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I39a5ade746812c66811eaec8cec1e1004c021c48
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-25 23:01:15 +00:00
Qt Submodule Update Bot 24dde1052f Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I14b467511df6067d2432a8221f7a5a155e938408
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-19 21:11:36 +00:00
Qt Submodule Update Bot 8f815cca03 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ie41a8ba44f7315c71a6aa349d9c9bd4afc9235b7
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-07 05:53:01 +00:00
Lucie Gérard 20bc59ea1a Add REUSE.toml files and missing licenses
REUSE.toml files are read by reuse to complement or override the
copyright and licensing information found in file.

The use of REUSE.toml files was introduced in REUSE version 3.1.0a1.
This reuse version is compatible with reuse specification
version 3.2 [1].
With this commit's files,
* The SPDX document generated by reuse spdx conforms to SPDX 2.3,
* The reuse lint command reports that the Qt project is reuse compliant.

In order to be reuse compliant all the licenses present in the
LICENSES directory must be used. License files not used are removed.

[1]: https://reuse.software/spec-3.2/

Task-number: QTBUG-124453
Task-number: QTBUG-125211
Pick-to: 6.8
Change-Id: I1fde341f07c48dbfb733d7be0969462b1110312b
Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
2024-11-06 14:06:33 +01:00
Qt Submodule Update Bot 55fce1c132 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ieb1fd19e6b5e324dabcde2381fafcaab10d6d26b
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-06 12:28:12 +00:00
Qt Submodule Update Bot a1cbe652bc Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I0d60f98efdffdbd045e7d97758da6c3c7d771032
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-11-01 18:42:30 +00:00
Qt Submodule Update Bot 4d1c30716a Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ie5514210fd071755076ba0ee05a6933cc041c472
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-10-30 21:07:15 +00:00
Timur Pocheptsov fbfc0ab8d8 tst_qhttpserver: do not block the test with keychain access dialog
Our approach with a temporary keychain stopped working on macOS 15,
where we fortunately have a new option when importing a PKCS12 blob.
But it is possible to build using SDK 14 and then run on macOS 15,
where our trick would fail. In this case, skip the test/SSL usage.

Task-number: QTBUG-130500
Pick-to: 6.8
Change-Id: Iebe31d2d6affa686ccb4287cd80c2c5683cc787a
Reviewed-by: Timur Pocheptsov <timur.pocheptsov@qt.io>
2024-10-26 07:50:23 +02:00
Tor Arne Vestbø 4482206a08 Blacklist tst_QHttpServer::pipelinedRequests on macOS 15
Task-number: QTBUG-130500
Change-Id: I457922a59fd90a05d2bbfab31dc6a913f03e6fa1
Reviewed-by: Timur Pocheptsov <timur.pocheptsov@qt.io>
2024-10-24 09:48:36 +02:00
Qt Submodule Update Bot 24053616c8 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I065d9e1877d9a91879176992ab460ea2a2322f0c
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-10-23 07:07:43 +00:00
Carl Schwan a46107febd Fix documentation of addAfterRequestHandler
The parameters were inversed in the example.

Pick-to: 6.8
Change-Id: Ida84993f27d3fcfabc05a9b8f10ba1340b144d1c
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2024-10-22 13:52:14 +00:00
Øystein Heskestad adf5c78896 QAbstractHttpServer: Fix two-way communication for WebSockets
WebSockets were successfully created but worked only from server to
client. Fix hand-over from QAbstractHttpServer to member object
QWebSocketServer. Add test to ensure that WebSockets work both
ways.

Fixes: QTBUG-129798
Pick-to: 6.8
Change-Id: If9bd2a42d398f157384added8787c009246f6c52
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2024-10-18 18:15:06 +02:00
Mårten Nordheim 8baaac9617 tst_qabstracthttpserver: Create stream before waiting for SETTINGS
Because of changes we are doing in QHttp2Connection it won't work otherwise.

Change-Id: Idf8b08a15c2b36742a6c865fc4d04054c6aaefa0
Reviewed-by: Matthias Rauter <matthias.rauter@qt.io>
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
2024-10-18 11:47:01 +02:00
Yuri Knigavko e7c4bb0f4f Fix memory leaks in test code of tst_qabstracthttpserver
Create QTcpServer objects in stack rather than in the heap to simplify memory ownership.
Normally QTcpServer created in the heap is not leaking, because it becomes a child of QAbstractHttpServer in QAbstractHttpServer.bind(). However parenting does not happen if bind() fails. So QTcpServer objects were leaking in tests where bind() was supposed to fail.
As the simplest fix, it was decided to create those QTcpServer objects in the stack.

Change-Id: I19788dff4c55deacf242be03871512c9c86296de
Reviewed-by: Mate Barany <mate.barany@qt.io>
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
2024-10-11 16:17:32 +02:00
Topi Reinio d124fe9786 Doc: Remove Technology Preview status
Qt HTTP Server is out of technology preview in Qt 6.8.0.

Task-number: QTBUG-129773
Pick-to: 6.8
Change-Id: I2dc7ea1d4c90800f3bace9497370632bea690085
Reviewed-by: Jesus Fernandez <jsfdez@gmail.com>
Reviewed-by: Paul Wicking <paul.wicking@qt.io>
2024-10-09 09:27:17 +00:00
Qt Submodule Update Bot ec342c6de7 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I4b81bfdfe367104c1b35a3c514156cdbbc9521d6
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-27 07:33:27 +00:00
Volker Hilsheimer a4b22aa7da Fix warning from unused variable
The sslPort variable is only used when SSL is available, which is
usually not the case on macOS builds.

Pick-to: 6.8
Change-Id: I6f8c023c2a85e5a3c74d737903cb994c690451a3
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
2024-09-26 16:15:07 +02:00
Qt Submodule Update Bot 182fd4f888 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Icab5156829b1be2a6a9de3ddf38c37c665f8fc2a
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-25 05:02:49 +00:00
Qt Submodule Update Bot 255a8c7e08 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Icd92e933448d325b888185b20279e954ea85cea3
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-23 18:58:01 +00:00
Qt Submodule Update Bot fe5d4a20e1 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: I59f61f0fb59dfe15da0a0f92fa646e42db45c5e3
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-20 17:50:48 +00:00
Mårten Nordheim 6e7b76131a Fix assert message
It's out-dated now, still referring to rvalue refs

Pick-to: 6.8 6.8.0
Change-Id: I07b7b098cc2d261908c4c8b115f3d19c74468e39
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
2024-09-18 18:37:04 +00:00
Mårten Nordheim 2c2dc9e15c Add a benchmark for QHttpServer
It's quite simple, we just download a 100MB payload from ourselves and
discard all the bytes.

The default qbytearray non-TLS case takes around 250ms to complete on my
machine, while the TLS case clocks in at around 800ms.

Some of this benchmark will measure the time it takes to read as well,
but even using an external process to perform the download we would
still have to wait for it to receive all the data.

Pick-to: 6.8
Change-Id: I0fb700b2f3ab5d73a81f673688ec9404a6749daa
Reviewed-by: Mate Barany <mate.barany@qt.io>
2024-09-12 21:22:02 +02:00
Mårten Nordheim 2ff6b4b8ae IOChunkedTransfer: avoid going back to the event loop
By looping in readFromInput() we can pass as much data as possible
to the `sink` without having to return to the event loop repeatedly.

And, in writeToOutput(), if we exhaust the buffer, just call
readFromInput() directly instead of queuing a meta call.

Because readFromInput() _also_ calls writeToOutput() when there is data
to write we now have to check for recursion before calling
readFromInput().

This cuts the time tst_bench_QHttpServer_transfer::transferPayload()
takes with the "qbuffer" data-tag from 2s to 0.5s on my machine.

Task-number: QTBUG-125717
Pick-to: 6.8
Change-Id: I5f7255ca3f68b414d2ca73dd377893b04fe13247
Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
2024-09-12 14:00:10 +02:00
Mårten Nordheim b63114a3b1 IOChunkedTransfer: Don't write to the sink if there is data pending
There are already mechanisms in place to try to write more when the sink
has managed to flush data into the OS buffers, so we can pace ourselves
better.

This reduces the amount of copying we do since we no longer, needlessly,
copy data into the sink's (pending) write-buffer. This brings memory
usage for transferring a large payload down to a more expected range.

Task-number: QTBUG-125717
Pick-to: 6.8
Change-Id: I38460cb5fa143dddb00c964c4da7c4b62d9628c4
Reviewed-by: Mate Barany <mate.barany@qt.io>
2024-09-12 13:59:23 +02:00
Mårten Nordheim 1e27b53dd5 IOChunkedTransfer: Connect to encryptedBytesWritten signal for TLS
With a QSslSocket the bytesWritten signal is not what we are actually
interested in, so much as the encryptedBytesWritten signal.

Task-number: QTBUG-125717
Pick-to: 6.8
Change-Id: If9eba53a2c1f321048fef4554fa0e172566efdf3
Reviewed-by: Lena Biliaieva <lena.biliaieva@qt.io>
Reviewed-by: Mate Barany <mate.barany@qt.io>
Reviewed-by: Øystein Heskestad <oystein.heskestad@qt.io>
2024-09-12 13:59:18 +02:00
Qt Submodule Update Bot e49c7e7567 Update dependencies on 'dev' in qt/qthttpserver
Change-Id: Ia365801dfcd999b94c35d82a29ff1a094691ab59
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-11 07:59:16 +00:00
Qt Submodule Update Bot a6ac9995df Update dependencies on 'dev' in qt/qthttpserver
Change-Id: If5b6d9466537f7a30e19b929fa7138133833d49c
Reviewed-by: Qt Submodule Update Bot <qt_submodule_update_bot@qt-project.org>
2024-09-05 05:49:13 +00:00