Compare commits

..

608 Commits

Author SHA1 Message Date
Łukasz Domeradzki
0467dc1da3 Make trade message disappear for all non-steam appids 2025-07-19 14:36:03 +02:00
Łukasz Domeradzki
d81e8d2de0 Bump 2025-07-19 13:22:05 +02:00
Łukasz Domeradzki
ec59e2e556 Add support for new trade messages acknowledge 2025-07-18 09:52:31 +02:00
ArchiBot
cfdb8c06f3 Automatic translations update 2025-07-18 02:35:51 +00:00
Łukasz Domeradzki
32bf5cd0a7 Bump 2025-07-17 13:45:20 +02:00
Łukasz Domeradzki
a0401a3962 Improve efficiency of MatchActively
Trade hold duration check made sense, but back when we were fetching inventories ourselves. Now, it's much better to find match first, as we have the full data loaded, and only if match is found, check user next.
2025-07-17 13:40:35 +02:00
renovate[bot]
4def44ed1e chore(deps): update dependency scalar.aspnetcore to 2.6.3 2025-07-17 03:52:21 +00:00
ArchiBot
bd472b68a1 Automatic translations update 2025-07-17 02:34:52 +00:00
renovate[bot]
142bac7275 chore(deps): update asf-ui digest to 1d94b49 2025-07-16 04:44:45 +00:00
ArchiBot
80d4ab1dea Automatic translations update 2025-07-16 02:34:20 +00:00
Outzzz
481c995481 new confirmation type (#3442) 2025-07-15 18:56:19 +02:00
ArchiBot
76e3059b34 Automatic translations update 2025-07-14 02:36:38 +00:00
renovate[bot]
9c6157563e chore(deps): update dependency scalar.aspnetcore to 2.6.1 2025-07-13 18:02:53 +00:00
renovate[bot]
c362900290 chore(deps): update asf-ui digest to 0822736 2025-07-12 03:10:35 +00:00
ArchiBot
1573707d39 Automatic translations update 2025-07-12 02:33:47 +00:00
ArchiBot
acce592f02 Automatic translations update 2025-07-11 02:34:06 +00:00
renovate[bot]
24cc03e4ed chore(deps): update asf-ui digest to 75cb11d 2025-07-10 22:00:47 +00:00
renovate[bot]
aec1f45023 chore(deps): update dependency scalar.aspnetcore to 2.6.0 2025-07-10 18:01:49 +00:00
renovate[bot]
e208a3cce0 chore(deps): update crowdin/github-action action to v2.9.0 2025-07-10 11:33:24 +00:00
ArchiBot
2f275e19bd Automatic translations update 2025-07-10 02:32:36 +00:00
renovate[bot]
ac8f12f438 chore(deps): update asf-ui digest to 7a782d7 2025-07-09 23:58:29 +00:00
renovate[bot]
c14580965f chore(deps): update wiki digest to c122ded 2025-07-09 17:02:47 +00:00
renovate[bot]
436a5ab3f9 chore(deps): update dotnet monorepo to 9.0.7 2025-07-09 04:24:15 +00:00
ArchiBot
3e1fde4515 Automatic translations update 2025-07-09 02:31:52 +00:00
renovate[bot]
9beec69e85 chore(deps): update asf-ui digest to 5c24f54 2025-07-08 05:00:15 +00:00
ArchiBot
a1116a87df Automatic translations update 2025-07-08 02:31:32 +00:00
renovate[bot]
cd4bc01d66 chore(deps): update dependency scalar.aspnetcore to 2.5.6 2025-07-07 20:07:16 +00:00
renovate[bot]
7e30601246 chore(deps): update wiki digest to 70b21c1 2025-07-07 13:06:35 +00:00
ArchiBot
708b3792c9 Automatic translations update 2025-07-07 02:34:03 +00:00
renovate[bot]
3c52408579 chore(deps): update wiki digest to f30f4d5 2025-07-06 12:35:34 +00:00
ArchiBot
ea5f729d58 Automatic translations update 2025-07-06 02:36:06 +00:00
renovate[bot]
4d3f7f0b5a chore(deps): update wiki digest to 522bba8 2025-07-05 14:26:30 +00:00
Łukasz Domeradzki
078f6eabdd Bump 2025-07-05 16:25:46 +02:00
Łukasz Domeradzki
6d6da98e8c Bump 2025-07-05 16:05:31 +02:00
renovate[bot]
49f1910425 chore(deps): update dependency nlog.web.aspnetcore to 6.0.1 2025-07-05 13:40:07 +00:00
renovate[bot]
4ba034f988 chore(deps): update dependency nlog.web.aspnetcore to v6 (#3438)
* chore(deps): update dependency nlog.web.aspnetcore to v6

* Adapt ASF to NLog v6

* Use another approach for NLog file archiving

* Use cached ${currentdir} to improve performance

* Misc fix

* Update suffix format

* Misc

---------

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Łukasz Domeradzki <JustArchi@JustArchi.net>
2025-07-05 15:39:37 +02:00
ArchiBot
e93ea74def Automatic translations update 2025-07-05 02:26:37 +00:00
Łukasz Domeradzki
5dadbe9090 Allow plugins to initialize new configs with some changed properties 2025-07-03 13:12:10 +02:00
renovate[bot]
e3c1a8c5fb chore(deps): update asf-ui digest to 545f9e1 2025-07-02 23:39:29 +00:00
Łukasz Domeradzki
8e50e9553a Misc fix 2025-07-02 16:55:09 +02:00
Łukasz Domeradzki
ed47c8268b Add optional cookies to WebAPI base 2025-07-02 08:57:44 +02:00
Łukasz Domeradzki
e0cdeaf09e Bump 2025-07-01 16:14:16 +02:00
Łukasz Domeradzki
fc198d6eae Update MaxItemsInSingleInventoryRequest 2025-07-01 16:13:47 +02:00
ArchiBot
977816baa9 Automatic translations update 2025-07-01 02:37:39 +00:00
renovate[bot]
758c0a0385 chore(deps): update asf-ui digest to b984a9d 2025-06-30 07:31:35 +00:00
ArchiBot
e4d7e9dda7 Automatic translations update 2025-06-30 02:33:41 +00:00
renovate[bot]
baadfee9e0 chore(deps): update ncipollo/release-action action to v1.18.0 2025-06-29 21:11:10 +00:00
renovate[bot]
25620603b5 chore(deps): update ncipollo/release-action action to v1.17.0 2025-06-29 06:24:51 +00:00
ArchiBot
a5e306ccae Automatic translations update 2025-06-29 02:36:53 +00:00
Łukasz Domeradzki
e09801442e Bump 2025-06-28 13:11:58 +02:00
Łukasz Domeradzki
08fb3ccb76 Fix serializable files not always getting written on change
In some cases, STJ might decide to replace the object rather than populating it. This will work for majority of properties and use cases, however, we actually set up events on some properties to notify us back if they change during runtime. That event registration did not work properly, as the object was replaced with the new, that did not have appropriate listeners set up.

Populate rather than replacing those selected properties, which fixes the problem.
2025-06-28 13:10:13 +02:00
ArchiBot
e9887cf89e Automatic translations update 2025-06-28 02:26:50 +00:00
renovate[bot]
de33bd057f chore(deps): update asf-ui digest to 49b98a8 2025-06-27 04:14:17 +00:00
ArchiBot
e04d37a694 Automatic translations update 2025-06-27 02:29:29 +00:00
renovate[bot]
6e7a1ea09b chore(deps): update dependency scalar.aspnetcore to 2.5.3 2025-06-26 16:37:37 +00:00
Łukasz Domeradzki
08b2c3186d Misc 2025-06-26 14:23:12 +02:00
renovate[bot]
6ca3989635 chore(deps): update dependency scalar.aspnetcore to 2.5.1 2025-06-26 02:58:11 +00:00
ArchiBot
c3019bed16 Automatic translations update 2025-06-26 02:29:26 +00:00
renovate[bot]
7f5615d109 chore(deps): update asf-ui digest to 220a8ec 2025-06-25 18:05:14 +00:00
renovate[bot]
43c76dc1af chore(deps): update crowdin/github-action action to v2.8.0 2025-06-25 07:11:07 +00:00
renovate[bot]
89deff7e06 chore(deps): update dependency markdig.signed to 0.41.3 2025-06-24 11:03:02 +00:00
ArchiBot
d536f7f56c Automatic translations update 2025-06-24 02:29:43 +00:00
renovate[bot]
8f43575a19 chore(deps): pin dependencies (#3439)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-06-22 17:46:37 +02:00
Łukasz Domeradzki
53adc67be1 Misc 2025-06-22 17:46:18 +02:00
Łukasz Domeradzki
e4addcadc8 Update renovate.json5 2025-06-22 16:23:21 +02:00
Łukasz Domeradzki
c48c1e6acd Kill build environment
It causes only unnecessary spam in PRs, the other environments still make sense
2025-06-22 15:47:17 +02:00
ArchiBot
cd2baa25c8 Automatic translations update 2025-06-22 02:35:38 +00:00
renovate[bot]
93e19d0f82 chore(deps): update dependency scalar.aspnetcore to 2.5.0 2025-06-21 17:53:08 +00:00
renovate[bot]
a8527dee70 chore(deps): update asf-ui digest to 622b78e 2025-06-21 10:10:38 +00:00
ArchiBot
b209be1618 Automatic translations update 2025-06-21 02:26:29 +00:00
renovate[bot]
fa55d9f402 chore(deps): update wiki digest to fb78823 2025-06-20 19:56:55 +00:00
renovate[bot]
c1aeb0b0a1 chore(deps): update dependency scalar.aspnetcore to 2.4.22 2025-06-19 22:56:09 +00:00
Łukasz Domeradzki
6e2bd99600 Bump 2025-06-20 00:55:39 +02:00
Jack Nolddor
a99c1f93e1 chore: blacklist summer sale 2025 appid (#3437) 2025-06-20 00:54:11 +02:00
ArchiBot
abc2e2be69 Automatic translations update 2025-06-19 02:28:53 +00:00
renovate[bot]
7aff1f857b chore(deps): update docker/setup-buildx-action action to v3.11.1 2025-06-18 11:50:02 +00:00
renovate[bot]
e47a94aeaa chore(deps): update dependency scalar.aspnetcore to 2.4.19 2025-06-18 02:34:15 +00:00
renovate[bot]
12730e6cb5 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.12.1 2025-06-17 23:46:43 +00:00
renovate[bot]
9909a211a4 chore(deps): update dependency mstest to 3.9.3 2025-06-17 16:53:55 +00:00
renovate[bot]
32591514de chore(deps): update dependency system.linq.async to 6.0.3 2025-06-17 03:14:00 +00:00
ArchiBot
05f65e0d9d Automatic translations update 2025-06-17 02:29:31 +00:00
renovate[bot]
353b032efd chore(deps): update dependency scalar.aspnetcore to 2.4.17 2025-06-16 20:08:55 +00:00
renovate[bot]
fb16a9e50c chore(deps): update docker/setup-buildx-action action to v3.11.0 2025-06-16 16:08:38 +00:00
ArchiBot
32165af41d Automatic translations update 2025-06-15 02:35:26 +00:00
renovate[bot]
3860d8d2fc chore(deps): update asf-ui digest to 6a9af77 2025-06-14 19:20:54 +00:00
Łukasz Domeradzki
dd6a8cdb80 Bump 2025-06-14 21:19:36 +02:00
Łukasz Domeradzki
27562e52ef Respect LastAnnouncement fully in public listing
I don't recall why we needed that ShouldSendHeartBeats condition here before, it causes the routine to run always if the bot is currently not listed, which is unwanted e.g. if the server tells user to go away, or due to any other reason.
2025-06-14 21:10:00 +02:00
renovate[bot]
693c9d67dc chore(deps): update dependency scalar.aspnetcore to 2.4.16 2025-06-14 09:50:47 +00:00
renovate[bot]
71cd68d38f chore(deps): update asf-ui digest to ecaf0d8 2025-06-14 06:15:43 +00:00
ArchiBot
624283cee7 Automatic translations update 2025-06-14 02:26:04 +00:00
renovate[bot]
0bf9d2f040 chore(deps): update dependency scalar.aspnetcore to 2.4.15 2025-06-13 21:38:40 +00:00
renovate[bot]
c01d893b6b chore(deps): update dependency scalar.aspnetcore to 2.4.14 2025-06-13 15:54:48 +00:00
renovate[bot]
3b9d5c7ab6 chore(deps): update wiki digest to 4dd4924 2025-06-13 12:00:30 +00:00
Łukasz Domeradzki
05d5d90e3e Bump 2025-06-13 13:59:41 +02:00
Łukasz Domeradzki
53b84a9271 Closes #3436 2025-06-13 13:41:36 +02:00
Łukasz Domeradzki
44688a4ce8 Misc 2025-06-13 09:44:18 +02:00
ArchiBot
908f7f5ccb Automatic translations update 2025-06-13 02:29:04 +00:00
Łukasz Domeradzki
79c3ce14e8 Misc 2025-06-12 23:33:47 +02:00
ArchiBot
d8d0b1deb8 Automatic translations update 2025-06-12 02:28:23 +00:00
renovate[bot]
22b9f92663 chore(deps): update actions/attest-build-provenance action to v2.4.0 2025-06-11 22:41:25 +00:00
renovate[bot]
0900480e62 chore(deps): update wiki digest to 6a30b79 2025-06-11 19:44:23 +00:00
renovate[bot]
6b41f91543 chore(deps): update dotnet monorepo to 9.0.6 2025-06-11 02:39:44 +00:00
ArchiBot
708de736e0 Automatic translations update 2025-06-11 02:28:49 +00:00
renovate[bot]
816b23e277 chore(deps): update dependency mstest to 3.9.2 2025-06-10 17:29:17 +00:00
renovate[bot]
b1e472879f chore(deps): update asf-ui digest to ec7099f 2025-06-10 09:26:25 +00:00
Łukasz Domeradzki
714f734e58 Bump 2025-06-10 11:25:30 +02:00
Łukasz Domeradzki
4f279f1068 Misc 2025-06-10 11:19:20 +02:00
Łukasz Domeradzki
e2194894ce Reset temporary account credentials upon turning off bot for wrong ones 2025-06-10 11:07:37 +02:00
ArchiBot
6bfc7d5c7f Automatic translations update 2025-06-10 02:29:39 +00:00
Łukasz Domeradzki
0018da8f8e Bump 2025-06-09 21:38:58 +02:00
renovate[bot]
a4ddac5039 chore(deps): update dependency steamkit2 to 3.3.0 (#3435)
* chore(deps): update dependency steamkit2 to 3.3.0

* Adapt to SK2 breaking changes

---------

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Łukasz Domeradzki <JustArchi@JustArchi.net>
2025-06-09 21:34:16 +02:00
ArchiBot
839bc06f88 Automatic translations update 2025-06-09 02:31:55 +00:00
Łukasz Domeradzki
2a1228c949 Bump 2025-06-09 00:23:01 +02:00
Łukasz Domeradzki
921d56a13d Bump 2025-06-09 00:15:16 +02:00
Łukasz Domeradzki
9fa1549e09 Closes #3434 2025-06-09 00:05:58 +02:00
ArchiBot
e0d19e256f Automatic translations update 2025-06-08 02:34:31 +00:00
renovate[bot]
18e8bf56e6 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.12.0 2025-06-07 18:52:25 +00:00
renovate[bot]
83500b7af5 chore(deps): update dependency scalar.aspnetcore to 2.4.13 2025-06-07 12:49:10 +00:00
renovate[bot]
548e8af27b chore(deps): update crowdin/github-action action to v2.7.1 2025-06-07 09:47:16 +00:00
renovate[bot]
54afced00a chore(deps): update asf-ui digest to 2526417 2025-06-07 05:05:49 +00:00
ArchiBot
b89967ecac Automatic translations update 2025-06-07 02:26:38 +00:00
renovate[bot]
130a25deaa chore(deps): update wiki digest to 5ef3932 2025-06-06 22:02:59 +00:00
ArchiBot
bc52dad3f5 Automatic translations update 2025-06-06 02:27:28 +00:00
renovate[bot]
4ce75e3ab0 chore(deps): update dependency markdig.signed to 0.41.2 2025-06-05 11:01:51 +00:00
renovate[bot]
a681b31630 chore(deps): update dependency scalar.aspnetcore to 2.4.8 2025-06-05 04:46:49 +00:00
ArchiBot
9777e87b0f Automatic translations update 2025-06-05 02:27:57 +00:00
renovate[bot]
8647201b1e chore(deps): update asf-ui digest to c0e3f38 2025-06-04 22:12:31 +00:00
Łukasz Domeradzki
543d3f2f85 Bump 2025-06-05 00:11:50 +02:00
Łukasz Domeradzki
0cd02d8de8 Misc chat ack improvements 2025-06-05 00:11:33 +02:00
ArchiBot
e93a486a85 Automatic translations update 2025-06-04 02:29:00 +00:00
ArchiBot
2225903719 Automatic translations update 2025-06-03 02:28:32 +00:00
ArchiBot
a854ba3ddf Automatic translations update 2025-06-02 02:30:53 +00:00
renovate[bot]
bededf4bec chore(deps): update asf-ui digest to e90f82b 2025-05-31 09:36:33 +00:00
ArchiBot
2fcb35e46c Automatic translations update 2025-05-31 02:24:32 +00:00
renovate[bot]
120509a02e chore(deps): update dependency scalar.aspnetcore to 2.4.7 2025-05-30 19:50:18 +00:00
renovate[bot]
6aca3ea0cc chore(deps): update dependency scalar.aspnetcore to 2.4.6 2025-05-30 11:50:30 +00:00
renovate[bot]
93ab09f6c5 chore(deps): update dependency scalar.aspnetcore to 2.4.5 2025-05-29 21:34:12 +00:00
Łukasz Domeradzki
c9fe2eb1d5 Bump 2025-05-29 23:33:36 +02:00
Łukasz Domeradzki
5d4666d538 Adapt to yet another Steam's breaking change 2025-05-29 23:29:40 +02:00
renovate[bot]
44549e2b2a chore(deps): update dependency nlog.web.aspnetcore to 5.5.0 (#3429)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-05-29 21:38:13 +02:00
ArchiBot
b20f8adb5f Automatic translations update 2025-05-29 02:26:58 +00:00
renovate[bot]
0983ef309f chore(deps): update docker/build-push-action action to v6.18.0 2025-05-28 08:44:36 +00:00
renovate[bot]
8a24c037ed chore(deps): update dependency scalar.aspnetcore to 2.4.4 2025-05-28 03:29:38 +00:00
renovate[bot]
dad1d7fda9 chore(deps): update asf-ui digest to 9920764 2025-05-27 23:04:44 +00:00
renovate[bot]
cce7c1c7c8 chore(deps): update dependency mstest to 3.9.1 2025-05-27 16:45:59 +00:00
ArchiBot
ac209cfefb Automatic translations update 2025-05-27 02:25:49 +00:00
Łukasz Domeradzki
62e9058966 Bump 2025-05-25 19:21:24 +02:00
Łukasz Domeradzki
21a202e47d Misc 2025-05-25 19:18:36 +02:00
Łukasz Domeradzki
274c63c166 Log less info about failing request by default
Some URLs can expose potentially-sensitive details otherwise, such as GetTradeOffers
2025-05-25 19:15:58 +02:00
ArchiBot
207d10c2be Automatic translations update 2025-05-25 02:32:04 +00:00
Łukasz Domeradzki
9dc220e0d5 Bump 2025-05-24 21:50:14 +02:00
Łukasz Domeradzki
73f0cf23f8 Add workaround for 429 in trade offers 2025-05-24 21:49:45 +02:00
Łukasz Domeradzki
0b24380b2e Improve logging of api calls 2025-05-24 18:51:51 +02:00
Łukasz Domeradzki
ff485845bf Log less info about failing request by default
Some URLs can expose potentially-sensitive details otherwise, such as GetTradeOffers
2025-05-24 18:33:23 +02:00
ArchiBot
198e408ba4 Automatic translations update 2025-05-24 02:23:52 +00:00
renovate[bot]
2f5f4661c2 chore(deps): update dependency scalar.aspnetcore to 2.4.3 2025-05-23 22:45:17 +00:00
renovate[bot]
430dad82db chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.11.0 2025-05-23 18:27:09 +00:00
renovate[bot]
9fce02c2ef chore(deps): update dependency scalar.aspnetcore to 2.4.2 2025-05-23 02:53:14 +00:00
ArchiBot
9d2d7e33e3 Automatic translations update 2025-05-23 02:26:27 +00:00
renovate[bot]
fc390e0b4c chore(deps): update wiki digest to 9d8da2b 2025-05-22 16:52:03 +00:00
Łukasz Domeradzki
2d3fbf3080 Bump 2025-05-22 13:49:52 +02:00
Łukasz Domeradzki
b7152bfb0a Closes #3428 2025-05-22 13:46:19 +02:00
renovate[bot]
b3f216d25d chore(deps): update dependency scalar.aspnetcore to 2.4.1 2025-05-22 07:51:36 +00:00
ArchiBot
1caa12c7e8 Automatic translations update 2025-05-22 02:25:48 +00:00
renovate[bot]
94e3a9a5f8 chore(deps): update asf-ui digest to 30223b6 2025-05-20 23:32:22 +00:00
renovate[bot]
9cf20708e6 chore(deps): update dependency mstest to 3.9.0 2025-05-20 12:52:58 +00:00
ArchiBot
c60b7b0252 Automatic translations update 2025-05-20 02:26:56 +00:00
ArchiBot
3477bcefc3 Automatic translations update 2025-05-19 02:29:36 +00:00
ArchiBot
549a76ee7e Automatic translations update 2025-05-18 02:30:19 +00:00
renovate[bot]
6c32cebe83 chore(deps): update wiki digest to 2cd6a9f 2025-05-17 18:31:15 +00:00
renovate[bot]
d30d4d202a chore(deps): update asf-ui digest to 9eee3d3 2025-05-16 11:19:02 +00:00
renovate[bot]
d545622d0c chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.10.0 2025-05-16 02:44:52 +00:00
renovate[bot]
f33016d523 chore(deps): update dependency scalar.aspnetcore to 2.3.1 2025-05-15 23:53:22 +00:00
renovate[bot]
8a531262e7 chore(deps): update docker/build-push-action action to v6.17.0 2025-05-15 18:52:16 +00:00
ArchiBot
cf0dd510c2 Automatic translations update 2025-05-15 02:24:28 +00:00
renovate[bot]
d735d1bda8 chore(deps): update dotnet monorepo 2025-05-14 02:54:23 +00:00
ArchiBot
e4dc83fc86 Automatic translations update 2025-05-14 02:25:22 +00:00
renovate[bot]
13263a8d1e chore(deps): update asf-ui digest to 0b5af7a 2025-05-13 07:05:57 +00:00
renovate[bot]
3e06b5f8c8 chore(deps): update dependency scalar.aspnetcore to 2.3.0 2025-05-13 03:08:45 +00:00
ArchiBot
857fc6a3c6 Automatic translations update 2025-05-13 02:26:39 +00:00
Łukasz Domeradzki
ad461e5b8c Misc 2025-05-12 21:51:06 +02:00
Łukasz Domeradzki
5464ef4353 Misc 2025-05-12 21:35:13 +02:00
Łukasz Domeradzki
e8f4737e81 Misc 2025-05-12 21:31:30 +02:00
Łukasz Domeradzki
1dcaf98774 Always update app change numbers 2025-05-12 10:14:54 +02:00
ArchiBot
e081267a9b Automatic translations update 2025-05-12 02:27:47 +00:00
Łukasz Domeradzki
6ec7f4609a Even further misc 2025-05-11 22:25:15 +02:00
Łukasz Domeradzki
0bef5ccfa9 Misc
Edge case if previously-store-only package suddenly pops up in license list (normally would fix itself only after 7 days)
2025-05-11 22:21:43 +02:00
Łukasz Domeradzki
512545b657 Bump 2025-05-11 21:45:16 +02:00
Łukasz Domeradzki
390d9ac57c Use LINQ chunks in STD 2025-05-11 21:42:00 +02:00
Łukasz Domeradzki
10abfb847f Closes #3415 (#3427)
* Closes #3415

* Misc

* Refresh tokens always for non-listed packages
2025-05-11 21:36:16 +02:00
renovate[bot]
a19611c3ae chore(deps): update asf-ui digest to f2af2b8 2025-05-11 06:46:09 +00:00
ArchiBot
44840aa0ff Automatic translations update 2025-05-11 02:28:49 +00:00
ArchiBot
f0945efd3a Automatic translations update 2025-05-10 02:23:04 +00:00
Łukasz Domeradzki
cba29bb2c5 Resolve misc TODOs 2025-05-09 23:31:27 +02:00
ArchiBot
08c9636cd9 Automatic translations update 2025-05-09 02:24:46 +00:00
renovate[bot]
d940c4ac82 chore(deps): update asf-ui digest to 1205ace (#3425)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-05-08 12:41:38 +02:00
ArchiBot
208e844c97 Automatic translations update 2025-05-08 02:25:45 +00:00
renovate[bot]
9f808a42a3 chore(deps): update dependency humanizer to 3.0.0-beta.96 2025-05-07 21:58:53 +00:00
Łukasz Domeradzki
cf9a578815 Misc tests improvement 2025-05-07 23:58:11 +02:00
Łukasz Domeradzki
449f3556a7 Add extra unit test 2025-05-07 23:49:08 +02:00
Łukasz Domeradzki
a3736d6cd6 Misc optimization 2025-05-07 23:21:04 +02:00
Łukasz Domeradzki
f975af721e Misc 2025-05-07 23:18:41 +02:00
Łukasz Domeradzki
e23dfe7846 Be more strict with plugin asset names 2025-05-07 18:55:32 +02:00
renovate[bot]
255a72e2ae chore(deps): update asf-ui digest to afc4c5a 2025-05-07 03:42:36 +00:00
renovate[bot]
de3aa36b1f chore(deps): update opentelemetry-dotnet-contrib monorepo to 1.12.0 2025-05-05 19:33:15 +00:00
renovate[bot]
ea844f6501 chore(deps): update dependency scalar.aspnetcore to 2.2.7 2025-05-05 15:42:53 +00:00
ArchiBot
9bbdc5f8d9 Automatic translations update 2025-05-05 02:26:45 +00:00
Łukasz Domeradzki
0644e634e7 Bump 2025-05-05 00:49:37 +02:00
Łukasz Domeradzki
66774631e7 Closes #3424 2025-05-05 00:48:48 +02:00
ArchiBot
735982ce4e Automatic translations update 2025-05-03 02:23:17 +00:00
Łukasz Domeradzki
0c207b4e2f Make NowFarming property public 2025-05-02 23:49:34 +02:00
Łukasz Domeradzki
cf5d7fd192 Misc 2025-05-02 13:23:59 +02:00
Łukasz Domeradzki
a19aadd826 Bump 2025-05-02 12:59:21 +02:00
Łukasz Domeradzki
f62da0e273 Closes #3420 2025-05-02 12:56:54 +02:00
Łukasz Domeradzki
af6f9466a8 Misc 2025-05-02 09:27:24 +02:00
ArchiBot
2ee53d8318 Automatic translations update 2025-05-02 02:23:48 +00:00
Łukasz Domeradzki
b6a5989770 Misc 2025-05-01 23:54:03 +02:00
Łukasz Domeradzki
193811cb9b Add support for Japanese Steam client language 2025-05-01 23:50:07 +02:00
Łukasz Domeradzki
0c23177455 Bump 2025-05-01 21:23:05 +02:00
Łukasz Domeradzki
c525ca5642 Bump 2025-05-01 21:22:33 +02:00
renovate[bot]
e4a726672d chore(deps): update dependency scalar.aspnetcore to 2.2.5 2025-05-01 14:53:32 +00:00
renovate[bot]
a897615d0e chore(deps): update asf-ui digest to af94f76 2025-05-01 09:09:15 +00:00
Łukasz Domeradzki
3e5ffe10b7 Misc further improvements to cross-process semaphores 2025-05-01 10:14:23 +02:00
ArchiBot
13131c769c Automatic translations update 2025-05-01 02:29:48 +00:00
renovate[bot]
449050b6df chore(deps): update dependency opentelemetry.extensions.hosting to 1.12.0 2025-04-30 08:35:30 +00:00
renovate[bot]
01b5251a39 chore(deps): update dependency scalar.aspnetcore to 2.2.2 2025-04-30 04:02:17 +00:00
Łukasz Domeradzki
6b6c976061 Modernize access modes upon creation
We can make use of some newly introduced overloads, not only improving on performance but also fixing potential (impossible to achieve in practice) crash between creation and mode setting
2025-04-29 18:34:25 +02:00
Łukasz Domeradzki
eeed61a9f6 Avoid some extra overhead if www folder is not found 2025-04-29 16:24:22 +02:00
Łukasz Domeradzki
4afe7654af Misc
The execute permission is unnecessary on temporary files, only directories need it
2025-04-29 15:37:30 +02:00
renovate[bot]
acdd504a7c chore(deps): update actions/attest-build-provenance action to v2.3.0 2025-04-28 16:58:21 +00:00
renovate[bot]
65c9477bb9 chore(deps): update dependency markdig.signed to 0.41.1 2025-04-28 11:50:58 +00:00
ArchiBot
eaa11c76ab Automatic translations update 2025-04-27 02:26:09 +00:00
ArchiBot
2ba0eb77ad Automatic translations update 2025-04-26 02:22:25 +00:00
renovate[bot]
3761e07c6d chore(deps): update asf-ui digest to 7c49cd8 2025-04-25 23:31:21 +00:00
renovate[bot]
c787c8ece7 chore(deps): update docker/build-push-action action to v6.16.0 2025-04-25 19:27:04 +00:00
renovate[bot]
f8e8e2c8a4 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.9.0 2025-04-25 13:54:23 +00:00
renovate[bot]
3960ec16b4 chore(deps): update asf-ui digest to 5165da4 2025-04-25 07:26:01 +00:00
Łukasz Domeradzki
ddb04b97a8 Bump 2025-04-25 09:25:24 +02:00
ArchiBot
868d593c5c Automatic translations update 2025-04-25 02:23:51 +00:00
renovate[bot]
e6a5524cbc chore(deps): update actions/download-artifact action to v4.3.0 2025-04-24 16:54:03 +00:00
renovate[bot]
cf179878ae chore(deps): update dependency scalar.aspnetcore to 2.2.1 2025-04-24 02:53:43 +00:00
ArchiBot
394f10f384 Automatic translations update 2025-04-24 02:23:45 +00:00
renovate[bot]
df814b1acb chore(deps): update wiki digest to cb76466 2025-04-23 16:44:22 +00:00
renovate[bot]
b7439693fc chore(deps): update dependency scalar.aspnetcore to 2.1.18 2025-04-22 19:25:42 +00:00
renovate[bot]
c009fc8dc8 chore(deps): update asf-ui digest to 6f0393c 2025-04-22 13:10:44 +00:00
renovate[bot]
cf62c0802f chore(deps): update dependency steamkit2 to 3.1.0 2025-04-21 15:29:13 +00:00
renovate[bot]
5f19372429 chore(deps): update dependency anglesharp to 1.3.0 2025-04-19 01:52:51 +00:00
renovate[bot]
adf2eccc9c chore(deps): update dependency scalar.aspnetcore to 2.1.17 2025-04-18 23:31:32 +00:00
renovate[bot]
ce463bf780 chore(deps): update asf-ui digest to 992890b 2025-04-18 18:58:10 +00:00
renovate[bot]
31fe442476 chore(deps): update dependency scalar.aspnetcore to 2.1.16 2025-04-17 01:36:25 +00:00
renovate[bot]
45daa46cf9 chore(deps): update dependency scalar.aspnetcore to 2.1.15 2025-04-16 19:57:00 +00:00
ArchiBot
83c12f5636 Automatic translations update 2025-04-16 02:23:33 +00:00
renovate[bot]
1683729772 chore(deps): update dependency markdig.signed to 0.41.0 2025-04-15 11:44:30 +00:00
renovate[bot]
21cd3d8dbb chore(deps): update asf-ui digest to c4ddfac 2025-04-14 11:09:57 +00:00
renovate[bot]
4b34905358 chore(deps): update actions/setup-node action to v4.4.0 2025-04-14 07:30:15 +00:00
Łukasz Domeradzki
c0214f16fc Bump 2025-04-14 09:29:37 +02:00
Łukasz Domeradzki
458cb95422 Bump 2025-04-14 09:29:09 +02:00
Łukasz Domeradzki
ef844c168c Bump 2025-04-14 09:18:23 +02:00
Łukasz Domeradzki
96e5924c0c Misc bulletproofing 2025-04-14 09:17:52 +02:00
Outzzz
d20fa79897 get inventory with language (#3409)
* get inventory with language

* get inventory with language

* edit

* edit
2025-04-14 09:15:11 +02:00
renovate[bot]
f1a49cdff0 chore(deps): update dependency scalar.aspnetcore to 2.1.13 2025-04-11 22:01:40 +00:00
renovate[bot]
baa1339573 chore(deps): update dependency scalar.aspnetcore to 2.1.11 2025-04-11 02:24:16 +00:00
renovate[bot]
53802829b6 chore(deps): update dependency scalar.aspnetcore to 2.1.10 2025-04-10 18:53:30 +00:00
renovate[bot]
ee7866590f chore(deps): update dotnet monorepo to 9.0.4 2025-04-10 01:48:00 +00:00
renovate[bot]
94cb4e4e0a chore(deps): update dependency scalar.aspnetcore to 2.1.9 2025-04-09 22:33:44 +00:00
renovate[bot]
78e5ab2cbb chore(deps): update asf-ui digest to 6596a83 2025-04-09 16:37:01 +00:00
renovate[bot]
a52bf7774c chore(deps): update dependency scalar.aspnetcore to 2.1.8 2025-04-09 10:52:51 +00:00
renovate[bot]
4aed278f9c chore(deps): update dependency microsoft.codeanalysis.resxsourcegenerator to 3.11.0-beta1.25123.3 2025-04-09 07:37:20 +00:00
renovate[bot]
1631e1687b chore(deps): update asf-ui digest to e425aab 2025-04-09 03:19:38 +00:00
ArchiBot
4738171fd3 Automatic translations update 2025-04-09 02:23:30 +00:00
renovate[bot]
001eabe25d chore(deps): update asf-ui digest to fdcd3c3 2025-04-08 11:07:38 +00:00
renovate[bot]
3d535c4c72 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.8.0 2025-04-08 06:32:55 +00:00
renovate[bot]
f59a3ca233 chore(deps): update asf-ui digest to cda7dfa 2025-04-07 23:28:05 +00:00
renovate[bot]
d3134afc5a chore(deps): update dependency scalar.aspnetcore to 2.1.7 2025-04-07 20:02:29 +00:00
ArchiBot
39bf821f78 Automatic translations update 2025-04-07 02:23:52 +00:00
ArchiBot
5324dad0c6 Automatic translations update 2025-04-06 02:24:03 +00:00
renovate[bot]
ab92bbf3d3 chore(deps): update dependency scalar.aspnetcore to 2.1.6 2025-04-04 19:35:03 +00:00
renovate[bot]
63a481629e chore(deps): update asf-ui digest to e9c6a29 2025-04-04 06:36:58 +00:00
renovate[bot]
d44d075b20 chore(deps): update peter-evans/dockerhub-description action to v4.0.2 2025-04-03 16:06:11 +00:00
renovate[bot]
030d71c52a chore(deps): update asf-ui digest to a69ee58 2025-04-03 10:06:29 +00:00
renovate[bot]
2fe0a2635e chore(deps): update dependency scalar.aspnetcore to 2.1.5 2025-04-03 02:41:38 +00:00
ArchiBot
ae45f474e3 Automatic translations update 2025-04-03 02:22:55 +00:00
renovate[bot]
33e98a995e chore(deps): update crowdin/github-action action to v2.7.0 (#3404)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-04-02 09:21:24 +02:00
renovate[bot]
92b0e4bfb6 chore(deps): update asf-ui digest to 2771a20 (#3406)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-04-02 05:30:59 +00:00
ArchiBot
2403ac17dc Automatic translations update 2025-04-02 02:23:43 +00:00
ArchiBot
ca74047828 Automatic translations update 2025-04-01 08:23:24 +00:00
Łukasz Domeradzki
21e951092d Update translations.yml 2025-04-01 10:22:47 +02:00
renovate[bot]
3ba97b49ba chore(deps): update peter-evans/dockerhub-description action to v4.0.1 2025-04-01 03:16:02 +00:00
renovate[bot]
5e739e483e chore(deps): update dependency scalar.aspnetcore to 2.1.4 2025-03-31 23:41:00 +00:00
renovate[bot]
992a4563c2 chore(deps): update asf-ui digest to b0cf3f0 2025-03-31 18:26:47 +00:00
renovate[bot]
3e9e1cb6ed chore(deps): update wiki digest to 55469ee 2025-03-31 12:35:58 +00:00
Łukasz Domeradzki
61f876480a General code cleanups 2025-03-31 00:06:05 +02:00
Łukasz Domeradzki
c2b1d1356c Misc optimization 2025-03-30 21:12:24 +02:00
Łukasz Domeradzki
d5ac569a6a Bump 2025-03-30 21:06:57 +02:00
Łukasz Domeradzki
0b1ddd39d5 Optimize serializable file writes 2025-03-30 21:06:33 +02:00
renovate[bot]
cbe0502154 chore(deps): update asf-ui digest to c311378 2025-03-30 06:14:12 +00:00
renovate[bot]
816914dd10 chore(deps): update crazy-max/ghaction-import-gpg action to v6.3.0 2025-03-30 02:09:52 +00:00
renovate[bot]
bcb4320f5d chore(deps): update dependency scalar.aspnetcore to 2.1.3 2025-03-28 22:48:05 +00:00
renovate[bot]
bc4d5d37ff chore(deps): update asf-ui digest to c16acf5 2025-03-27 12:04:46 +00:00
renovate[bot]
1996763751 chore(deps): update dependency scalar.aspnetcore to 2.1.2 2025-03-26 18:53:18 +00:00
renovate[bot]
99a0a5cc48 chore(deps): update asf-ui digest to a93167e 2025-03-26 05:57:09 +00:00
ArchiBot
63c91d2d19 Automatic translations update 2025-03-26 02:22:32 +00:00
renovate[bot]
d6be6cf435 chore(deps): update asf-ui digest to ee55958 2025-03-25 03:00:04 +00:00
renovate[bot]
8f7f9a27ee chore(deps): update asf-ui digest to 0b9c0c2 2025-03-22 06:46:28 +00:00
ArchiBot
b776d4d882 Automatic translations update 2025-03-22 02:21:23 +00:00
renovate[bot]
63c81c2403 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.7.0 2025-03-21 19:49:13 +00:00
renovate[bot]
ad9a77ff19 chore(deps): update dependency scalar.aspnetcore to 2.1.1 2025-03-20 19:28:04 +00:00
renovate[bot]
2e17a15d60 chore(deps): update asf-ui digest to 5dcfb93 2025-03-20 03:09:58 +00:00
renovate[bot]
3fae20673b chore(deps): update actions/upload-artifact action to v4.6.2 2025-03-19 22:42:10 +00:00
renovate[bot]
5b36c1c286 chore(deps): update actions/download-artifact action to v4.2.1 2025-03-19 17:14:20 +00:00
renovate[bot]
4fc4d011f2 chore(deps): update dependency scalar.aspnetcore to 2.1.0 2025-03-19 07:40:28 +00:00
ArchiBot
91aa9754bb Automatic translations update 2025-03-19 02:22:16 +00:00
renovate[bot]
a6ba407ebf chore(deps): update actions/download-artifact action to v4.2.0 2025-03-18 18:54:59 +00:00
Łukasz Domeradzki
1cdb128c6b Bump 2025-03-18 19:54:28 +01:00
Łukasz Domeradzki
38ca6b7642 Update Scalar.AspNetCore 2025-03-18 19:50:45 +01:00
Łukasz Domeradzki
65c7a60c92 Switch to scalar for swagger-ui generation (#3391) 2025-03-18 19:47:43 +01:00
renovate[bot]
77c802ee5f chore(deps): update dependency swashbuckle.aspnetcore.swaggerui to 7.3.2 2025-03-18 11:31:12 +00:00
renovate[bot]
a8f23159f4 chore(deps): update asf-ui digest to d847829 2025-03-18 03:09:59 +00:00
renovate[bot]
ee8a7a6f61 chore(deps): update actions/setup-node action to v4.3.0 2025-03-17 23:28:51 +00:00
renovate[bot]
4a612b9436 chore(deps): update dependency mstest to 3.8.3 2025-03-17 16:55:26 +00:00
renovate[bot]
4d89995016 chore(deps): update asf-ui digest to f2393a2 2025-03-17 12:10:41 +00:00
renovate[bot]
368c453504 chore(deps): update actions/setup-dotnet action to v4.3.1 2025-03-17 05:46:02 +00:00
ArchiBot
1694851395 Automatic translations update 2025-03-16 02:23:25 +00:00
renovate[bot]
1ed4f3f456 chore(deps): update docker/login-action action to v3.4.0 2025-03-14 11:57:11 +00:00
renovate[bot]
588d49eeb9 chore(deps): update asf-ui digest to 41bfaf0 2025-03-12 19:26:11 +00:00
renovate[bot]
22d4f22da6 chore(deps): update asf-ui digest to 2c3829f (#3396)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-03-12 11:39:52 +00:00
renovate[bot]
ced640f024 chore(deps): update dotnet monorepo to 9.0.3 2025-03-11 21:54:46 +00:00
renovate[bot]
7b8804b53c chore(deps): update dependency microsoft.codeanalysis.resxsourcegenerator to 3.11.0-beta1.25076.3 2025-03-11 19:08:49 +00:00
renovate[bot]
5d25742faf chore(deps): update asf-ui digest to bc98426 2025-03-11 03:22:59 +00:00
ArchiBot
4460b18c5e Automatic translations update 2025-03-11 02:21:55 +00:00
ArchiBot
cb5eb499d9 Automatic translations update 2025-03-10 02:11:40 +00:00
Łukasz Domeradzki
9382c6d390 Bump 2025-03-09 23:51:11 +01:00
Łukasz Domeradzki
7cd091cfa2 Implement dummy answer to ClientGetClientAppList request 2025-03-09 23:47:10 +01:00
renovate[bot]
961dc4cf5d chore(deps): update asf-ui digest to c1e8e5b 2025-03-09 05:32:53 +00:00
ArchiBot
f77193dc48 Automatic translations update 2025-03-09 02:10:59 +00:00
renovate[bot]
a4b31d2cdc chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.6.1 (#3393)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-03-08 21:50:56 +00:00
renovate[bot]
83b3edae86 chore(deps): update asf-ui digest to a48983b (#3394)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-03-08 17:55:33 +00:00
Łukasz Domeradzki
ebc4601ed4 Add another useful json helper 2025-03-08 15:00:38 +01:00
Łukasz Domeradzki
a478c02967 Remove qodana support 2025-03-08 11:56:56 +01:00
renovate[bot]
aac1f81704 chore(deps): update opentelemetry-dotnet-contrib monorepo to 1.11.1 2025-03-06 05:37:39 +00:00
ArchiBot
100b85abe0 Automatic translations update 2025-03-06 02:21:28 +00:00
renovate[bot]
bb52122db1 chore(deps): update actions/attest-build-provenance action to v2.2.3 2025-03-05 23:37:03 +00:00
renovate[bot]
397b36c557 chore(deps): update asf-ui digest to 4cba2a6 2025-03-05 12:14:04 +00:00
renovate[bot]
77b041ea67 chore(deps): update dependency opentelemetry.extensions.hosting to 1.11.2 2025-03-04 22:34:48 +00:00
renovate[bot]
b1d896ae70 chore(deps): update asf-ui digest to c8faaa2 2025-03-04 03:28:37 +00:00
ArchiBot
8f5157d8dd Automatic translations update 2025-03-03 08:39:18 +00:00
Łukasz Domeradzki
c5cf5f70c8 Bump 2025-03-02 22:17:40 +01:00
ArchiBot
88f7856c9b Automatic translations update 2025-03-02 11:26:14 +00:00
Łukasz Domeradzki
d843d1d5b1 Remove deprecated functionalities, bump 2025-03-01 15:22:04 +01:00
renovate[bot]
921b416374 chore(deps): update asf-ui digest to e0efa0f 2025-02-28 22:08:34 +00:00
renovate[bot]
c2eac39145 chore(deps): update dependency swashbuckle.aspnetcore.swaggerui to 7.3.1 2025-02-27 23:10:42 +00:00
renovate[bot]
467dbf723d chore(deps): update actions/attest-build-provenance action to v2.2.2 2025-02-27 19:21:44 +00:00
renovate[bot]
9460b476dd chore(deps): update docker/setup-buildx-action action to v3.10.0 2025-02-27 06:38:29 +00:00
renovate[bot]
16fb5a7d98 chore(deps): update actions/attest-build-provenance action to v2.2.1 2025-02-27 01:35:23 +00:00
renovate[bot]
c17da5951d chore(deps): update asf-ui digest to 19776b3 2025-02-26 22:25:40 +00:00
renovate[bot]
66a959d21c chore(deps): update docker/build-push-action action to v6.15.0 2025-02-26 16:27:29 +00:00
renovate[bot]
480037b84b chore(deps): update dependency swashbuckle.aspnetcore.swaggerui to 7.3.0 2025-02-26 11:52:42 +00:00
renovate[bot]
fa7867ab18 chore(deps): update actions/download-artifact action to v4.1.9 2025-02-26 02:52:48 +00:00
ArchiBot
0c5cdfae0a Automatic translations update 2025-02-26 02:20:45 +00:00
renovate[bot]
7e5f82d65b chore(deps): update asf-ui digest to 9546310 2025-02-25 07:33:09 +00:00
Łukasz Domeradzki
9753b36769 Misc 2025-02-23 19:56:23 +01:00
Łukasz Domeradzki
fd2c1e8c24 Bump 2025-02-23 19:21:50 +01:00
Łukasz Domeradzki
e5c9defac8 Closes #3184 2025-02-23 19:13:44 +01:00
Łukasz Domeradzki
33c8c0f0d6 Rewrite GitHub service from xpath to css selectors 2025-02-23 17:28:36 +01:00
renovate[bot]
197b41d96f chore(deps): update ncipollo/release-action action to v1.16.0 2025-02-22 17:50:41 +00:00
renovate[bot]
52a8bcbbfe chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.6.0 2025-02-22 05:46:28 +00:00
renovate[bot]
e102b6c565 chore(deps): update asf-ui digest to 687959a 2025-02-22 02:49:10 +00:00
renovate[bot]
f899508253 chore(deps): update actions/upload-artifact action to v4.6.1 2025-02-21 23:35:02 +00:00
renovate[bot]
ab20d5fccf chore(deps): update github/codeql-action action to v3.28.10 2025-02-21 19:00:23 +00:00
ArchiBot
3c9827b1e1 Automatic translations update 2025-02-21 02:19:55 +00:00
renovate[bot]
9636fa1da1 chore(deps): update docker/build-push-action action to v6.14.0 2025-02-19 18:45:04 +00:00
renovate[bot]
b5ad577821 chore(deps): update dependency mstest to 3.8.2 2025-02-19 15:02:36 +00:00
renovate[bot]
ca483a91f3 chore(deps): update dependency mstest to 3.8.1 2025-02-18 21:39:39 +00:00
renovate[bot]
49e904c25a chore(deps): update asf-ui digest to b1b2d2e 2025-02-18 19:24:37 +00:00
renovate[bot]
9a0c0bfff5 chore(deps): update crowdin/github-action action to v2.6.1 2025-02-18 12:03:05 +00:00
ArchiBot
2ed1214d37 Automatic translations update 2025-02-18 02:19:06 +00:00
ArchiBot
adf417e2f1 Automatic translations update 2025-02-17 02:20:41 +00:00
Łukasz Domeradzki
ab333dc0b3 Bump 2025-02-16 17:44:42 +01:00
Łukasz Domeradzki
3f079a8fea Add new ASF API endpoint for inventory summary, add inventory command
Wow, new features in ASF?!
2025-02-16 17:26:51 +01:00
renovate[bot]
90db25e4de chore(deps): update asf-ui digest to 6908495 2025-02-16 06:46:41 +00:00
ArchiBot
ec793e22a1 Automatic translations update 2025-02-16 02:21:22 +00:00
renovate[bot]
c76f6caa2b chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.5.0 2025-02-15 01:25:06 +00:00
renovate[bot]
60245d5399 chore(deps): update asf-ui digest to 9b20a8f 2025-02-14 19:41:41 +00:00
renovate[bot]
8fb2ec61b4 chore(deps): update asf-ui digest to 41e8159 2025-02-14 11:02:36 +00:00
renovate[bot]
4a939ad607 chore(deps): update asf-ui digest to 6e74737 2025-02-14 02:59:21 +00:00
renovate[bot]
ba1be3df10 chore(deps): update asf-ui digest to 88995f5 2025-02-13 03:25:18 +00:00
ArchiBot
93333f0ece Automatic translations update 2025-02-13 02:19:24 +00:00
Łukasz Domeradzki
dcde5d9d54 Misc test improvements 2025-02-13 00:20:10 +01:00
renovate[bot]
52af5c85f0 chore(deps): update dependency mstest to 3.8.0 2025-02-12 15:13:10 +00:00
Łukasz Domeradzki
d47f17c7ad Bump 2025-02-12 16:12:41 +01:00
Łukasz Domeradzki
8533659b74 Misc cleanup 2025-02-12 16:12:01 +01:00
Łukasz Domeradzki
2f658a3d4e Closes #3376 2025-02-12 16:11:10 +01:00
renovate[bot]
2c31b5f11f chore(deps): update dotnet monorepo to 9.0.2 2025-02-11 22:08:26 +00:00
renovate[bot]
c66bd6259c chore(deps): update dependency microsoft.codeanalysis.resxsourcegenerator to 3.11.0-beta1.24629.2 2025-02-11 20:08:15 +00:00
renovate[bot]
145c64389d chore(deps): update asf-ui digest to 1bf87dd 2025-02-11 16:12:08 +00:00
renovate[bot]
23263e634e chore(deps): update crowdin/github-action action to v2.6.0 2025-02-11 11:55:35 +00:00
renovate[bot]
2074865a7c chore(deps): update asf-ui digest to a5471a6 2025-02-11 05:32:13 +00:00
ArchiBot
4cb9f54204 Automatic translations update 2025-02-11 02:19:51 +00:00
renovate[bot]
78b1d7de0f chore(deps): update dependency anglesharp.xpath to 2.0.5 2025-02-10 21:36:42 +00:00
Łukasz Domeradzki
c296790226 Bump 2025-02-09 21:16:40 +01:00
Łukasz Domeradzki
d7fec15597 Bump 2025-02-09 21:16:25 +01:00
Łukasz Domeradzki
f33fda8313 Misc 2025-02-09 21:15:24 +01:00
Łukasz Domeradzki
62ce58e148 Closes #3378 2025-02-09 21:14:05 +01:00
renovate[bot]
db70633721 chore(deps): update asf-ui digest to 3b86172 2025-02-09 09:56:32 +00:00
ArchiBot
8c62b01d19 Automatic translations update 2025-02-08 02:17:22 +00:00
renovate[bot]
5f3b2c9a0d chore(deps): update github/codeql-action action to v3.28.9 2025-02-07 18:33:48 +00:00
Łukasz Domeradzki
1afac53318 Closes #3384 2025-02-07 15:31:11 +01:00
renovate[bot]
78d2ff1645 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.4.0 2025-02-07 05:57:00 +00:00
renovate[bot]
31082e0184 chore(deps): update docker/setup-buildx-action action to v3.9.0 2025-02-06 17:30:45 +00:00
renovate[bot]
7e942d6481 chore(deps): update asf-ui digest to d006b23 (#3383)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-02-06 13:43:03 +01:00
ArchiBot
af0659595e Automatic translations update 2025-02-06 02:19:05 +00:00
ArchiBot
89962bd393 Automatic translations update 2025-02-05 02:18:55 +00:00
Sebastian Göls
c71fe556a3 Fix typo (#3382) 2025-02-04 09:08:24 +01:00
ArchiBot
4c88e098c6 Automatic translations update 2025-02-04 02:18:24 +00:00
renovate[bot]
8069c19eef chore(deps): update wiki digest to 6603a8e 2025-02-03 21:46:23 +00:00
Łukasz Domeradzki
91fd6a1014 Bump 2025-02-03 11:15:30 +01:00
renovate[bot]
18be38352f chore(deps): update dependency steamkit2 to 3.0.2 2025-02-03 04:55:35 +00:00
renovate[bot]
e5029c983c chore(deps): update dependency nlog.web.aspnetcore to 5.4.0 2025-02-02 20:35:59 +00:00
renovate[bot]
e8bbaabc01 chore(deps): update asf-ui digest to fbdc518 2025-02-02 05:17:52 +00:00
ArchiBot
e62e3be68a Automatic translations update 2025-02-02 02:19:26 +00:00
ArchiBot
3c48bc1756 Automatic translations update 2025-01-31 02:18:21 +00:00
renovate[bot]
00a02f2be4 chore(deps): update actions/setup-dotnet action to v4.3.0 2025-01-30 12:42:26 +00:00
renovate[bot]
2c09757086 chore(deps): update asf-ui digest to 83b9d20 2025-01-30 04:21:04 +00:00
ArchiBot
73a4e8acd3 Automatic translations update 2025-01-30 02:17:28 +00:00
renovate[bot]
7b98fea247 chore(deps): update github/codeql-action action to v3.28.8 2025-01-29 20:39:05 +00:00
renovate[bot]
3cf25f6385 chore(deps): update github/codeql-action action to v3.28.7 2025-01-29 14:41:10 +00:00
ArchiBot
69d666b24d Automatic translations update 2025-01-29 02:17:55 +00:00
renovate[bot]
0a234166f6 chore(deps): update github/codeql-action action to v3.28.6 2025-01-28 05:56:43 +00:00
ArchiBot
68d63853f4 Automatic translations update 2025-01-28 02:18:08 +00:00
renovate[bot]
f3551594c3 chore(deps): update dependency mstest to 3.7.3 2025-01-27 21:11:56 +00:00
renovate[bot]
6effcc0d4f chore(deps): update asf-ui digest to 99a0294 2025-01-27 19:31:08 +00:00
Łukasz Domeradzki
1e3f535330 Bump 2025-01-27 20:30:37 +01:00
Łukasz Domeradzki
0a2ce30c82 Misc 2025-01-27 20:24:43 +01:00
Łukasz Domeradzki
dd37914703 Apply feedback 2025-01-27 20:12:35 +01:00
Łukasz Domeradzki
67c2e9c6d3 Record input from the user in the logs as well 2025-01-27 19:57:42 +01:00
Łukasz Domeradzki
ec151c383b Ensure rare console writes leave trace in the log as of what is happening 2025-01-27 19:44:47 +01:00
renovate[bot]
05079eb941 chore(deps): update opentelemetry-dotnet-contrib monorepo to 1.11.0 2025-01-27 09:50:46 +00:00
renovate[bot]
38ebfc9345 chore(deps): update actions/setup-node action to v4.2.0 2025-01-27 04:35:19 +00:00
renovate[bot]
fc4f4092f2 chore(deps): update docker/build-push-action action to v6.13.0 2025-01-26 17:30:19 +00:00
renovate[bot]
59f00714d6 chore(deps): update github/codeql-action action to v3.28.5 2025-01-26 13:06:44 +00:00
renovate[bot]
7d84599d0a chore(deps): update asf-ui digest to 907e0fb 2025-01-26 09:43:31 +00:00
renovate[bot]
da1e49ffde chore(deps): update crowdin/github-action action to v2.5.2 2025-01-24 08:25:11 +00:00
renovate[bot]
30498df864 chore(deps): update actions/attest-build-provenance action to v2.2.0 2025-01-24 04:30:18 +00:00
renovate[bot]
9ad08bd028 chore(deps): update github/codeql-action action to v3.28.4 2025-01-24 01:04:48 +00:00
renovate[bot]
70d190488f chore(deps): update dependency opentelemetry.extensions.hosting to 1.11.1 2025-01-23 23:16:35 +00:00
renovate[bot]
274136e3e1 chore(deps): update asf-ui digest to ad215c8 2025-01-22 05:58:53 +00:00
ArchiBot
9b81c390bf Automatic translations update 2025-01-22 02:19:11 +00:00
renovate[bot]
c649edf051 chore(deps): update github/codeql-action action to v3.28.2 2025-01-21 20:58:29 +00:00
renovate[bot]
7bb1528e78 chore(deps): update dependency mstest to 3.7.2 2025-01-21 18:58:00 +00:00
renovate[bot]
b8fb66c7fe chore(deps): update asf-ui digest to bbeba04 2025-01-21 05:56:07 +00:00
ArchiBot
075a234e14 Automatic translations update 2025-01-21 02:18:06 +00:00
Łukasz Domeradzki
7e6a79dac2 Misc rename 2025-01-20 12:32:09 +01:00
Łukasz Domeradzki
ff6473dbe6 Bump 2025-01-20 11:54:41 +01:00
Łukasz Domeradzki
ac01cca55e Go back to swagger in regards to #3376, add cmdline switch to force openapi 2025-01-20 11:49:35 +01:00
renovate[bot]
2a66fce878 chore(deps): update asf-ui digest to 3e24284 2025-01-19 05:05:53 +00:00
ArchiBot
9d5d6b792d Automatic translations update 2025-01-19 02:20:36 +00:00
renovate[bot]
7927ff859f chore(deps): update asf-ui digest to 9cd1203 2025-01-18 04:34:13 +00:00
renovate[bot]
f2992fa6dd chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.3.1 2025-01-18 00:24:41 +00:00
renovate[bot]
af27952ced chore(deps): update crowdin/github-action action to v2.5.1 2025-01-17 09:54:22 +00:00
ArchiBot
2f92a80bd6 Automatic translations update 2025-01-17 02:17:34 +00:00
renovate[bot]
786dc16bbd chore(deps): update dependency opentelemetry.extensions.hosting to 1.11.0 2025-01-16 13:11:57 +00:00
ArchiBot
947ed6234e Automatic translations update 2025-01-16 02:18:00 +00:00
renovate[bot]
6e8ee64918 chore(deps): update docker/build-push-action action to v6.12.0 2025-01-15 15:02:14 +00:00
renovate[bot]
ce0d423497 chore(deps): update dotnet monorepo to 9.0.1 2025-01-15 11:13:32 +00:00
renovate[bot]
851c8bdbf8 chore(deps): update dependency microsoft.codeanalysis.resxsourcegenerator to 3.11.0-beta1.24605.2 2025-01-15 05:05:22 +00:00
ArchiBot
9ed6586b93 Automatic translations update 2025-01-15 02:18:20 +00:00
renovate[bot]
fcb965e492 chore(deps): update asf-ui digest to e18599e 2025-01-14 20:55:47 +00:00
ArchiBot
32cde62815 Automatic translations update 2025-01-14 02:17:39 +00:00
renovate[bot]
d83e4fceca chore(deps): update dependency mstest to 3.7.1 2025-01-13 18:01:12 +00:00
ArchiBot
af1d017123 Automatic translations update 2025-01-13 02:20:56 +00:00
Sebastian Göls
3759e906cc Improve monitoring plugin (#3374) 2025-01-12 23:18:05 +01:00
renovate[bot]
764ec31559 chore(deps): update ncipollo/release-action action to v1.15.0 2025-01-12 05:12:51 +00:00
renovate[bot]
b3754fc32c chore(deps): update asf-ui digest to 9028c68 2025-01-11 06:42:38 +00:00
renovate[bot]
4780aa7601 chore(deps): update actions/upload-artifact action to v4.6.0 2025-01-11 01:24:26 +00:00
renovate[bot]
7c67a7409f chore(deps): update asf-ui digest to 345fe2b 2025-01-10 22:33:08 +00:00
renovate[bot]
db9969558f chore(deps): update github/codeql-action action to v3.28.1 2025-01-10 18:50:15 +00:00
renovate[bot]
78fd2ae333 chore(deps): update dependency markdig.signed to 0.40.0 2025-01-10 09:50:23 +00:00
renovate[bot]
6f4337c91e chore(deps): update docker/build-push-action action to v6.11.0 2025-01-08 14:52:37 +00:00
ArchiBot
a92430b4f0 Automatic translations update 2025-01-08 02:19:48 +00:00
Łukasz Domeradzki
f18a1d584d Misc monitoring stuff 2025-01-07 14:59:31 +01:00
Łukasz Domeradzki
1302fd8984 Misc monitoring plugin improvements 2025-01-07 14:38:29 +01:00
ArchiBot
289010ba88 Automatic translations update 2025-01-07 02:20:15 +00:00
ArchiBot
99f994b4b5 Automatic translations update 2025-01-06 02:21:19 +00:00
renovate[bot]
cd63f14f97 chore(deps): update wiki digest to 871cf91 2025-01-05 19:44:13 +00:00
Łukasz Domeradzki
b38748de18 Misc 2025-01-05 19:04:55 +01:00
Łukasz Domeradzki
730814f4f6 Use new field keyword 2025-01-05 16:51:43 +01:00
Łukasz Domeradzki
ccec47c8bd Resolve some qodana warnings 2025-01-05 16:22:54 +01:00
Łukasz Domeradzki
90ae809bbe Bump 2025-01-05 15:35:06 +01:00
Łukasz Domeradzki
30a48b08fe Don't trim tags, needed for STD plugin 2025-01-05 15:28:05 +01:00
Łukasz Domeradzki
9e207025c5 Happy new year 2025-01-05 02:40:56 +01:00
Łukasz Domeradzki
3f98337459 Closes #3343 2025-01-05 02:32:05 +01:00
Łukasz Domeradzki
8c9cf69353 Misc warnings cleanup 2025-01-04 19:30:24 +01:00
renovate[bot]
d9b4bd5aca chore(deps): update asf-ui digest to bd81c92 2025-01-04 13:58:20 +00:00
Łukasz Domeradzki
96407018fb Don't allow to run with invalid IPCPassword
This scenario would throw when IPC is required to compare provided password with hash in the config. Instead, yell at user and prevent them from running with such config at all.
2025-01-04 14:47:53 +01:00
ArchiBot
1f78dbb553 Automatic translations update 2025-01-04 02:18:30 +00:00
renovate[bot]
3ef582ef84 chore(deps): update wiki digest to 17137f3 2025-01-03 17:09:53 +00:00
Łukasz Domeradzki
5be6e8ccda Add flags resources for wiki 2025-01-03 16:37:47 +01:00
ArchiBot
12cea2303c Automatic translations update 2025-01-03 02:19:54 +00:00
ArchiBot
ab11e10c5c Automatic translations update 2025-01-02 02:19:10 +00:00
Łukasz Domeradzki
a97d761f46 Bump, remove obsolete functionalities 2025-01-01 15:05:17 +01:00
Łukasz Domeradzki
7bf2dab4d0 Closes #3370 2025-01-01 14:49:19 +01:00
Łukasz Domeradzki
13567d4aaa Copy over bundled plugins to main ASF dir as well 2025-01-01 14:33:36 +01:00
Łukasz Domeradzki
c4ef7e6872 Misc corrections to solution 2025-01-01 14:31:57 +01:00
ArchiBot
bf83b4807d Automatic translations update 2024-12-31 02:19:27 +00:00
renovate[bot]
69b3e460ef chore(deps): update dependency steamkit2 to 3.0.1 2024-12-29 11:07:39 +00:00
ArchiBot
6aa32cdd32 Automatic translations update 2024-12-29 02:22:08 +00:00
renovate[bot]
626f3c6a0a chore(deps): update actions/setup-dotnet action to v4.2.0 2024-12-27 01:22:27 +00:00
renovate[bot]
5f34a16dd7 chore(deps): update asf-ui digest to 8b93e22 2024-12-25 16:02:20 +00:00
Łukasz Domeradzki
4beff6fc22 Bump 2024-12-25 14:46:22 +01:00
Łukasz Domeradzki
cb08e05d62 Merge branch 'main' of https://github.com/JustArchiNET/ArchiSteamFarm 2024-12-25 14:45:38 +01:00
Łukasz Domeradzki
fca28d30cd Bump ASF-ui 2024-12-25 14:45:27 +01:00
Sebastian Göls
7df37649b7 Update grafana-dashboard.json (#3366) 2024-12-25 14:37:02 +01:00
Łukasz Domeradzki
ba68d1010f Add optional filtering for plugins GET endpoint 2024-12-25 14:34:18 +01:00
Łukasz Domeradzki
711cda2d90 Revert "Misc"
This reverts commit b5039d6308.
2024-12-25 14:30:02 +01:00
Łukasz Domeradzki
b5039d6308 Misc 2024-12-25 14:22:24 +01:00
renovate[bot]
89bea12f9b chore(deps): update jetbrains/qodana-action action to v2024.3.4 2024-12-22 16:39:24 +00:00
renovate[bot]
53d7876d47 chore(deps): update asf-ui digest to 57b98e6 2024-12-21 10:05:04 +00:00
renovate[bot]
a0a8018527 chore(deps): update github/codeql-action action to v3.28.0 2024-12-20 23:02:00 +00:00
renovate[bot]
475daf5183 chore(deps): update dependency mstest to 3.7.0 2024-12-20 15:43:58 +00:00
Łukasz Domeradzki
b6597ce468 Bump 2024-12-20 15:21:22 +01:00
Łukasz Domeradzki
61fdbcfa9f Skip borrowed games from owned packages 2024-12-20 15:08:17 +01:00
Łukasz Domeradzki
f7f7dbdab8 Misc 2024-12-20 14:54:33 +01:00
Łukasz Domeradzki
267384ad59 Decrease memory consumption from owned packages 2024-12-20 14:50:56 +01:00
Łukasz Domeradzki
7dc3d16666 Properly resolve #3358 2024-12-20 14:17:53 +01:00
Łukasz Domeradzki
b251598ca4 Revert "Use different URL to resolve #3358"
This reverts commit 328a3748f5.
2024-12-20 13:45:14 +01:00
Łukasz Domeradzki
96279a96bb Merge branch 'main' of https://github.com/JustArchiNET/ArchiSteamFarm 2024-12-20 13:34:11 +01:00
Łukasz Domeradzki
328a3748f5 Use different URL to resolve #3358 2024-12-20 13:34:09 +01:00
ArchiBot
5b30a29e09 Automatic translations update 2024-12-20 02:20:19 +00:00
renovate[bot]
c97fbe4256 chore(deps): update wiki digest to d57f0d1 2024-12-19 22:19:30 +00:00
Łukasz Domeradzki
713971ced6 Remove AutoSteamSaleEvent farming preference (#3360) 2024-12-19 21:28:50 +01:00
Łukasz Domeradzki
b28c3e368e Bump 2024-12-19 13:27:10 +01:00
renovate[bot]
d5045ce737 chore(deps): update dependency markdig.signed to 0.39.1 2024-12-19 05:48:01 +00:00
renovate[bot]
4acb6eda07 chore(deps): update actions/upload-artifact action to v4.5.0 2024-12-18 07:32:05 +00:00
renovate[bot]
74aeb89afa chore(deps): update asf-ui digest to 10e22ad 2024-12-18 04:57:17 +00:00
renovate[bot]
545d15c4c6 chore(deps): update jetbrains/qodana-action action to v2024.3.3 2024-12-18 01:59:58 +00:00
Łukasz Domeradzki
054a317777 Try to address #3362 2024-12-17 23:59:32 +01:00
renovate[bot]
dd7ae5801d chore(deps): update dependency markdig.signed to 0.39.0 2024-12-17 12:01:20 +00:00
renovate[bot]
d3d003b00e chore(deps): update asf-ui digest to eb1efb2 2024-12-17 06:12:39 +00:00
renovate[bot]
c3b431d573 chore(deps): update asf-ui digest to c465c58 2024-12-16 17:03:33 +00:00
renovate[bot]
865668f6b1 chore(deps): update docker/setup-buildx-action action to v3.8.0 2024-12-16 12:16:34 +00:00
renovate[bot]
2f15569ddc chore(deps): update crowdin/github-action action to v2.5.0 2024-12-16 10:10:16 +00:00
renovate[bot]
6c2fd10b2f chore(deps): update asf-ui digest to 551378e 2024-12-16 03:58:02 +00:00
ArchiBot
7dee5b9998 Automatic translations update 2024-12-16 02:24:12 +00:00
ArchiBot
1f1dcbe39c Automatic translations update 2024-12-15 02:25:58 +00:00
Łukasz Domeradzki
acd081775d Misc Rider enhancements 2024-12-14 17:51:03 +01:00
renovate[bot]
0db414d608 chore(deps): update asf-ui digest to 9905d3e 2024-12-14 03:57:34 +00:00
ArchiBot
09d715c03d Automatic translations update 2024-12-14 02:22:17 +00:00
renovate[bot]
b776aa48cd chore(deps): update asf-ui digest to b6c7dc8 2024-12-13 04:40:56 +00:00
renovate[bot]
d4eef759fb chore(deps): update github/codeql-action action to v3.27.9 2024-12-13 02:30:35 +00:00
Łukasz Domeradzki
c1005134b0 Bump 2024-12-12 22:15:55 +01:00
Łukasz Domeradzki
fc525c5619 Bump 2024-12-12 22:15:36 +01:00
Jack Nolddor
1f27cb37f2 feat: blacklist winter sale 2024 app (#3359)
refer to https://steamdb.info/app/2861720/
2024-12-12 22:14:32 +01:00
renovate[bot]
58f2b8e45c chore(deps): update jetbrains/qodana-action action to v2024.3.2 2024-12-11 18:23:28 +00:00
renovate[bot]
57c8533303 chore(deps): update asf-ui digest to addd6c6 2024-12-11 16:28:20 +00:00
renovate[bot]
aa1302c058 chore(deps): update dependency opentelemetry.instrumentation.aspnetcore to 1.10.1 2024-12-11 00:53:58 +00:00
renovate[bot]
ac31004074 chore(deps): update swashbuckle-aspnetcore monorepo to 7.2.0 2024-12-10 23:35:15 +00:00
renovate[bot]
755ab226c3 chore(deps): update dependency microsoft.codeanalysis.resxsourcegenerator to 3.11.0-beta1.24527.2 2024-12-10 20:22:39 +00:00
renovate[bot]
78195e6913 chore(deps): update github/codeql-action action to v3.27.7 2024-12-10 15:05:44 +00:00
Łukasz Domeradzki
0f48b92b47 Misc 2024-12-10 12:14:44 +01:00
renovate[bot]
3de504192b chore(deps): update actions/attest-build-provenance action to v2.1.0 2024-12-09 23:28:56 +00:00
renovate[bot]
eea71a9ecf chore(deps): update dependency opentelemetry.instrumentation.aspnetcore to 1.10.0 2024-12-09 11:58:44 +00:00
ArchiBot
b9b93caf50 Automatic translations update 2024-12-08 02:26:04 +00:00
renovate[bot]
d06e69055a chore(deps): update actions/attest-build-provenance action to v2.0.1 2024-12-06 18:55:21 +00:00
renovate[bot]
6f528990c3 chore(deps): update dependency opentelemetry.instrumentation.runtime to 1.10.0 2024-12-06 02:01:40 +00:00
renovate[bot]
46c720ae23 chore(deps): update asf-ui digest to 1e52298 2024-12-05 23:24:12 +00:00
Łukasz Domeradzki
a8982581b7 Bump 2024-12-05 20:22:37 +01:00
Łukasz Domeradzki
d21912dcd9 Add workaround for #3352 2024-12-05 20:20:30 +01:00
renovate[bot]
f74e6bff39 chore(deps): update dependency microsoft.identitymodel.jsonwebtokens to 8.3.0 2024-12-05 04:51:28 +00:00
ArchiBot
9bad87c576 Automatic translations update 2024-12-05 02:23:35 +00:00
renovate[bot]
af6354c62a chore(deps): update asf-ui digest to c316254 2024-12-04 21:19:54 +00:00
renovate[bot]
9621339ac4 chore(deps): update actions/attest-build-provenance action to v2 (#3356)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-04 22:19:16 +01:00
renovate[bot]
ecf00aded6 chore(deps): update asf-ui digest to c7a10da 2024-12-04 13:14:37 +00:00
renovate[bot]
3b04524dbc chore(deps): update asf-ui digest to bfdb3fb 2024-12-04 04:22:58 +00:00
renovate[bot]
5f86d7fca0 chore(deps): update dependency mstest to 3.6.4 2024-12-03 23:05:13 +00:00
renovate[bot]
d85945e664 chore(deps): update asf-ui digest to 11c980c 2024-12-03 20:18:15 +00:00
renovate[bot]
82f1ded4a1 chore(deps): update github/codeql-action action to v3.27.6 2024-12-03 12:21:13 +00:00
renovate[bot]
00393279ed chore(deps): update asf-ui digest to dcdb4aa 2024-12-03 07:40:10 +00:00
ArchiBot
4fc72bf56e Automatic translations update 2024-12-03 02:23:29 +00:00
Łukasz Domeradzki
d373cfb9ae Bump 2024-12-02 14:20:40 +01:00
Łukasz Domeradzki
90ead36184 Merge branch 'stable' 2024-12-02 14:20:08 +01:00
Łukasz Domeradzki
a4e46d9451 Bump 2024-12-02 09:25:10 +01:00
Łukasz Domeradzki
ea53975acf Attempt to resolve #3348 2024-12-02 09:17:26 +01:00
ArchiBot
29709abc62 Automatic translations update 2024-12-02 02:23:18 +00:00
ArchiBot
26b09f3f8a Automatic translations update 2024-12-01 02:31:06 +00:00
renovate[bot]
c98a177909 chore(deps): update asf-ui digest to 5a3591d 2024-11-30 11:03:51 +00:00
ArchiBot
57ceba2134 Automatic translations update 2024-11-30 02:21:27 +00:00
ArchiBot
1801f8d62a Automatic translations update 2024-11-29 02:23:43 +00:00
renovate[bot]
840cf03441 chore(deps): update wiki digest to 2c27b3d 2024-11-28 18:57:08 +00:00
renovate[bot]
8de27db858 chore(deps): update dependency opentelemetry.instrumentation.http to 1.10.0 2024-11-27 21:29:51 +00:00
renovate[bot]
ba3b49cfbd chore(deps): update docker/build-push-action action to v6.10.0 2024-11-26 15:23:49 +00:00
renovate[bot]
df94dee4cd chore(deps): update asf-ui digest to d361815 2024-11-26 05:28:28 +00:00
renovate[bot]
9dbd835600 chore(deps): update swashbuckle-aspnetcore monorepo to 7.1.0 2024-11-25 15:51:49 +00:00
renovate[bot]
c714dcdd69 chore(deps): update asf-ui digest to c0c518c 2024-11-25 13:39:45 +00:00
renovate[bot]
d291b9479d chore(deps): update crowdin/github-action action to v2.4.0 2024-11-25 09:32:54 +00:00
ArchiBot
ddf6bb29bf Automatic translations update 2024-11-25 02:22:41 +00:00
ArchiBot
4f38b8174d Automatic translations update 2024-11-24 02:24:21 +00:00
renovate[bot]
4abb2cf526 chore(deps): update wiki digest to 0dcdb24 2024-11-23 21:38:16 +00:00
Citrinate
837ca6a805 Fix typo (#3344) 2024-11-23 17:30:58 +01:00
renovate[bot]
08eebdf24f chore(deps): update dependency nlog.web.aspnetcore to 5.3.15 2024-11-21 21:33:59 +00:00
Łukasz Domeradzki
2d4ee1c9f8 Improve COPY in our dockerfiles
https://docs.docker.com/reference/dockerfile/#copy---link

> If you don't rely on the behavior of following symlinks in the destination path, using --link is always recommended. The performance of --link is equivalent or better than the default behavior and, it creates much better conditions for cache reuse.

Also recommended in aspnet samples: https://github.com/dotnet/dotnet-docker/blob/main/samples/aspnetapp/Dockerfile
2024-11-21 22:33:32 +01:00
renovate[bot]
448cdda23d chore(deps): update asf-ui digest to 28133ae 2024-11-20 21:46:06 +00:00
renovate[bot]
ccbb830538 chore(deps): update github/codeql-action action to v3.27.5 2024-11-20 16:35:42 +00:00
ArchiBot
bdb94b8f0b Automatic translations update 2024-11-20 02:22:06 +00:00
renovate[bot]
0f4626557e chore(deps): update asf-ui digest to 6cfb52e 2024-11-19 15:57:11 +00:00
renovate[bot]
0c091ea5a5 chore(deps): update asf-ui digest to b10ccf2 2024-11-19 04:31:36 +00:00
ArchiBot
cdaa1a6374 Automatic translations update 2024-11-19 02:22:10 +00:00
renovate[bot]
857c81e0bc chore(deps): update wiki digest to dc8e632 2024-11-18 15:09:05 +00:00
Łukasz Domeradzki
6ab1e40826 Bump 2024-11-18 11:10:07 +01:00
354 changed files with 6295 additions and 3641 deletions

View File

@@ -122,9 +122,6 @@ dotnet_code_quality.ca3012.excluded_symbol_names = BotController|CommandControll
dotnet_code_quality_unused_parameters = all:warning
dotnet_diagnostic.CA1028.severity = silent
dotnet_diagnostic.CA1031.severity = silent
# Rule - almost everything
dotnet_naming_rule.almost_everything_must_be_pascal_case.severity = warning
dotnet_naming_rule.almost_everything_must_be_pascal_case.style = pascal_case

View File

@@ -16,4 +16,4 @@ ASF is available for free, this release was made possible thanks to the people t
[![GitHub sponsor](https://img.shields.io/badge/GitHub-sponsor-ea4aaa.svg?logo=github-sponsors)](https://github.com/sponsors/JustArchi) [![PayPal.me donate](https://img.shields.io/badge/PayPal.me-donate-00457c.svg?logo=paypal)](https://paypal.me/JustArchi) [![PayPal donate](https://img.shields.io/badge/PayPal-donate-00457c.svg?logo=paypal)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=HD2P2P3WGS5Y4) [![Revolut donate](https://img.shields.io/badge/Revolut-donate-0075eb.svg?logo=revolut)](https://pay.revolut.com/justarchi) [![Steam donate](https://img.shields.io/badge/Steam-donate-000000.svg?logo=steam)](https://steamcommunity.com/tradeoffer/new/?partner=46697991&token=0ix2Ruv_)
[![BTC donate](https://img.shields.io/badge/BTC-donate-f7931a.svg?logo=bitcoin)](https://www.blockchain.com/explorer/addresses/btc/3HwcgZbtoF5vSxJkNUvThVSJipKi7r5EqU) [![ETH donate](https://img.shields.io/badge/ETH-donate-3c3c3d.svg?logo=ethereum)](https://www.blockchain.com/explorer/addresses/eth/0xA1F7Ba62C5a3A8b93Fe6656936192432F328a366) [![LTC donate](https://img.shields.io/badge/LTC-donate-a6a9aa.svg?logo=litecoin)](https://live.blockcypher.com/ltc/address/MJCeBEZUsNgDhRhqbLFfPiDcf7CSrdvmZ3) [![USDC donate](https://img.shields.io/badge/USDC-donate-2775ca.svg?logo=cashapp)](https://etherscan.io/address/0xCf42D9F53F974CBd7c304eF0243CAe8e029885A8) [![USDT donate](https://img.shields.io/badge/USDT-donate-50af95.svg?logo=tether)](https://etherscan.io/address/0x985FDdD3AD00838A2049B07A33b783104d60f776)
[![BTC donate](https://img.shields.io/badge/BTC-donate-f7931a.svg?logo=bitcoin)](https://www.blockchain.com/explorer/addresses/btc/3HwcgZbtoF5vSxJkNUvThVSJipKi7r5EqU) [![ETH donate](https://img.shields.io/badge/ETH-donate-3c3c3d.svg?logo=ethereum)](https://www.blockchain.com/explorer/addresses/eth/0xA1F7Ba62C5a3A8b93Fe6656936192432F328a366) [![LTC donate](https://img.shields.io/badge/LTC-donate-a6a9aa.svg?logo=litecoin)](https://live.blockcypher.com/ltc/address/MJCeBEZUsNgDhRhqbLFfPiDcf7CSrdvmZ3) [![USDC donate](https://img.shields.io/badge/USDC-donate-2775ca.svg?logo=cashapp)](https://etherscan.io/address/0xCf42D9F53F974CBd7c304eF0243CAe8e029885A8)

3
.github/qodana.yaml vendored
View File

@@ -10,6 +10,9 @@ exclude:
- ArchiSteamFarm.OfficialPlugins.MobileAuthenticator/Localization
- ArchiSteamFarm.OfficialPlugins.SteamTokenDumper/Localization
- name: AsyncVoidMethod
- name: CA1515
paths:
- ArchiSteamFarm
- name: InternalOrPrivateMemberNotDocumented
- name: InvertIf
- name: NullableWarningSuppressionIsUsed

View File

@@ -1,7 +1,8 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [
"config:base",
"config:best-practices",
":assignee(JustArchi)",
":automergeBranch",
":automergeDigest",
@@ -10,6 +11,7 @@
":disableRateLimiting",
":label(🤖 Automatic)"
],
"git-submodules": {
"enabled": true
}

View File

@@ -21,13 +21,13 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Setup .NET Core
uses: actions/setup-dotnet@v4.1.0
uses: actions/setup-dotnet@67a3573c9a986a3f9c594539f4ab511d57bb3ce9 # v4.3.1
with:
dotnet-version: ${{ env.DOTNET_SDK_VERSION }}
@@ -38,4 +38,4 @@ jobs:
run: dotnet build -c "${{ matrix.configuration }}" -p:ContinuousIntegrationBuild=true -p:UseAppHost=false --nologo
- name: Run ${{ matrix.configuration }} ArchiSteamFarm.Tests
run: dotnet test ArchiSteamFarm.Tests -c "${{ matrix.configuration }}" -p:ContinuousIntegrationBuild=true -p:UseAppHost=false --nologo
run: dotnet test ArchiSteamFarm.Tests -c "${{ matrix.configuration }}" -p:ContinuousIntegrationBuild=true -p:UseAppHost=false --filter TestCategory!=Manual --nologo

View File

@@ -1,39 +0,0 @@
name: ASF-code-quality
on:
- push
env:
DOTNET_CLI_TELEMETRY_OPTOUT: true
DOTNET_NOLOGO: true
permissions:
checks: write
contents: write
pull-requests: write
security-events: write
jobs:
main:
environment: qa-qodana
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
with:
show-progress: false
- name: Run Qodana scan
uses: JetBrains/qodana-action@v2024.2.6
with:
args: --config,.github/qodana.yaml,--property=idea.headless.enable.statistics=false
pr-mode: false
upload-result: true
env:
QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }}
- name: Report Qodana results to GitHub
uses: github/codeql-action/upload-sarif@v3.27.4
with:
sarif_file: ${{ runner.temp }}/qodana/results/qodana.sarif.json

View File

@@ -14,13 +14,13 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Upload latest strings for translation on Crowdin
uses: crowdin/github-action@v2.3.0
uses: crowdin/github-action@9fd07c1c5b36b15f082d1d860dc399f16f849bd7 # v2.9.0
with:
crowdin_branch_name: main
config: '.github/crowdin.yml'

View File

@@ -19,16 +19,16 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3.7.1
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1
- name: Build ${{ matrix.configuration }} Docker image from ${{ matrix.file }}
uses: docker/build-push-action@v6.9.0
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0
with:
build-args: CONFIGURATION=${{ matrix.configuration }}
context: .

View File

@@ -18,23 +18,23 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3.7.1
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1
- name: Login to ghcr.io
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to DockerHub
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
@@ -50,7 +50,7 @@ jobs:
echo "DH_REPOSITORY=$(echo ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }} | tr '[:upper:]' '[:lower:]')" >> "$GITHUB_ENV"
- name: Build and publish Docker image from Dockerfile.Service
uses: docker/build-push-action@v6.9.0
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0
with:
context: .
file: Dockerfile.Service

View File

@@ -19,23 +19,23 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3.7.1
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1
- name: Login to ghcr.io
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to DockerHub
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
@@ -50,7 +50,7 @@ jobs:
echo "DH_REPOSITORY=$(echo ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }} | tr '[:upper:]' '[:lower:]')" >> "$GITHUB_ENV"
- name: Build and publish Docker image from Dockerfile
uses: docker/build-push-action@v6.9.0
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0
with:
context: .
platforms: ${{ env.PLATFORMS }}
@@ -69,7 +69,7 @@ jobs:
push: true
- name: Update DockerHub repository description
uses: peter-evans/dockerhub-description@v4.0.0
uses: peter-evans/dockerhub-description@432a30c9e07499fd01da9f8a49f0faf9e0ca5b77 # v4.0.2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

View File

@@ -19,23 +19,23 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3.7.1
uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1
- name: Login to ghcr.io
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Login to DockerHub
uses: docker/login-action@v3.3.0
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
@@ -51,7 +51,7 @@ jobs:
echo "DH_REPOSITORY=$(echo ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }} | tr '[:upper:]' '[:lower:]')" >> "$GITHUB_ENV"
- name: Build and publish Docker image from Dockerfile
uses: docker/build-push-action@v6.9.0
uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0
with:
context: .
platforms: ${{ env.PLATFORMS }}

View File

@@ -18,7 +18,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Lock inactive threads
uses: dessant/lock-threads@v5.0.1
uses: dessant/lock-threads@1bf7ec25051fe7c00bdd17e6a7cf3d7bfb7dc771 # v5.0.1
with:
discussion-inactive-days: 90
issue-inactive-days: 60

View File

@@ -19,13 +19,13 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
- name: Setup Node.js with npm
uses: actions/setup-node@v4.1.0
uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
with:
check-latest: true
node-version: ${{ env.NODE_JS_VERSION }}
@@ -43,7 +43,7 @@ jobs:
run: npm run-script deploy --no-progress --prefix ASF-ui
- name: Upload ASF-ui
uses: actions/upload-artifact@v4.4.3
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
if-no-files-found: error
name: ASF-ui
@@ -73,7 +73,6 @@ jobs:
- os: windows-latest
variant: win-x64
environment: build
runs-on: ${{ matrix.os }}
permissions:
@@ -82,12 +81,12 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
- name: Setup .NET Core
uses: actions/setup-dotnet@v4.1.0
uses: actions/setup-dotnet@67a3573c9a986a3f9c594539f4ab511d57bb3ce9 # v4.3.1
with:
dotnet-version: ${{ env.DOTNET_SDK_VERSION }}
@@ -95,7 +94,7 @@ jobs:
run: dotnet --info
- name: Download previously built ASF-ui
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ASF-ui
path: ASF-ui/dist
@@ -362,12 +361,12 @@ jobs:
- name: Generate artifact attestation for ASF-${{ matrix.variant }}.zip
if: ${{ github.event_name == 'push' }}
uses: actions/attest-build-provenance@v1.4.4
uses: actions/attest-build-provenance@e8998f949152b193b063cb0ec769d69d929409be # v2.4.0
with:
subject-path: out/ASF-${{ matrix.variant }}.zip
- name: Upload ASF-${{ matrix.variant }}
uses: actions/upload-artifact@v4.4.3
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
if-no-files-found: error
name: ${{ matrix.os }}_ASF-${{ matrix.variant }}
@@ -409,13 +408,13 @@ jobs:
- name: Generate artifact attestation for ArchiSteamFarm.OfficialPlugins.Monitoring
if: ${{ github.event_name == 'push' && matrix.os == 'ubuntu-latest' && matrix.variant == 'generic' }}
uses: actions/attest-build-provenance@v1.4.4
uses: actions/attest-build-provenance@e8998f949152b193b063cb0ec769d69d929409be # v2.4.0
with:
subject-path: out/ArchiSteamFarm.OfficialPlugins.Monitoring.zip
- name: Upload ArchiSteamFarm.OfficialPlugins.Monitoring
if: ${{ matrix.os == 'ubuntu-latest' && matrix.variant == 'generic' }}
uses: actions/upload-artifact@v4.4.3
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
if-no-files-found: error
name: ArchiSteamFarm.OfficialPlugins.Monitoring
@@ -434,66 +433,66 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
- name: Download ASF-generic artifact from ubuntu-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ubuntu-latest_ASF-generic
path: out
- name: Download ASF-linux-arm artifact from ubuntu-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ubuntu-latest_ASF-linux-arm
path: out
- name: Download ASF-linux-arm64 artifact from ubuntu-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ubuntu-latest_ASF-linux-arm64
path: out
- name: Download ASF-linux-x64 artifact from ubuntu-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ubuntu-latest_ASF-linux-x64
path: out
- name: Download ASF-osx-arm64 artifact from macos-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: macos-latest_ASF-osx-arm64
path: out
- name: Download ASF-osx-x64 artifact from macos-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: macos-latest_ASF-osx-x64
path: out
- name: Download ASF-win-arm64 artifact from windows-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: windows-latest_ASF-win-arm64
path: out
- name: Download ASF-win-x64 artifact from windows-latest
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: windows-latest_ASF-win-x64
path: out
- name: Download ArchiSteamFarm.OfficialPlugins.Monitoring artifact
uses: actions/download-artifact@v4.1.8
uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
with:
name: ArchiSteamFarm.OfficialPlugins.Monitoring
path: out
- name: Import GPG key for signing
uses: crazy-max/ghaction-import-gpg@v6.2.0
uses: crazy-max/ghaction-import-gpg@e89d40939c28e39f97cf32126055eeae86ba74ec # v6.3.0
with:
gpg_private_key: ${{ secrets.ARCHIBOT_GPG_PRIVATE_KEY }}
@@ -507,31 +506,31 @@ jobs:
gpg -a -b -o SHA512SUMS.sign SHA512SUMS
- name: Generate artifact attestation for SHA512SUMS
uses: actions/attest-build-provenance@v1.4.4
uses: actions/attest-build-provenance@e8998f949152b193b063cb0ec769d69d929409be # v2.4.0
with:
subject-path: out/SHA512SUMS
- name: Upload SHA512SUMS
uses: actions/upload-artifact@v4.4.3
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
if-no-files-found: error
name: SHA512SUMS
path: out/SHA512SUMS
- name: Generate artifact attestation for SHA512SUMS.sign
uses: actions/attest-build-provenance@v1.4.4
uses: actions/attest-build-provenance@e8998f949152b193b063cb0ec769d69d929409be # v2.4.0
with:
subject-path: out/SHA512SUMS.sign
- name: Upload SHA512SUMS.sign
uses: actions/upload-artifact@v4.4.3
uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with:
if-no-files-found: error
name: SHA512SUMS.sign
path: out/SHA512SUMS.sign
- name: Create ArchiSteamFarm GitHub release
uses: ncipollo/release-action@v1.14.0
uses: ncipollo/release-action@bcfe5470707e8832e12347755757cec0eb3c22af # v1.18.0
with:
allowUpdates: true
artifactErrorsFailBuild: true

View File

@@ -15,7 +15,7 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4.2.2
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
show-progress: false
submodules: recursive
@@ -27,11 +27,11 @@ jobs:
run: |
set -eu
git fetch --depth=1 origin master
git fetch origin master
git reset --hard origin/master
- name: Download latest translations from Crowdin
uses: crowdin/github-action@v2.3.0
uses: crowdin/github-action@9fd07c1c5b36b15f082d1d860dc399f16f849bd7 # v2.9.0
with:
upload_sources: false
download_translations: true
@@ -43,7 +43,7 @@ jobs:
token: ${{ secrets.ASF_CROWDIN_API_TOKEN }}
- name: Import GPG key for signing
uses: crazy-max/ghaction-import-gpg@v6.2.0
uses: crazy-max/ghaction-import-gpg@e89d40939c28e39f97cf32126055eeae86ba74ec # v6.3.0
with:
gpg_private_key: ${{ secrets.ARCHIBOT_GPG_PRIVATE_KEY }}
git_config_global: true

2
ASF-ui

Submodule ASF-ui updated: 1f0b1914a4...1d94b493ef

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -50,17 +50,16 @@ internal sealed class ExamplePlugin : IASF, IBot, IBotCommand2, IBotConnection,
// This is used for identification purposes, typically you want to use a friendly name of your plugin here, such as the name of your main class
// Please note that this property can have direct dependencies only on structures that were initialized by the constructor, as it's possible to be called before OnLoaded() takes place
[JsonInclude]
[Required]
public string Name => nameof(ExamplePlugin);
// This will be displayed to the user and written in the log file, typically you should point it to the version of your library, but alternatively you can do some more advanced logic if you'd like to
// Please note that this property can have direct dependencies only on structures that were initialized by the constructor, as it's possible to be called before OnLoaded() takes place
[JsonInclude]
[Required]
public Version Version => typeof(ExamplePlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
// Plugins can expose custom properties for our GET /Api/Plugins API call, simply annotate them with [JsonProperty] (or keep public)
// Plugins can expose custom properties for our GET /Api/Plugins API call, simply annotate them with [JsonInclude] (or keep public)
[JsonInclude]
[JsonRequired]
[Required]
public bool CustomIsEnabledField { get; private init; } = true;

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -22,7 +22,6 @@
// limitations under the License.
using System;
using System.ComponentModel.DataAnnotations;
using System.Composition;
using System.Runtime;
using System.Text.Json.Serialization;
@@ -39,15 +38,13 @@ namespace ArchiSteamFarm.CustomPlugins.PeriodicGC;
internal sealed class PeriodicGCPlugin : IPlugin {
private const byte GCPeriod = 60; // In seconds
private static readonly object LockObject = new();
private static readonly Lock Lock = new();
private static readonly Timer PeriodicGCTimer = new(PerformGC);
[JsonInclude]
[Required]
public string Name => nameof(PeriodicGCPlugin);
[JsonInclude]
[Required]
public Version Version => typeof(PeriodicGCPlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
public Task OnLoaded() {
@@ -55,7 +52,7 @@ internal sealed class PeriodicGCPlugin : IPlugin {
ASF.ArchiLogger.LogGenericWarning($"Periodic GC will occur every {timeSpan.ToHumanReadable()}. Please keep in mind that this plugin should be used for debugging tests only.");
lock (LockObject) {
lock (Lock) {
PeriodicGCTimer.Change(timeSpan, timeSpan);
}
@@ -65,7 +62,7 @@ internal sealed class PeriodicGCPlugin : IPlugin {
private static void PerformGC(object? state = null) {
ASF.ArchiLogger.LogGenericWarning($"Performing GC, current memory: {GC.GetTotalMemory(false) / 1024} KB.");
lock (LockObject) {
lock (Lock) {
GCSettings.LargeObjectHeapCompactionMode = GCLargeObjectHeapCompactionMode.CompactOnce;
GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced, true, true);
}

View File

@@ -4,7 +4,7 @@
</PropertyGroup>
<ItemGroup>
<PackageReference Include="AngleSharp.XPath" IncludeAssets="compile" />
<PackageReference Include="AngleSharp" IncludeAssets="compile" />
<PackageReference Include="JetBrains.Annotations" PrivateAssets="all" />
<PackageReference Include="System.Composition.AttributedModel" IncludeAssets="compile" />
</ItemGroup>

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -66,7 +66,7 @@ public sealed class SignInWithSteamController : ArchiController {
return StatusCode((int) HttpStatusCode.ServiceUnavailable, new GenericResponse(false, Strings.FormatErrorRequestFailedTooManyTimes(WebBrowser.MaxTries)));
}
IAttr? paramsNode = challengeResponse.Content.SelectSingleNode<IAttr>("//input[@name='openidparams']/@value");
IElement? paramsNode = challengeResponse.Content.QuerySelector("input[name='openidparams'][value]");
if (paramsNode == null) {
ASF.ArchiLogger.LogNullError(paramsNode);
@@ -74,7 +74,7 @@ public sealed class SignInWithSteamController : ArchiController {
return StatusCode((int) HttpStatusCode.InternalServerError, new GenericResponse(false, Strings.FormatErrorObjectIsNull(nameof(paramsNode))));
}
string paramsValue = paramsNode.Value;
string? paramsValue = paramsNode.GetAttribute("value");
if (string.IsNullOrEmpty(paramsValue)) {
ASF.ArchiLogger.LogNullError(paramsValue);
@@ -82,7 +82,7 @@ public sealed class SignInWithSteamController : ArchiController {
return StatusCode((int) HttpStatusCode.InternalServerError, new GenericResponse(false, Strings.FormatErrorObjectIsNull(nameof(paramsValue))));
}
IAttr? nonceNode = challengeResponse.Content.SelectSingleNode<IAttr>("//input[@name='nonce']/@value");
IElement? nonceNode = challengeResponse.Content.QuerySelector("input[name='nonce'][value]");
if (nonceNode == null) {
ASF.ArchiLogger.LogNullError(nonceNode);
@@ -90,7 +90,7 @@ public sealed class SignInWithSteamController : ArchiController {
return StatusCode((int) HttpStatusCode.InternalServerError, new GenericResponse(false, Strings.FormatErrorObjectIsNull(nameof(nonceNode))));
}
string nonceValue = nonceNode.Value;
string? nonceValue = nonceNode.GetAttribute("value");
if (string.IsNullOrEmpty(nonceValue)) {
ASF.ArchiLogger.LogNullError(nonceValue);

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -22,7 +22,6 @@
// limitations under the License.
using System;
using System.ComponentModel.DataAnnotations;
using System.Composition;
using System.Text.Json.Serialization;
using System.Threading.Tasks;
@@ -36,11 +35,9 @@ namespace ArchiSteamFarm.CustomPlugins.SignInWithSteam;
[UsedImplicitly]
internal sealed class SignInWithSteamPlugin : IPlugin {
[JsonInclude]
[Required]
public string Name => nameof(SignInWithSteamPlugin);
[JsonInclude]
[Required]
public Version Version => typeof(SignInWithSteamPlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
public Task OnLoaded() {

View File

@@ -7,7 +7,6 @@
<PackageReference Include="JetBrains.Annotations" PrivateAssets="all" />
<PackageReference Include="Microsoft.CodeAnalysis.ResxSourceGenerator" PrivateAssets="all" />
<PackageReference Include="SteamKit2" IncludeAssets="compile" />
<PackageReference Include="Swashbuckle.AspNetCore.Annotations" IncludeAssets="compile" />
<PackageReference Include="System.Composition.AttributedModel" IncludeAssets="compile" />
<PackageReference Include="System.Linq.Async" IncludeAssets="compile" />
</ItemGroup>
@@ -19,4 +18,8 @@
<ItemGroup>
<EmbeddedResource Update="Localization\Strings.resx" EmitFormatMethods="true" />
</ItemGroup>
<Target Name="PostBuild" AfterTargets="PostBuildEvent">
<Copy SourceFolders="$(TargetDir)" DestinationFolder="..\ArchiSteamFarm\bin\$(Configuration)\$(TargetFramework)\plugins\$(AssemblyName)\" SkipUnchangedFiles="true" />
</Target>
</Project>

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -38,6 +38,7 @@ namespace ArchiSteamFarm.OfficialPlugins.ItemsMatcher;
internal sealed class BotCache : SerializableFile {
[JsonDisallowNull]
[JsonInclude]
[JsonObjectCreationHandling(JsonObjectCreationHandling.Populate)]
internal ConcurrentList<AssetForListing> LastAnnouncedAssetsForListing { get; private init; } = [];
internal string? LastAnnouncedTradeToken {

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -25,7 +25,6 @@ using System;
using System.Collections.Concurrent;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.Composition;
using System.Linq;
using System.Text.Json;
@@ -47,11 +46,9 @@ internal sealed class ItemsMatcherPlugin : OfficialPlugin, IBot, IBotCommand2, I
internal static readonly ConcurrentDictionary<Bot, RemoteCommunication> RemoteCommunications = new();
[JsonInclude]
[Required]
public override string Name => nameof(ItemsMatcherPlugin);
[JsonInclude]
[Required]
public override Version Version => typeof(ItemsMatcherPlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
public async Task<string?> OnBotCommand(Bot bot, EAccess access, string message, string[] args, ulong steamID = 0) {

View File

@@ -64,4 +64,20 @@
<value>Matched totalt {0} sæt denne runde.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Annoncerer {0} ({1}) med inventar lavet af {2} varer i alt på listen...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>Matchede i alt {0} varer med bot {1} ({2}), sender handelstilbud...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
<value>Mislykkedes at sende et handelstilbud til bot {0} ({1}), går videre...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>Nogle bekræftelser mislykkedes, ca. {0} ud af {1} handler blev sendt med succes.</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -64,4 +64,16 @@
<value>Ο τελικός αριθμός συνόλων που έχουν ταιριάξει είναι {0}, αυτόν τον γύρο.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Ανακοίνωση {0} ({1}) με απογραφή από στοιχεία {2} συνολικά στην καταχώρηση...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>Ταίριαξε ένα σύνολο αντικειμένων {0} με bot {1} ({2}), στέλνοντας προσφορά συναλλαγής...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
<value>Αποτυχία αποστολής μιας προσφοράς συναλλαγής στο bot {0} ({1}), με κίνηση...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
</root>

View File

@@ -60,4 +60,24 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="ActivelyMatchingItemsRound" xml:space="preserve">
<value>Berhasil mencocokkan total {0} set pada putaran ini.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Mengumumkan {0} ({1}) dengan inventaris yang terdiri dari {2} item di total pada daftar...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>Berhasil mencocokkan total {0} item dengan bot {1} ({2}), mengirimkan penawaran perdagangan...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
<value>Gagal mengirimkan penawaran perdagangan ke bot {0} ({1}), melanjutkan...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>Beberapa konfirmasi gagal, sekitar {0} dari {1} penawaran perdagangan berhasil dikirim.</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -64,6 +64,10 @@
<value>Abbinati un totale di {0} set questo round.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Annuncio {0} ({1}) con inventario fatto di elementi {2} in totale sulla lista...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>Abbinato un totale di {0} elementi tramite bot {1} ({2}), inviando un'offerta commerciale...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
@@ -73,7 +77,7 @@
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>Alcune conferme sono fallite, circa {0} su {1} sono state inviate con successo.</value>
<value>Alcune conferme non sono riuscite, circa {0} su {1} sono state inviate con successo.</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -64,4 +64,20 @@
<value>すべてのうち、{0} セットにマッチしたためこのラウンドを終了します。</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>{0}{1})をリスト上でアナウンス中です。インベントリには合計 {2} 個のアイテムが含まれています…</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>ボット {1}{2})と合計 {0} 個のアイテムが一致しました。トレードオファーを送信しています…</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
<value>ボット {0} ({1})にトレードオファーを送信できませんでした。次に進みます…</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>いくつかの確認に失敗しました。 {0} の取引から約 {1} が正常に送信されました。</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -61,15 +61,15 @@
</value>
</resheader>
<data name="ActivelyMatchingItemsRound" xml:space="preserve">
<value>{0} conjunto(s) foi(foram) associado(s) nessa rodada.</value>
<value>Total de {0} conjunto(s) correspondido(s) nesta rodada.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Anunciando {0} ({1}) com um inventário composto pelo total de {2} itens listados...</value>
<value>Anunciando {0} ({1}) com um inventário de {2} itens no total na listagem...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>{0} item(ns) correspondidos(s) com o bot {1} ({2}), enviando oferta de troca...</value>
<value>{0} item(ns) correspondido(s) com o bot {1} ({2}), enviando proposta de troca...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
@@ -77,7 +77,7 @@
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>Algumas confirmações falharam, cerca de {0} de {1} operações foram enviadas com sucesso.</value>
<value>Algumas confirmações falharam, aproximadamente {0} de {1} trocas foram enviadas com sucesso.</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -60,4 +60,24 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="ActivelyMatchingItemsRound" xml:space="preserve">
<value>Matchade totalt {0} sets denna runda.</value>
<comment>{0} will be replaced by number of sets traded</comment>
</data>
<data name="ListingAnnouncing" xml:space="preserve">
<value>Meddela {0} ({1}) med lager gjorda av {2} objekt totalt på listan...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname, {2} will be replaced with number of items in the inventory</comment>
</data>
<data name="MatchingFound" xml:space="preserve">
<value>Matchade totalt {0} objekt med bot {1} ({2}), skickar handels-erbjudande...</value>
<comment>{0} will be replaced by number of items matched, {1} will be replaced by steam ID (number), {2} will be replaced by user's nickname</comment>
</data>
<data name="TradeOfferFailed" xml:space="preserve">
<value>Det gick inte att skicka ett byteserbjudande till bot {0} ({1}), går vidare...</value>
<comment>{0} will be replaced by steam ID (number), {1} will be replaced by user's nickname'</comment>
</data>
<data name="ActivelyMatchingSomeConfirmationsFailed" xml:space="preserve">
<value>Vissa bekräftelser har misslyckats, cirka {0} av {1} skickades framgångsrikt.</value>
<comment>{0} will be replaced by amount of the trade offers that succeeded (number), {1} will be replaced by amount of the trade offers that were supposed to be sent in total (number)</comment>
</data>
</root>

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -60,14 +60,14 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
private const byte MinHeartBeatTTL = 10; // Minimum amount of minutes we must wait before sending next HeartBeat
private const byte MinimumPasswordResetCooldownDays = 5; // As imposed by Steam limits
private const byte MinimumSteamGuardEnabledDays = 15; // As imposed by Steam limits
private const byte MinPersonaStateTTL = 5; // Minimum amount of minutes we must wait before requesting persona state update
private const byte MinPersonaStateTTL = MinAnnouncementTTL; // Minimum amount of minutes we must wait before requesting persona state update
private static readonly FrozenSet<EAssetType> AcceptedMatchableTypes = new HashSet<EAssetType>(4) {
private static readonly FrozenSet<EAssetType> AcceptedMatchableTypes = [
EAssetType.Emoticon,
EAssetType.FoilTradingCard,
EAssetType.ProfileBackground,
EAssetType.TradingCard
}.ToFrozenSet();
];
private readonly Bot Bot;
private readonly Timer? HeartBeatTimer;
@@ -187,7 +187,7 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
return;
}
if ((DateTime.UtcNow < LastAnnouncement.AddMinutes(ShouldSendAnnouncementEarlier ? MinAnnouncementTTL : MaxAnnouncementTTL)) && ShouldSendHeartBeats) {
if (DateTime.UtcNow < LastAnnouncement.AddMinutes(ShouldSendAnnouncementEarlier ? MinAnnouncementTTL : MaxAnnouncementTTL)) {
return;
}
@@ -199,7 +199,7 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
await RequestsSemaphore.WaitAsync().ConfigureAwait(false);
try {
if ((DateTime.UtcNow < LastAnnouncement.AddMinutes(ShouldSendAnnouncementEarlier ? MinAnnouncementTTL : MaxAnnouncementTTL)) && ShouldSendHeartBeats) {
if (DateTime.UtcNow < LastAnnouncement.AddMinutes(ShouldSendAnnouncementEarlier ? MinAnnouncementTTL : MaxAnnouncementTTL)) {
return;
}
@@ -1276,20 +1276,7 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
Bot.ArchiLogger.LogGenericTrace($"{listedUser.SteamID}...");
byte? tradeHoldDuration = await Bot.ArchiWebHandler.GetCombinedTradeHoldDurationAgainstUser(listedUser.SteamID, listedUser.TradeToken).ConfigureAwait(false);
switch (tradeHoldDuration) {
case null:
Bot.ArchiLogger.LogGenericTrace(Strings.FormatErrorIsEmpty(nameof(tradeHoldDuration)));
continue;
case > 0 when (tradeHoldDuration.Value > maxTradeHoldDuration) || (tradeHoldDuration.Value > listedUser.MaxTradeHoldDuration):
Bot.ArchiLogger.LogGenericTrace($"{tradeHoldDuration.Value} > {maxTradeHoldDuration} || {listedUser.MaxTradeHoldDuration}");
continue;
}
HashSet<Asset> theirInventory = listedUser.Assets.Where(item => (!listedUser.MatchEverything || item.Tradable) && wantedSets.Contains((item.RealAppID, item.Type, item.Rarity)) && ((tradeHoldDuration.Value == 0) || !(item.Type is EAssetType.FoilTradingCard or EAssetType.TradingCard && CardsFarmer.SalesBlacklist.Contains(item.RealAppID)))).Select(static asset => asset.ToAsset()).ToHashSet();
HashSet<Asset> theirInventory = listedUser.Assets.Where(item => (!listedUser.MatchEverything || item.Tradable) && wantedSets.Contains((item.RealAppID, item.Type, item.Rarity))).Select(static asset => asset.ToAsset()).ToHashSet();
if (theirInventory.Count == 0) {
continue;
@@ -1297,6 +1284,8 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
skippedSetsThisUser.Clear();
byte? tradeHoldDuration = null;
Dictionary<(uint RealAppID, EAssetType Type, EAssetRarity Rarity), Dictionary<ulong, uint>> theirTradableState = MatchingUtilities.GetTradableInventoryState(theirInventory);
for (byte i = 0; i < Trading.MaxTradesPerAccount; i++) {
@@ -1335,6 +1324,10 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
match = false;
foreach ((ulong ourItem, uint ourFullAmount) in ourFullSet.Where(static item => item.Value > 1).OrderByDescending(static item => item.Value)) {
if ((tradeHoldDuration > maxTradeHoldDuration) || (tradeHoldDuration > listedUser.MaxTradeHoldDuration)) {
break;
}
if (!ourTradableSet.TryGetValue(ourItem, out uint ourTradableAmount) || (ourTradableAmount == 0)) {
continue;
}
@@ -1378,6 +1371,29 @@ internal sealed class RemoteCommunication : IAsyncDisposable, IDisposable {
}
}
// Now that we have a match, check trade hold to ensure user is valid to match against
// Since it involves remote call, we didn't do it previously, to skip checking against users with no matches for us
if (tradeHoldDuration == null) {
tradeHoldDuration = await Bot.ArchiWebHandler.GetCombinedTradeHoldDurationAgainstUser(listedUser.SteamID, listedUser.TradeToken).ConfigureAwait(false);
if (tradeHoldDuration == null) {
Bot.ArchiLogger.LogGenericTrace(Strings.FormatErrorIsEmpty(nameof(tradeHoldDuration)));
break;
}
if ((tradeHoldDuration.Value > maxTradeHoldDuration) || (tradeHoldDuration.Value > listedUser.MaxTradeHoldDuration)) {
Bot.ArchiLogger.LogGenericTrace($"{tradeHoldDuration.Value} > {maxTradeHoldDuration} || {listedUser.MaxTradeHoldDuration}");
break;
}
}
if ((tradeHoldDuration.Value > 0) && set.Type is EAssetType.FoilTradingCard or EAssetType.TradingCard && CardsFarmer.SalesBlacklist.Contains(set.RealAppID)) {
// We're not considering this set for matching due to trade hold
continue;
}
// Skip this set from the remaining of this round
skippedSetsThisTrade.Add(set);

View File

@@ -15,6 +15,10 @@
</ItemGroup>
<ItemGroup>
<EmbeddedResource Update="Localization\Strings.resx" />
<EmbeddedResource Update="Localization\Strings.resx" EmitFormatMethods="true" />
</ItemGroup>
<Target Name="PostBuild" AfterTargets="PostBuildEvent">
<Copy SourceFolders="$(TargetDir)" DestinationFolder="..\ArchiSteamFarm\bin\$(Configuration)\$(TargetFramework)\plugins\$(AssemblyName)\" SkipUnchangedFiles="true" />
</Target>
</Project>

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -135,12 +135,6 @@ internal static class Commands {
mobileAuthenticator.Init(bot);
MobileAuthenticatorHandler? mobileAuthenticatorHandler = bot.GetHandler<MobileAuthenticatorHandler>();
if (mobileAuthenticatorHandler == null) {
throw new InvalidOperationException(nameof(mobileAuthenticatorHandler));
}
ulong steamTime = await mobileAuthenticator.GetSteamTime().ConfigureAwait(false);
string? code = mobileAuthenticator.GenerateTokenForTime(steamTime);
@@ -149,10 +143,10 @@ internal static class Commands {
return bot.Commands.FormatBotResponse(Strings.FormatWarningFailedWithError(nameof(mobileAuthenticator.GenerateTokenForTime)));
}
CTwoFactor_FinalizeAddAuthenticator_Response? response = await mobileAuthenticatorHandler.FinalizeAuthenticator(bot.SteamID, activationCode, code, steamTime).ConfigureAwait(false);
CTwoFactor_FinalizeAddAuthenticator_Response? response = await MobileAuthenticatorWebHandler.FinalizeAuthenticator(bot, activationCode, code, steamTime).ConfigureAwait(false);
if (response == null) {
return bot.Commands.FormatBotResponse(Strings.FormatWarningFailedWithError(nameof(mobileAuthenticatorHandler.FinalizeAuthenticator)));
return bot.Commands.FormatBotResponse(Strings.FormatWarningFailedWithError(nameof(MobileAuthenticatorWebHandler.FinalizeAuthenticator)));
}
if (!response.success) {
@@ -319,18 +313,12 @@ internal static class Commands {
return bot.Commands.FormatBotResponse(Strings.BotNotConnected);
}
MobileAuthenticatorHandler? mobileAuthenticatorHandler = bot.GetHandler<MobileAuthenticatorHandler>();
if (mobileAuthenticatorHandler == null) {
throw new InvalidOperationException(nameof(mobileAuthenticatorHandler));
}
string deviceID = $"android:{Guid.NewGuid()}";
CTwoFactor_AddAuthenticator_Response? response = await mobileAuthenticatorHandler.AddAuthenticator(bot.SteamID, deviceID).ConfigureAwait(false);
CTwoFactor_AddAuthenticator_Response? response = await MobileAuthenticatorWebHandler.AddAuthenticator(bot, deviceID).ConfigureAwait(false);
if (response == null) {
return bot.Commands.FormatBotResponse(Strings.WarningFailed);
return bot.Commands.FormatBotResponse(Strings.FormatWarningFailedWithError(nameof(MobileAuthenticatorWebHandler.AddAuthenticator)));
}
EResult result = (EResult) response.status;

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -1,118 +0,0 @@
// ----------------------------------------------------------------------------------------------
// _ _ _ ____ _ _____
// / \ _ __ ___ | |__ (_)/ ___| | |_ ___ __ _ _ __ ___ | ___|__ _ _ __ _ __ ___
// / _ \ | '__|/ __|| '_ \ | |\___ \ | __|/ _ \ / _` || '_ ` _ \ | |_ / _` || '__|| '_ ` _ \
// / ___ \ | | | (__ | | | || | ___) || |_| __/| (_| || | | | | || _|| (_| || | | | | | | |
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// |
// http://www.apache.org/licenses/LICENSE-2.0
// |
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
using System;
using System.Threading.Tasks;
using ArchiSteamFarm.Core;
using ArchiSteamFarm.NLog;
using SteamKit2;
using SteamKit2.Internal;
namespace ArchiSteamFarm.OfficialPlugins.MobileAuthenticator;
internal sealed class MobileAuthenticatorHandler : ClientMsgHandler {
private readonly ArchiLogger ArchiLogger;
private readonly TwoFactor UnifiedTwoFactorService;
internal MobileAuthenticatorHandler(ArchiLogger archiLogger, SteamUnifiedMessages steamUnifiedMessages) {
ArgumentNullException.ThrowIfNull(archiLogger);
ArgumentNullException.ThrowIfNull(steamUnifiedMessages);
ArchiLogger = archiLogger;
UnifiedTwoFactorService = steamUnifiedMessages.CreateService<TwoFactor>();
}
public override void HandleMsg(IPacketMsg packetMsg) => ArgumentNullException.ThrowIfNull(packetMsg);
internal async Task<CTwoFactor_AddAuthenticator_Response?> AddAuthenticator(ulong steamID, string deviceID) {
if ((steamID == 0) || !new SteamID(steamID).IsIndividualAccount) {
throw new ArgumentOutOfRangeException(nameof(steamID));
}
ArgumentException.ThrowIfNullOrEmpty(deviceID);
if (Client == null) {
throw new InvalidOperationException(nameof(Client));
}
if (!Client.IsConnected) {
return null;
}
CTwoFactor_AddAuthenticator_Request request = new() {
authenticator_type = 1,
authenticator_time = Utilities.GetUnixTime(),
device_identifier = deviceID,
steamid = steamID
};
SteamUnifiedMessages.ServiceMethodResponse<CTwoFactor_AddAuthenticator_Response> response;
try {
response = await UnifiedTwoFactorService.AddAuthenticator(request).ToLongRunningTask().ConfigureAwait(false);
} catch (Exception e) {
ArchiLogger.LogGenericWarningException(e);
return null;
}
return response.Result == EResult.OK ? response.Body : null;
}
internal async Task<CTwoFactor_FinalizeAddAuthenticator_Response?> FinalizeAuthenticator(ulong steamID, string activationCode, string authenticatorCode, ulong authenticatorTime) {
if ((steamID == 0) || !new SteamID(steamID).IsIndividualAccount) {
throw new ArgumentOutOfRangeException(nameof(steamID));
}
ArgumentException.ThrowIfNullOrEmpty(activationCode);
ArgumentException.ThrowIfNullOrEmpty(authenticatorCode);
ArgumentOutOfRangeException.ThrowIfNegativeOrZero(authenticatorTime);
if (Client == null) {
throw new InvalidOperationException(nameof(Client));
}
if (!Client.IsConnected) {
return null;
}
CTwoFactor_FinalizeAddAuthenticator_Request request = new() {
activation_code = activationCode,
authenticator_code = authenticatorCode,
authenticator_time = authenticatorTime,
steamid = steamID
};
SteamUnifiedMessages.ServiceMethodResponse<CTwoFactor_FinalizeAddAuthenticator_Response> response;
try {
response = await UnifiedTwoFactorService.FinalizeAddAuthenticator(request).ToLongRunningTask().ConfigureAwait(false);
} catch (Exception e) {
ArchiLogger.LogGenericWarningException(e);
return null;
}
return response.Result == EResult.OK ? response.Body : null;
}
}

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -22,9 +22,7 @@
// limitations under the License.
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.Composition;
using System.Diagnostics.CodeAnalysis;
using System.Text.Json.Serialization;
@@ -40,13 +38,11 @@ namespace ArchiSteamFarm.OfficialPlugins.MobileAuthenticator;
[Export(typeof(IPlugin))]
[SuppressMessage("ReSharper", "MemberCanBeFileLocal")]
internal sealed class MobileAuthenticatorPlugin : OfficialPlugin, IBotCommand2, IBotSteamClient {
internal sealed class MobileAuthenticatorPlugin : OfficialPlugin, IBotCommand2 {
[JsonInclude]
[Required]
public override string Name => nameof(MobileAuthenticatorPlugin);
[JsonInclude]
[Required]
public override Version Version => typeof(MobileAuthenticatorPlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
public async Task<string?> OnBotCommand(Bot bot, EAccess access, string message, string[] args, ulong steamID = 0) {
@@ -69,25 +65,6 @@ internal sealed class MobileAuthenticatorPlugin : OfficialPlugin, IBotCommand2,
return await Commands.OnBotCommand(bot, access, message, args, steamID).ConfigureAwait(false);
}
public Task OnBotSteamCallbacksInit(Bot bot, CallbackManager callbackManager) {
ArgumentNullException.ThrowIfNull(bot);
ArgumentNullException.ThrowIfNull(callbackManager);
return Task.CompletedTask;
}
public Task<IReadOnlyCollection<ClientMsgHandler>?> OnBotSteamHandlersInit(Bot bot) {
ArgumentNullException.ThrowIfNull(bot);
SteamUnifiedMessages? steamUnifiedMessages = bot.GetHandler<SteamUnifiedMessages>();
if (steamUnifiedMessages == null) {
throw new InvalidOperationException(nameof(steamUnifiedMessages));
}
return Task.FromResult<IReadOnlyCollection<ClientMsgHandler>?>(new HashSet<ClientMsgHandler>(1) { new MobileAuthenticatorHandler(bot.ArchiLogger, steamUnifiedMessages) });
}
public override Task OnLoaded() {
Utilities.WarnAboutIncompleteTranslation(Strings.ResourceManager);

View File

@@ -0,0 +1,174 @@
// ----------------------------------------------------------------------------------------------
// _ _ _ ____ _ _____
// / \ _ __ ___ | |__ (_)/ ___| | |_ ___ __ _ _ __ ___ | ___|__ _ _ __ _ __ ___
// / _ \ | '__|/ __|| '_ \ | |\___ \ | __|/ _ \ / _` || '_ ` _ \ | |_ / _` || '__|| '_ ` _ \
// / ___ \ | | | (__ | | | || | ___) || |_| __/| (_| || | | | | || _|| (_| || | | | | | | |
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// |
// http://www.apache.org/licenses/LICENSE-2.0
// |
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Threading.Tasks;
using ArchiSteamFarm.Core;
using ArchiSteamFarm.Localization;
using ArchiSteamFarm.Steam;
using ArchiSteamFarm.Steam.Integration;
using ArchiSteamFarm.Web;
using SteamKit2;
using SteamKit2.Internal;
namespace ArchiSteamFarm.OfficialPlugins.MobileAuthenticator;
internal static class MobileAuthenticatorWebHandler {
private const string TwoFactorService = "ITwoFactorService";
internal static async Task<CTwoFactor_AddAuthenticator_Response?> AddAuthenticator(Bot bot, string deviceID) {
ArgumentNullException.ThrowIfNull(bot);
ArgumentException.ThrowIfNullOrEmpty(deviceID);
if (!bot.IsConnectedAndLoggedOn) {
return null;
}
string? accessToken = bot.AccessToken;
if (string.IsNullOrEmpty(accessToken)) {
return null;
}
const string endpoint = "AddAuthenticator";
HttpMethod method = HttpMethod.Post;
CTwoFactor_AddAuthenticator_Request request = new() {
authenticator_time = Utilities.GetUnixTime(),
authenticator_type = 1,
device_identifier = deviceID,
steamid = bot.SteamID
};
Dictionary<string, object?> arguments = new(1, StringComparer.Ordinal) {
{ "access_token", accessToken }
};
using WebAPI.AsyncInterface twoFactorService = bot.SteamConfiguration.GetAsyncWebAPIInterface(TwoFactorService);
twoFactorService.Timeout = bot.ArchiWebHandler.WebBrowser.Timeout;
WebAPI.WebAPIResponse<CTwoFactor_AddAuthenticator_Response>? response = null;
for (byte i = 0; (i < WebBrowser.MaxTries) && (response == null); i++) {
if ((i > 0) && (ArchiWebHandler.WebLimiterDelay > 0)) {
await Task.Delay(ArchiWebHandler.WebLimiterDelay).ConfigureAwait(false);
}
if (Debugging.IsUserDebugging) {
bot.ArchiLogger.LogGenericDebug($"{method} {bot.SteamConfiguration.WebAPIBaseAddress}{TwoFactorService}/{endpoint}");
}
try {
response = await ArchiWebHandler.WebLimitRequest(
bot.SteamConfiguration.WebAPIBaseAddress,
// ReSharper disable once AccessToDisposedClosure
async () => await twoFactorService.CallProtobufAsync<CTwoFactor_AddAuthenticator_Response, CTwoFactor_AddAuthenticator_Request>(method, endpoint, request, extraArgs: arguments).ConfigureAwait(false)
).ConfigureAwait(false);
} catch (TaskCanceledException e) {
bot.ArchiLogger.LogGenericDebuggingException(e);
} catch (Exception e) {
bot.ArchiLogger.LogGenericWarningException(e);
}
}
if (response == null) {
bot.ArchiLogger.LogGenericWarning(Strings.FormatErrorRequestFailedTooManyTimes(WebBrowser.MaxTries));
return null;
}
return response.Body;
}
internal static async Task<CTwoFactor_FinalizeAddAuthenticator_Response?> FinalizeAuthenticator(Bot bot, string activationCode, string authenticatorCode, ulong authenticatorTime) {
ArgumentNullException.ThrowIfNull(bot);
ArgumentException.ThrowIfNullOrEmpty(activationCode);
ArgumentException.ThrowIfNullOrEmpty(authenticatorCode);
ArgumentOutOfRangeException.ThrowIfZero(authenticatorTime);
if (!bot.IsConnectedAndLoggedOn) {
return null;
}
string? accessToken = bot.AccessToken;
if (string.IsNullOrEmpty(accessToken)) {
return null;
}
const string endpoint = "FinalizeAddAuthenticator";
HttpMethod method = HttpMethod.Post;
CTwoFactor_FinalizeAddAuthenticator_Request request = new() {
activation_code = activationCode,
authenticator_code = authenticatorCode,
authenticator_time = authenticatorTime,
steamid = bot.SteamID
};
Dictionary<string, object?> arguments = new(1, StringComparer.Ordinal) {
{ "access_token", accessToken }
};
using WebAPI.AsyncInterface twoFactorService = bot.SteamConfiguration.GetAsyncWebAPIInterface(TwoFactorService);
twoFactorService.Timeout = bot.ArchiWebHandler.WebBrowser.Timeout;
WebAPI.WebAPIResponse<CTwoFactor_FinalizeAddAuthenticator_Response>? response = null;
for (byte i = 0; (i < WebBrowser.MaxTries) && (response == null); i++) {
if ((i > 0) && (ArchiWebHandler.WebLimiterDelay > 0)) {
await Task.Delay(ArchiWebHandler.WebLimiterDelay).ConfigureAwait(false);
}
if (Debugging.IsUserDebugging) {
bot.ArchiLogger.LogGenericDebug($"{method} {bot.SteamConfiguration.WebAPIBaseAddress}{TwoFactorService}/{endpoint}");
}
try {
response = await ArchiWebHandler.WebLimitRequest(
bot.SteamConfiguration.WebAPIBaseAddress,
// ReSharper disable once AccessToDisposedClosure
async () => await twoFactorService.CallProtobufAsync<CTwoFactor_FinalizeAddAuthenticator_Response, CTwoFactor_FinalizeAddAuthenticator_Request>(method, endpoint, request, extraArgs: arguments).ConfigureAwait(false)
).ConfigureAwait(false);
} catch (TaskCanceledException e) {
bot.ArchiLogger.LogGenericDebuggingException(e);
} catch (Exception e) {
bot.ArchiLogger.LogGenericWarningException(e);
}
}
if (response == null) {
bot.ArchiLogger.LogGenericWarning(Strings.FormatErrorRequestFailedTooManyTimes(WebBrowser.MaxTries));
return null;
}
return response.Body;
}
}

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -25,7 +25,6 @@ using System;
using System.Collections.Concurrent;
using System.Collections.Frozen;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Composition;
using System.Diagnostics.CodeAnalysis;
using System.Diagnostics.Metrics;
@@ -48,11 +47,9 @@ namespace ArchiSteamFarm.OfficialPlugins.Monitoring;
[Export(typeof(IPlugin))]
[SuppressMessage("ReSharper", "MemberCanBeFileLocal")]
internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialGitHubPluginUpdates, IWebInterface, IWebServiceProvider, IBotTradeOfferResults {
internal sealed class MonitoringPlugin : OfficialPlugin, IBot, IBotTradeOfferResults, IDisposable, IOfficialGitHubPluginUpdates, IWebInterface, IWebServiceProvider {
private const string MeterName = SharedInfo.AssemblyName;
private const string MetricNamePrefix = "asf";
private const string UnknownLabelValueFallback = "unknown";
private static readonly Measurement<byte> BuildInfo = new(
@@ -73,13 +70,11 @@ internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialG
private static FrozenSet<Measurement<int>>? PluginMeasurements;
[JsonInclude]
[Required]
public override string Name => nameof(MonitoringPlugin);
public string RepositoryName => SharedInfo.GithubRepo;
[JsonInclude]
[Required]
public override Version Version => typeof(MonitoringPlugin).Assembly.GetName().Version ?? throw new InvalidOperationException(nameof(Version));
private readonly ConcurrentDictionary<Bot, TradeStatistics> TradeStatistics = new();
@@ -88,6 +83,20 @@ internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialG
public void Dispose() => Meter?.Dispose();
public Task OnBotDestroy(Bot bot) {
ArgumentNullException.ThrowIfNull(bot);
TradeStatistics.TryRemove(bot, out _);
return Task.CompletedTask;
}
public Task OnBotInit(Bot bot) {
ArgumentNullException.ThrowIfNull(bot);
return Task.CompletedTask;
}
public Task OnBotTradeOfferResults(Bot bot, IReadOnlyCollection<ParseTradeResult> tradeResults) {
ArgumentNullException.ThrowIfNull(bot);
ArgumentNullException.ThrowIfNull(tradeResults);
@@ -120,8 +129,11 @@ internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialG
InitializeMeter();
services.AddOpenTelemetry().WithMetrics(
builder => {
if (Meter == null) {
throw new InvalidOperationException(nameof(Meter));
}
services.AddOpenTelemetry().WithMetrics(builder => {
builder.AddPrometheusExporter(static config => config.ScrapeEndpointPath = "/Api/metrics");
builder.AddRuntimeInstrumentation();
builder.AddAspNetCoreInstrumentation();
@@ -133,17 +145,18 @@ internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialG
public override Task OnLoaded() => Task.CompletedTask;
[MemberNotNull(nameof(Meter))]
private void InitializeMeter() {
if (Meter != null) {
return;
}
PluginMeasurements = new HashSet<Measurement<int>>(3) {
new(PluginsCore.ActivePlugins.Count),
new(PluginsCore.ActivePlugins.Count(static plugin => plugin is OfficialPlugin), new KeyValuePair<string, object?>(TagNames.PluginType, "official")),
new(PluginsCore.ActivePlugins.Count(static plugin => plugin is not OfficialPlugin), new KeyValuePair<string, object?>(TagNames.PluginType, "custom"))
}.ToFrozenSet();
int officialPluginCount = PluginsCore.ActivePlugins.Count(static plugin => plugin is OfficialPlugin);
PluginMeasurements = [
new Measurement<int>(PluginsCore.ActivePlugins.Count),
new Measurement<int>(officialPluginCount, new KeyValuePair<string, object?>(TagNames.PluginType, "official")),
new Measurement<int>(PluginsCore.ActivePlugins.Count - officialPluginCount, new KeyValuePair<string, object?>(TagNames.PluginType, "custom"))
];
Meter = new Meter(MeterName, Version.ToString());
@@ -258,8 +271,7 @@ internal sealed class MonitoringPlugin : OfficialPlugin, IDisposable, IOfficialG
);
Meter.CreateObservableCounter(
$"{MetricNamePrefix}_bot_trades", () => TradeStatistics.SelectMany<KeyValuePair<Bot, TradeStatistics>, Measurement<int>>(
static kv => [
$"{MetricNamePrefix}_bot_trades", () => TradeStatistics.SelectMany<KeyValuePair<Bot, TradeStatistics>, Measurement<int>>(static kv => [
new Measurement<int>(
kv.Value.AcceptedOffers,
new KeyValuePair<string, object?>(TagNames.BotName, kv.Key.BotName),

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");
@@ -22,12 +22,13 @@
// limitations under the License.
using System;
using System.Threading;
using ArchiSteamFarm.Steam.Exchange;
namespace ArchiSteamFarm.OfficialPlugins.Monitoring;
internal sealed class TradeStatistics {
private readonly object Lock = new();
private readonly Lock Lock = new();
internal int AcceptedOffers { get; private set; }
internal int BlacklistedOffers { get; private set; }

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -7,7 +7,6 @@
<PackageReference Include="JetBrains.Annotations" PrivateAssets="all" />
<PackageReference Include="Microsoft.CodeAnalysis.ResxSourceGenerator" PrivateAssets="all" />
<PackageReference Include="SteamKit2" IncludeAssets="compile" />
<PackageReference Include="Swashbuckle.AspNetCore.Annotations" IncludeAssets="compile" />
<PackageReference Include="System.Composition.AttributedModel" IncludeAssets="compile" />
</ItemGroup>
@@ -18,4 +17,8 @@
<ItemGroup>
<EmbeddedResource Update="Localization\Strings.resx" EmitFormatMethods="true" />
</ItemGroup>
<Target Name="PostBuild" AfterTargets="PostBuildEvent">
<Copy SourceFolders="$(TargetDir)" DestinationFolder="..\ArchiSteamFarm\bin\$(Configuration)\$(TargetFramework)\plugins\$(AssemblyName)\" SkipUnchangedFiles="true" />
</Target>
</Project>

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -6,7 +6,7 @@
// /_/ \_\|_| \___||_| |_||_||____/ \__|\___| \__,_||_| |_| |_||_| \__,_||_| |_| |_| |_|
// ----------------------------------------------------------------------------------------------
// |
// Copyright 2015-2024 Łukasz "JustArchi" Domeradzki
// Copyright 2015-2025 Łukasz "JustArchi" Domeradzki
// Contact: JustArchi@JustArchi.net
// |
// Licensed under the Apache License, Version 2.0 (the "License");

View File

@@ -104,10 +104,7 @@
<value>Приключи събирането на {0} информация за играта или приложението.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Успешно извлечени {0} от {1} депо ключове.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Приключи събирането на всички ключове за депа за общо {0} игри или проложения.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Úspěšně načteno {0} z {1} depot klíčů.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Dokončeno {0} z {1} požadavků na sklad</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Načítání všech tokenbů úložišť, celkem z {0} aplikací bylo dokončeno.</value>

View File

@@ -60,33 +60,115 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="PluginDisabledMissingBuildToken" xml:space="preserve">
<value>{0} er blevet deaktiveret på grund af en manglende build token</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginDisabledInConfig" xml:space="preserve">
<value>{0} er i øjeblikket deaktiveret i henhold til din konfiguration. Hvis du vil hjælpe SteamDB i dataindsendelse, så tjek vores wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} er blevet initialiseret med succes, tak på forhånd for din hjælp. Den første indsendelse vil ske i cirka {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} kunne ikke indlæses, en ny instans vil blive initialiseret...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
<value>Der er ingen apps, der kræver en opdatering i denne bot instans.</value>
</data>
<data name="BotRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Henter i alt {0} app-adgangstokens...</value>
<comment>{0} will be replaced by the number (total count) of app access tokens being retrieved</comment>
</data>
<data name="BotRetrievingAppAccessTokens" xml:space="preserve">
<value>Henter {0} app-adgangstokens...</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppAccessTokens" xml:space="preserve">
<value>Færdig med at hente {0} app-adgangstegn.</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Færdig med at hente i alt {0} app-adgangstokiner.</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>Henter alle depoter for i alt {0} apps...</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>Retrieving {0} app infos...</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>Færdig med at hente {0} app-info.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Færdig {0} ud af {1} depot nøgleanmodninger.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Færdig med at hente alle depot nøgler for i alt {0} apps.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Der er ingen nye data at indsende, alt er opdateret.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Kunne ikke indsende data, da der ikke er noget gyldigt SteamID sæt, som vi kunne klassificere som bidragsyder. Overvej opsætning af {0} egenskab.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>Indsender i alt registrerede apps/pakker/depots: {0}/{1}/{2}...</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>Indsendelsen er mislykkedes på grund af for mange anmodninger, vi vil prøve igen om cirka {0} fra nu.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>Dataene er blevet indsendt. Serveren har registreret i alt nye apps/packages/depots: {0} ({1} verificeret)/{2} ({3} verificeret)/{4} ({5} verificeret).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Nye apps: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedApps" xml:space="preserve">
<value>Verificerede apps: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewPackages" xml:space="preserve">
<value>Nye pakker: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedPackages" xml:space="preserve">
<value>Verificerede pakker: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Nye depoter: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Verificerede depot: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} initialiseret, plugin vil ikke løse nogen af dem: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>Indlæser STD global cache...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Validerer STD global cache integritet...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Mislykkedes at verificere STD global cache integritet. Dette tyder på en potentiel fil / hukommelse korruption, en ny instans vil blive initialiseret i stedet.</value>
</data>
</root>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Erfolgreich {0} von {1} Depot-Schlüsseln abgerufen.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>{0} von {1} Depot-Schlüsselanfragen beendet.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Abruf aller Depotschlüssel für insgesamt {0} Apps abgeschlossen.</value>

View File

@@ -68,7 +68,10 @@
<value>{0} είναι απενεργοποιημένο σύμφωνα με τις ρυθμίσεις σας. Αν θέλετε να βοηθήσετε το SteamDB στην υποβολή δεδομένων, παρακαλώ ελέγξτε το wiki μας.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>Το {0} έχει αρχικοποιηθεί με επιτυχία, σας ευχαριστώ εκ των προτέρων για τη βοήθειά σας. Η πρώτη υποβολή θα γίνει σε περίπου {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} δεν μπόρεσε να φορτωθεί, μια νέα παρουσία θα αρχικοποιηθεί...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
@@ -104,7 +107,10 @@
<value>Ολοκληρώθηκε η ανάκτηση {0} πληροφοριών εφαρμογών.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Ολοκληρώθηκε το {0} από τα αιτήματα κλειδιού depot {1}.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Ολοκληρώθηκε η ανάκτηση όλων των κλειδιών αποθηκών για συνολικά {0} εφαρμογές.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Se recuperaron exitosamente {0} de {1} claves de depósito.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Se completaron {0} de {1} solicitudes de clave de depósito.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Se han recuperado todas las claves de depósito para un total de {0} aplicaciones.</value>

View File

@@ -107,10 +107,7 @@
<value>دریافت اطلاعات {0} برنامه با موفقیت انجام شد.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>تعداد {0} از {1} کلید های depot با موفقیت دریافت شد.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>دریافت تمامی کلید های depot برای تعداد {0} برنامه انجام شد.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>

View File

@@ -68,7 +68,10 @@
<value>{0} on tällä hetkellä poistettu käytöstä asetuksistasi. Jos haluat auttaa SteamDB:tä tietojen lähettämisessä, ole hyvä ja tutustu wikimme.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} on alustettu onnistuneesti, kiitos etukäteen avustasi. Ensimmäiseen lähetykseen on noin {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} ei voitu ladata. Uusi instanssi alustetaan...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
@@ -105,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Onnistuneesti haettu {0}/{1} depot-avaimesta.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Suoritettiin {0}/{1} depot-avaimien pyynnöistä.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Saatiin haettua kaikki depot-avaimet yhteensä {0} sovellukselle.</value>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Récupération réussie de {0} sur {1} clés de dépôts.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Récupération de {0} sur {1} demandes de clés de dépôt terminée.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Fin de la récupération de toutes les clés de dépôts pour un total de {0} applications.</value>

View File

@@ -60,33 +60,115 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="PluginDisabledMissingBuildToken" xml:space="preserve">
<value>{0} telah dinonaktifkan karena token build yang hilang</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginDisabledInConfig" xml:space="preserve">
<value>{0} saat ini dinonaktifkan sesuai konfigurasi Anda. Jika Anda ingin membantu SteamDB dalam pengiriman data, silakan lihat wiki kami.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} telah berhasil diinisialisasi, terima kasih sebelumnya atas bantuan Anda. Pengiriman pertama akan terjadi dalam sekitar {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} tidak dapat dimuat, instansi baru akan diinisialisasi...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
<value>Tidak ada aplikasi yang memerlukan penyegaran pada instansi bot ini.</value>
</data>
<data name="BotRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Memuat total {0} token akses aplikasi...</value>
<comment>{0} will be replaced by the number (total count) of app access tokens being retrieved</comment>
</data>
<data name="BotRetrievingAppAccessTokens" xml:space="preserve">
<value>Memuat {0} token akses aplikasi...</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppAccessTokens" xml:space="preserve">
<value>Selesai memuat {0} token akses aplikasi.</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Selesai memuat total {0} token akses aplikasi.</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>Memuat semua depot untuk total {0} aplikasi...</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>Memuat {0} informasi aplikasi...</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>Selesai memuat {0} informasi aplikasi.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Selesai {0} dari {1} depot key yang di minta.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Selesai memuat semua kunci depot untuk total {0} aplikasi.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Tidak ada data baru untuk dikirim, semuanya sudah terbarui.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Gagal mengirim data karena tidak ada SteamID yang valid yang dapat kami klasifikasikan sebagai kontributor. Pertimbangkan untuk mengatur properti {0}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>Mengirim total aplikasi/paket/depot yang terdaftar: {0}/{1}/{2}...</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>Pengiriman gagal karena terlalu banyak permintaan yang dikirim, kami akan mencoba lagi dalam sekitar {0} dari sekarang.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>Data telah berhasil dikirim. Server telah mendaftarkan total aplikasi/paket/depot baru: {0} ({1} terverifikasi)/{2} ({3} terverifikasi)/{4} ({5} terverifikasi).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Aplikasi baru: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedApps" xml:space="preserve">
<value>Aplikasi yang terverifikasi: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewPackages" xml:space="preserve">
<value>Paket baru: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedPackages" xml:space="preserve">
<value>Paket yang terverifikasi: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Depot baru: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Depot yang terverifikasi: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} diinisialisasi, plugin ini tidak akan memecahkan salah satu dari ini: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>Memuat cache global STD...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Memvalidasi integritas cache global STD...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Gagal memverifikasi integritas cache global STD. Ini menunjukkan potensi kerusakan file/memori, instansi baru akan diinisialisasi sebagai gantinya.</value>
</data>
</root>

View File

@@ -68,9 +68,12 @@
<value>{0} è attualmente disabilitato in base alla tua configurazione. Se desideri aiutare SteamDB nell'invio dei dati, controlla la nostra wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} è stato inizializzato con successo, grazie in anticipo per il tuo aiuto. Il primo invio avverrà tra circa {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} non può essere caricato, una nuova richiesta verrà iniziata...</value>
<value>{0} non può essere caricato, verrà inizializzata una nuova istanza...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
@@ -105,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Recuperate {0} chiavi depot su {1} con successo.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Hai completato le richieste di chiave del deposito {0} su {1}.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Finito il recupero di tutte le chiavi del deposito per un totale di {0} applicazioni.</value>
@@ -116,7 +119,7 @@
<value>Non ci sono nuovi dati da inviare, tutto è aggiornato.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Impossibile inviare i dati perché non c'è uno SteamID impostato valido che potremmo classificare come contributore. Considera di impostare delle proprietà {0}.</value>
<value>Impossibile inviare i dati perché non è impostato un SteamID valido che possa essere classificato come contributore. Considera di configurare la proprietà {0}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">

View File

@@ -60,25 +60,80 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="PluginDisabledMissingBuildToken" xml:space="preserve">
<value>ビルドトークンが見つからないため、{0} は無効化されました</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginDisabledInConfig" xml:space="preserve">
<value>{0} は現在の設定により無効化されています。SteamDB へのデータ提供に協力いただける場合は、当プロジェクトの Wiki をご覧ください。</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} は正常に初期化されました。ご協力ありがとうございます。最初の送信はおおよそ {1} 後に行われます。</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} を読み込むことができませんでした。新しいインスタンスを初期化します…</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
<value>このボットでは更新が必要なアプリはありません。</value>
</data>
<data name="BotRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>合計 {0} 個のアプリアクセストークンを取得中…</value>
<comment>{0} will be replaced by the number (total count) of app access tokens being retrieved</comment>
</data>
<data name="BotRetrievingAppAccessTokens" xml:space="preserve">
<value>{0} 個のアプリアクセストークンを取得中…</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppAccessTokens" xml:space="preserve">
<value>{0} 個のアプリアクセストークンの取得が完了しました。</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>合計 {0} 個のアプリアクセストークンの取得が完了しました。</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>合計 {0} 個のアプリに対する全デポを取得中…</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>{0} 個のアプリ情報を取得中…</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>{0} 個のアプリ情報の取得が完了しました。</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>{1} 件中 {0} 件のデポキーリクエストが完了しました。</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>合計 {0} 個のアプリに対するすべてのデポキー取得が完了しました。</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>送信する新しいデータはありません。すべて最新の状態です。</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>寄稿者として分類可能な有効な Steam Id が設定されていないため、データを送信できませんでした。{0} プロパティの設定を検討してください。</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>登録されたアプリ/パッケージ/デポを合計 {0}/{1}/{2} 件送信中…</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>リクエストが多すぎたため送信に失敗しました。約 {0} 後に再試行します。</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>データは正常に送信されました。サーバーは新規アプリ/パッケージ/デポを合計 {0}(うち {1} 件が確認済み)/{2}{3} 件確認済み)/{4}{5} 件確認済み)として登録しました。</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>新しいアプリ: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
@@ -95,10 +150,25 @@
<value>認証済みパッケージ: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>新しいデポ: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>検証済みのデポ: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} を初期化しました。このプラグインは次の項目には対応しません: {1}。</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>STD のグローバルキャッシュを読み込み中…</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>STD のグローバルキャッシュの整合性を検証中…</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>STD のグローバルキャッシュの整合性を検証できませんでした。ファイルまたはメモリの破損が疑われます。新しいインスタンスを初期化します。</value>
</data>
</root>

View File

@@ -121,7 +121,9 @@
<data name="LoadingGlobalCache" xml:space="preserve">
<value>STD 글로벌 캐시 로드 중...</value>
</data>
</root>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Veiksmīgi izgūtas {0} no {1} depot atslēgām.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Pabeigts {0} no {1} noliktavas atslēgu pieprasījumiem.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Pabeigta visu depot atslēgu izgūšana, kopā {0} lietotnēm.</value>

View File

@@ -68,7 +68,10 @@
<value>{0} is momenteel uitgeschakeld volgens uw configuratie. Als je SteamDB wilt helpen bij het indienen van gegevens, bekijk dan onze wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} is met succes geïnitialiseerd. Alvast bedankt voor uw hulp. De eerste uitwerking zal gebeuren in ongeveer {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} kon niet worden geladen, een nieuwe instantie zal worden geïnitialiseerd...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
@@ -105,15 +108,32 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Succesvol {0} van de {1} depotsleutels opgehaald.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Klaar {0} van {1} depot sleutelverzoeken.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Ophalen van alle depot keys voltooid voor een totaal van {0} apps.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Er zijn geen nieuwe gegevens om in te dienen, alles is up-to-date.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Kon de gegevens niet indienen omdat er geen geldige SteamID is die we als bijdrager kunnen classificeren. Overweeg het instellen van {0} property.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>Verzenden van een totaal van geregistreerde apps/packages/depos: {0}/{1}/{2}...</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>De indiening is mislukt door te veel verzonden, we zullen het vanaf nu opnieuw proberen in ongeveer {0}.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>De gegevens zijn succesvol ingediend. De server heeft een totaal van nieuwe apps/pakketten/depots: {0} ({1} geverifieerd)/{2} ({3} geverifieerd)/{4} ({5} geverifieerd).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Nieuwe apps: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
@@ -130,10 +150,25 @@
<value>Geverifieerde pakketten: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Nieuwe depoten: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Geverifieerde depot: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} geïnitialiseerd, de plugin zal geen van deze oplossen: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>STD global cache laden...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Valideren van STD globale cache integriteit...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Kon de wereldwijde STD cache integriteit niet verifiëren. Dit suggereert een potentiële bestands/geheugencorruptie, een nieuw exemplaar zal in plaats daarvan worden geïnitialiseerd.</value>
</data>
</root>

View File

@@ -60,33 +60,112 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="PluginDisabledMissingBuildToken" xml:space="preserve">
<value>{0} har blitt deaktivert på grunn av et manglende byggetoken</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginDisabledInConfig" xml:space="preserve">
<value>{0} er for øyeblikket deaktivert i henhold til din konfigurasjon. Hvis du vil hjelpe SteamDB med datainnsending, vennligst sjekk ut vår wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} har blitt igangsatt vellykket, takk for din hjelp. Den første innsending vil skje i omtrent {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} kunne ikke lastes inn, en frisk forekomst vil bli initialisert...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
<value>Det er ingen programmer som krever en oppdatering på denne botthendelsen.</value>
</data>
<data name="BotRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Henter de totale {0} app-tilgangstegener...</value>
<comment>{0} will be replaced by the number (total count) of app access tokens being retrieved</comment>
</data>
<data name="BotRetrievingAppAccessTokens" xml:space="preserve">
<value>Henter {0} app-tilgangstokene...</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppAccessTokens" xml:space="preserve">
<value>Ferdig med å hente {0} app-tilgangsnøkkler.</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Ferdig med å hente totalt {0} app-tilgangsnøkkler.</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>Henter alle depoter for en total {0} apper...</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>Retrieving {0} app infos...</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>Ferdig med å hente {0} app infos.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Ferdig med {0} av {1} lagerets viktigste forespørsler.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Fullførte henting av alle depot-nøkler for totalt {0} apper.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Det finnes ingen nye data, alt er oppdatert.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Kunne ikke sende inn data fordi det ikke er gyldig SteamID satt som vi kan klassifisere som bidragsyter. Vurder å sette opp {0} egenskapen.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>Innsendingen mislyktes på grunn av for mange forespørsler sendt, vi prøver igjen om lag {0} nå.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>Dataene har blitt sendt inn. Serveren har registrert totalt nye applikasjoner/pakker/depoter: {0} ({1} verifisert)/{2} ({3} bekreftet)/{4} ({5} verifisert).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Nye apper: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedApps" xml:space="preserve">
<value>Verifiserte apper: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewPackages" xml:space="preserve">
<value>Nye pakker: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedPackages" xml:space="preserve">
<value>Verifiserte pakker: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Nye depoter: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Verifiserte depoter: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} initialisert, utvidelsen vil ikke løse noen av disse: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>Laster STD global cache...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Validerer STD global cache integritet...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Kan ikke verifisere STD globale cachens integritet. Dette foreslår en potensiell fil-/minnesorpsjon, et frisk eksempel vil bli initialisert i stedet.</value>
</data>
</root>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Pomyślnie pobrano {0} z {1} kluczy magazynu.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Zakończono {0} z {1} żądań klucza magazynu.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Zakończono pobieranie wszystkich kluczy magazynu dla {0} aplikacji.</value>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>{0} de {1} chaves de depots recuperadas com sucesso.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Concluído {0} de {1} solicitações de chave do depot.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Recuperamos códigos de acesso para {0} aplicativos.</value>

View File

@@ -68,7 +68,10 @@
<value>{0} está atualmente desativado de acordo com a sua configuração. Se quiser ajudar o SteamDB na submissão de dados, por favor confira o nosso wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} foi inicializado com sucesso, obrigado antecipadamente por sua ajuda. O primeiro envio ocorrerá em aproximadamente {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} não pôde ser carregado, uma instância nova será inicializada...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
@@ -92,24 +95,80 @@
<value>Terminado o recolhimento de um total de {0} tokens de acesso a aplicações.</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>Recuperando todos os depósitos para um total de apps {0}...</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>Retrieving {0} app infos...</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>Informações do aplicativo {0} finalizadas.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>{0} terminou de pedidos chave de depósito {1}.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Terminou de recuperar todas as chaves de depósito para um total de aplicativos {0}.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Não há novos dados para enviar, tudo está atualizado.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Não foi possível enviar os dados porque não há um conjunto SteamID válido que possamos classificar como colaborador. Considere configurar a propriedade {0}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>Enviar um total de apps/pacotes/pacotes registrados: {0}/{1}/{2}...</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>O envio falhou devido a muitas solicitações enviadas, tentaremos novamente em aproximadamente {0} a partir de agora.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>Os dados foram enviados com sucesso. O servidor registrou um total de novos aplicativos/pacotes/depósitos: {0} ({1} verificado)/{2} ({3} verificado)/{4} ({5} verificado).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Novos aplicativos: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedApps" xml:space="preserve">
<value>Apps verificados: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewPackages" xml:space="preserve">
<value>Novos pacotes: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedPackages" xml:space="preserve">
<value>Pacotes verificados: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Novos depósitos: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Depósitos verificados: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} inicializado, o plugin não resolverá nenhum desses: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>Carregando cache global STD...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Validando integridade de cache global STD...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Falha ao verificar a integridade do cache global STD. Isso sugere uma potencial corrupção de arquivo/memória, uma instância nova será inicializada em vez disso.</value>
</data>
</root>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>SUCCESFULLY RETRIEVD {0} OUT OV {1} DEPOT KEYS.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>FINISHD {0} OUT OV {1} DEPOT KEY REQUESTS.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>FINISHD RETRIEVIN ALL DEPOT KEYS 4 TOTAL OV {0} APPS.</value>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Successfully retrieved {0} out of {1} depot keys.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Finished {0} out of {1} depot key requests.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Finished retrieving all depot keys for a total of {0} apps.</value>

View File

@@ -68,7 +68,10 @@
<value>{0} este momentan dezactivat în funcție de configurația ta. Dacă doriți să ajutați SteamDB în transmiterea de date, vă rugăm să consultați wiki-ul.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} a fost inițializat cu succes, îți mulțumim anticipat pentru ajutorul tău. Prima trimitere va avea loc în aproximativ {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} nu a putut fi încărcat, o nouă instanță va fi inițializată...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
@@ -105,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>{0} din {1} chei de depozit au fost recuperate cu succes.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Am terminat {0} din {1} cereri de chei de depozit.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>S-a terminat preluarea tuturor depot keys pentru un total de {0} aplicații.</value>

View File

@@ -108,8 +108,8 @@
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Успешно извлечено {0} ключей хранилища из {1}.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
<value>Завершено {0} из {1} запросов ключей хранилища.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Получение всех ключей хранилища {0} приложений завершено.</value>

View File

@@ -104,10 +104,7 @@
<value>Dokončené získavanie informácií {0} aplikácií.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Úspešne načítaných {0} z {1} depot kľúčov.</value>
<comment>{0} will be replaced by the number (count this batch) of depot keys that were successfully retrieved, {1} will be replaced by the number (count this batch) of depot keys that were supposed to be retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Dokončené získanie všetkých kľúčov položiek {0} aplikácií.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>

View File

@@ -60,33 +60,115 @@
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
</value>
</resheader>
<data name="PluginDisabledMissingBuildToken" xml:space="preserve">
<value>{0} har inaktiverats på grund av en saknad build-token</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginDisabledInConfig" xml:space="preserve">
<value>{0} är för närvarande inaktiverat enligt din konfiguration. Om du vill hjälpa SteamDB i datainlämning, vänligen kolla in vår wiki.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin")</comment>
</data>
<data name="PluginInitializedAndEnabled" xml:space="preserve">
<value>{0} har initierats framgångsrikt, tack i förväg för din hjälp. Den första inlämningen kommer att ske i ungefär {1}.</value>
<comment>{0} will be replaced by the name of the plugin (e.g. "SteamTokenDumperPlugin"), {1} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="FileCouldNotBeLoadedFreshInit" xml:space="preserve">
<value>{0} kunde inte laddas, en ny instans kommer att initieras...</value>
<comment>{0} will be replaced by the name of the file (e.g. "GlobalCache")</comment>
</data>
<data name="BotNoAppsToRefresh" xml:space="preserve">
<value>Det finns inga appar som kräver en uppdatering på denna bot instans.</value>
</data>
<data name="BotRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Hämtar totalt {0} app access-tokens...</value>
<comment>{0} will be replaced by the number (total count) of app access tokens being retrieved</comment>
</data>
<data name="BotRetrievingAppAccessTokens" xml:space="preserve">
<value>Hämtar {0} app access-tokens...</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppAccessTokens" xml:space="preserve">
<value>Slutförd hämtning av {0} app access-tokens.</value>
<comment>{0} will be replaced by the number (count this batch) of app access tokens retrieved</comment>
</data>
<data name="BotFinishedRetrievingTotalAppAccessTokens" xml:space="preserve">
<value>Slutförd hämtning av totalt {0} app access-tokens.</value>
<comment>{0} will be replaced by the number (total count) of app access tokens retrieved</comment>
</data>
<data name="BotRetrievingTotalDepots" xml:space="preserve">
<value>Hämtar alla depåer för totalt {0} appar...</value>
<comment>{0} will be replaced by the number (total count) of apps being retrieved</comment>
</data>
<data name="BotRetrievingAppInfos" xml:space="preserve">
<value>Hämtar {0} app-infon...</value>
<comment>{0} will be replaced by the number (count this batch) of app infos being retrieved</comment>
</data>
<data name="BotFinishedRetrievingAppInfos" xml:space="preserve">
<value>Slutade hämta {0} app-infon.</value>
<comment>{0} will be replaced by the number (count this batch) of app infos retrieved</comment>
</data>
<data name="BotFinishedRetrievingDepotKeys" xml:space="preserve">
<value>Avslutade {0} av {1} depå nyckel förfrågningar.</value>
<comment>{0} will be replaced by the number (count this batch) of depot key requests that were successfully answered, {1} will be replaced by the number (count this batch) of depot key requests that were supposed to be sent</comment>
</data>
<data name="BotFinishedRetrievingTotalDepots" xml:space="preserve">
<value>Slutförd hämtning av alla depå-nycklar för totalt {0} appar.</value>
<comment>{0} will be replaced by the number (total count) of apps retrieved</comment>
</data>
<data name="SubmissionNoNewData" xml:space="preserve">
<value>Det finns inget ny data att skicka in, allt är uppdaterat.</value>
</data>
<data name="SubmissionNoContributorSet" xml:space="preserve">
<value>Kunde inte skicka in data eftersom det inte finns någon giltig SteamID som vi kunde klassificera som en bidragsgivare. Överväg att konfigurera {0} egenskap.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SteamOwnerID") that the user is expected to set</comment>
</data>
<data name="SubmissionInProgress" xml:space="preserve">
<value>Skicka in totalt registrerade appar/paket/depåer: {0}/{1}/{2}...</value>
<comment>{0} will be replaced by the number of app access tokens being submitted, {1} will be replaced by the number of package access tokens being submitted, {2} will be replaced by the number of depot keys being submitted</comment>
</data>
<data name="SubmissionFailedTooManyRequests" xml:space="preserve">
<value>Inlämningen misslyckades på grund av för många förfrågningar skickade, vi försöker igen om ungefär {0} från nu.</value>
<comment>{0} will be replaced by translated TimeSpan string (such as "53 minutes")</comment>
</data>
<data name="SubmissionSuccessful" xml:space="preserve">
<value>Data har lyckats överlämnas. Servern har registrerat totalt nya appar/packet/depåer: {0} ({1} verifierad)/{2} ({3} verifierad)/{4} ({5} verifierad).</value>
<comment>{0} will be replaced by the number of new app access tokens that the server has registered, {1} will be replaced by the number of verified app access tokens that the server has registered, {2} will be replaced by the number of new package access tokens that the server has registered, {3} will be replaced by the number of verified package access tokens that the server has registered, {4} will be replaced by the number of new depot keys that the server has registered, {5} will be replaced by the number of verified depot keys that the server has registered</comment>
</data>
<data name="SubmissionSuccessfulNewApps" xml:space="preserve">
<value>Nya appar: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedApps" xml:space="preserve">
<value>Verifierade appar: {0}</value>
<comment>{0} will be replaced by list of the apps (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewPackages" xml:space="preserve">
<value>Nya paket: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedPackages" xml:space="preserve">
<value>Verifierade paket: {0}</value>
<comment>{0} will be replaced by list of the packages (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulNewDepots" xml:space="preserve">
<value>Nya depåer: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="SubmissionSuccessfulVerifiedDepots" xml:space="preserve">
<value>Verifierade depåer: {0}</value>
<comment>{0} will be replaced by list of the depots (IDs, numbers), separated by a comma</comment>
</data>
<data name="PluginSecretListInitialized" xml:space="preserve">
<value>{0} initierad, plugin kommer inte att lösa någon av dessa: {1}.</value>
<comment>{0} will be replaced by the name of the config property (e.g. "SecretPackageIDs"), {1} will be replaced by list of the objects (IDs, numbers), separated by a comma</comment>
</data>
<data name="LoadingGlobalCache" xml:space="preserve">
<value>Laddar STD global cache...</value>
</data>
<data name="ValidatingGlobalCacheIntegrity" xml:space="preserve">
<value>Validerar STD global cache integritet...</value>
</data>
<data name="GlobalCacheIntegrityValidationFailed" xml:space="preserve">
<value>Det gick inte att verifiera STD global cache integritet. Detta tyder på en potentiell fil/minnes korruption, en ny instans kommer att initieras istället.</value>
</data>
</root>

Some files were not shown because too many files have changed in this diff Show More