mirror of
https://github.com/mRemoteNG/mRemoteNG.git
synced 2026-02-17 22:11:48 +08:00
Compare commits
404 Commits
v1.77.2
...
v1.77.2-de
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
15149f9e2c | ||
|
|
ab3d85b089 | ||
|
|
2f3a03eab7 | ||
|
|
629515b81a | ||
|
|
05c8da3ee4 | ||
|
|
859d12b450 | ||
|
|
cd7c594b76 | ||
|
|
39862e15f6 | ||
|
|
87b0cf5c3f | ||
|
|
a14219e1e2 | ||
|
|
ee4660707c | ||
|
|
ccdf15c79c | ||
|
|
b31362afab | ||
|
|
74d6c88565 | ||
|
|
638f64b888 | ||
|
|
ffff9c1529 | ||
|
|
39968c7c6e | ||
|
|
2c3edf0ff2 | ||
|
|
2c4445a2d9 | ||
|
|
09114a5ed3 | ||
|
|
22e7825d65 | ||
|
|
62862141a8 | ||
|
|
920461920c | ||
|
|
f5d0e93ecd | ||
|
|
952a2f536b | ||
|
|
fbb9d849b4 | ||
|
|
65a13dee68 | ||
|
|
09d26b37c7 | ||
|
|
47de6905df | ||
|
|
c0cf316c16 | ||
|
|
c055f8069d | ||
|
|
575356214f | ||
|
|
4b5dc4152a | ||
|
|
a023409fe9 | ||
|
|
d36c59658d | ||
|
|
4f832ee70b | ||
|
|
7b97097515 | ||
|
|
86b3cb8d5d | ||
|
|
33e007ad48 | ||
|
|
efea9f0857 | ||
|
|
aa755a0093 | ||
|
|
807e80acbe | ||
|
|
4096247ee8 | ||
|
|
782d09ddbc | ||
|
|
4c304e11f3 | ||
|
|
aee497de03 | ||
|
|
823f8614e5 | ||
|
|
b54afb8823 | ||
|
|
22e611c63b | ||
|
|
3deb01a65d | ||
|
|
6f24b0bb71 | ||
|
|
9d7921f538 | ||
|
|
a4e66b3d11 | ||
|
|
3866ff76f9 | ||
|
|
82f947abdd | ||
|
|
47c6f53b43 | ||
|
|
606657524e | ||
|
|
168285944c | ||
|
|
1746af927b | ||
|
|
2eca8ffba2 | ||
|
|
6ef0c06a19 | ||
|
|
af68f1a16e | ||
|
|
f429839a17 | ||
|
|
66770e602a | ||
|
|
f760131cf5 | ||
|
|
cdc1d5064f | ||
|
|
3b707d29b9 | ||
|
|
df632bb1f0 | ||
|
|
74cb453995 | ||
|
|
f8eec94b04 | ||
|
|
697efacc58 | ||
|
|
ff9cff8f44 | ||
|
|
d78388646d | ||
|
|
05ffcdeef7 | ||
|
|
3b8e347a9e | ||
|
|
37f160f698 | ||
|
|
6f1446339c | ||
|
|
fed44dc366 | ||
|
|
c71ec34998 | ||
|
|
157bda8f51 | ||
|
|
d80e5bc792 | ||
|
|
f9669e8158 | ||
|
|
04c83c608b | ||
|
|
9f50037e11 | ||
|
|
33fd741ba7 | ||
|
|
035c3f9319 | ||
|
|
3df922340d | ||
|
|
72b9190e2f | ||
|
|
8fe1bdf39a | ||
|
|
f78bf2bc8a | ||
|
|
a1f0a69874 | ||
|
|
8a26b2f433 | ||
|
|
a18784d2c7 | ||
|
|
3c25a987fd | ||
|
|
7cebc4ef42 | ||
|
|
a8ab46d5c8 | ||
|
|
8bac5a8c54 | ||
|
|
801a41ae10 | ||
|
|
47e37afe12 | ||
|
|
942bf7d8cb | ||
|
|
0e8d573819 | ||
|
|
2bdfd7401e | ||
|
|
68dd6b1e23 | ||
|
|
2fe85ae0e5 | ||
|
|
e9fa1c3b5e | ||
|
|
f543b83cfc | ||
|
|
2d917ca11a | ||
|
|
2c830627ef | ||
|
|
46003a3509 | ||
|
|
6b0412586e | ||
|
|
36ca7ffbdb | ||
|
|
e5244f1fec | ||
|
|
359a7272e8 | ||
|
|
82cd3a7e56 | ||
|
|
a2e78fd08a | ||
|
|
a48b5e9d65 | ||
|
|
f4c4d9ea8c | ||
|
|
02ed45fa61 | ||
|
|
ad227ea2ee | ||
|
|
d7e2358d3e | ||
|
|
196e98e4a7 | ||
|
|
00bc45fba1 | ||
|
|
62c0d3f07f | ||
|
|
d42574a16c | ||
|
|
a854b04293 | ||
|
|
96632da4d7 | ||
|
|
cf18d6b1e9 | ||
|
|
262e2e1b85 | ||
|
|
743c46de70 | ||
|
|
9624bc96c9 | ||
|
|
1643bb7d59 | ||
|
|
edad5a838f | ||
|
|
fb35226e20 | ||
|
|
40605737b1 | ||
|
|
01a62e099e | ||
|
|
80748bb66b | ||
|
|
c6c77e9bc4 | ||
|
|
1f462648c4 | ||
|
|
099256e5d4 | ||
|
|
8735d24122 | ||
|
|
b2fc3967d3 | ||
|
|
0ec02cfa56 | ||
|
|
ade36d6876 | ||
|
|
73313d7dae | ||
|
|
7db9865ffa | ||
|
|
40656cb70b | ||
|
|
b5a07f3e79 | ||
|
|
66877ce9b1 | ||
|
|
57b067b4e2 | ||
|
|
74999e9394 | ||
|
|
f4d6f1e5ee | ||
|
|
096f670eb3 | ||
|
|
bceaca49bf | ||
|
|
5e94c84516 | ||
|
|
28dc14e739 | ||
|
|
d5d28e80cb | ||
|
|
f1eea76249 | ||
|
|
0976404eda | ||
|
|
8074c9a7c6 | ||
|
|
513af43fca | ||
|
|
afd5d76992 | ||
|
|
a31da5f880 | ||
|
|
be470f50ec | ||
|
|
a04494346e | ||
|
|
797533459e | ||
|
|
22e879ef18 | ||
|
|
dc6bc5b4d6 | ||
|
|
a6c7457c59 | ||
|
|
b609cfba2a | ||
|
|
345980f457 | ||
|
|
5a86a0a8cb | ||
|
|
24c1ce3f4a | ||
|
|
fc65c2583e | ||
|
|
1df3c33f69 | ||
|
|
98a9cc7436 | ||
|
|
ff88d4649c | ||
|
|
8c61306a8d | ||
|
|
6496e34868 | ||
|
|
7d6c9d517c | ||
|
|
d918d8ffd1 | ||
|
|
ca61ea09d0 | ||
|
|
faff230d42 | ||
|
|
c288c3d071 | ||
|
|
500a22b0b6 | ||
|
|
ba1317d245 | ||
|
|
5cfbfc5071 | ||
|
|
bf4b9d5355 | ||
|
|
904f0bc202 | ||
|
|
94c546bd0f | ||
|
|
64f1e10a5e | ||
|
|
8b20da78ff | ||
|
|
1be4ef437d | ||
|
|
76da9c3247 | ||
|
|
1e4dcc23d7 | ||
|
|
9c95e7fd96 | ||
|
|
cea5f57c60 | ||
|
|
19e6d37b62 | ||
|
|
018979d17f | ||
|
|
8bd398cbd6 | ||
|
|
59872b14cf | ||
|
|
c5240d72e1 | ||
|
|
77b54f9a10 | ||
|
|
b5bcb5b3bb | ||
|
|
87c500138b | ||
|
|
f3f384ebcc | ||
|
|
08de2eacd6 | ||
|
|
b763d968fe | ||
|
|
3b05eba2e2 | ||
|
|
b6d2c72a40 | ||
|
|
e6d2c9791d | ||
|
|
91a0eeb29a | ||
|
|
8c9c4865f2 | ||
|
|
6fbd4a7c88 | ||
|
|
239adaa129 | ||
|
|
9f8c82b649 | ||
|
|
7875bb6ebd | ||
|
|
a33abf3f56 | ||
|
|
1fadadcdb5 | ||
|
|
a294dec0dc | ||
|
|
5de75e6a8a | ||
|
|
4b44be2e54 | ||
|
|
b5f1d63175 | ||
|
|
1c5695df7e | ||
|
|
1808ad9ad7 | ||
|
|
8dc5e81374 | ||
|
|
b899056a8e | ||
|
|
f884c47ad8 | ||
|
|
07eae639b6 | ||
|
|
d2349bd713 | ||
|
|
28ee3c6e8f | ||
|
|
4430f269f7 | ||
|
|
a72f7d63f6 | ||
|
|
859b6f8ac5 | ||
|
|
a7f238aba3 | ||
|
|
e0cff27aae | ||
|
|
d9c4a6ec76 | ||
|
|
4d95bc4255 | ||
|
|
fdea0144b0 | ||
|
|
7398a373c2 | ||
|
|
c88e45cde8 | ||
|
|
f77848e3d9 | ||
|
|
5ed78cc3b6 | ||
|
|
1b4593bb62 | ||
|
|
c620e26644 | ||
|
|
74af24c3db | ||
|
|
ac1f32f773 | ||
|
|
99c7dbb332 | ||
|
|
b0632b8910 | ||
|
|
d26a9615c0 | ||
|
|
f609d6e0b2 | ||
|
|
e5042712b6 | ||
|
|
bf93d3af04 | ||
|
|
ea43abe392 | ||
|
|
0e74314ddc | ||
|
|
54eabd6a74 | ||
|
|
2f52473566 | ||
|
|
98e7250b3c | ||
|
|
882438f5e0 | ||
|
|
bb93dddd39 | ||
|
|
59f6a8a933 | ||
|
|
8ce83f3cd0 | ||
|
|
745e402da9 | ||
|
|
6cbe1c92d5 | ||
|
|
54fc2fb4c6 | ||
|
|
adc2815ab5 | ||
|
|
75f9f647ee | ||
|
|
f14f7dbb72 | ||
|
|
4978618e9a | ||
|
|
59b9f4f15b | ||
|
|
7ff0ce5369 | ||
|
|
93bd278819 | ||
|
|
b97b1f3690 | ||
|
|
307f374be1 | ||
|
|
17f701824e | ||
|
|
c7b89dcf71 | ||
|
|
fc527a947f | ||
|
|
d0520690a2 | ||
|
|
315d020b6f | ||
|
|
8a4bcdef52 | ||
|
|
727ef34c6d | ||
|
|
d8bc06d05d | ||
|
|
def214dde2 | ||
|
|
219f948c4a | ||
|
|
72193eccf0 | ||
|
|
7eb85c6a3d | ||
|
|
954c667173 | ||
|
|
33c738df5f | ||
|
|
2141fe298f | ||
|
|
8e73f512b4 | ||
|
|
92dddb8fd8 | ||
|
|
e9869f4c88 | ||
|
|
52597d4dcb | ||
|
|
dc7ce27b81 | ||
|
|
4242595a66 | ||
|
|
50b9a11503 | ||
|
|
621a723602 | ||
|
|
6260cc3655 | ||
|
|
300e668327 | ||
|
|
3cf274c37a | ||
|
|
2ca356ee5c | ||
|
|
ca8751c40c | ||
|
|
3c7e97d2d9 | ||
|
|
dbe2d690da | ||
|
|
949410e2cc | ||
|
|
100f856b5f | ||
|
|
d7bee01454 | ||
|
|
5566081986 | ||
|
|
29f7dd93f3 | ||
|
|
3dd8db5728 | ||
|
|
17e70d11f5 | ||
|
|
f8afd439b2 | ||
|
|
0dc61b1c26 | ||
|
|
de6c4fcb17 | ||
|
|
57f5c854ff | ||
|
|
4f4523ab77 | ||
|
|
e34e632519 | ||
|
|
f810b902a6 | ||
|
|
fd5bdc1484 | ||
|
|
e3a12ae6c5 | ||
|
|
c9c5664ec6 | ||
|
|
75cff549ce | ||
|
|
885cb6915d | ||
|
|
f9396a4ecf | ||
|
|
f1a03329e5 | ||
|
|
f65be671a3 | ||
|
|
fa9e8f6cba | ||
|
|
67a3e76cfe | ||
|
|
e4569c0bb8 | ||
|
|
6f1a62e917 | ||
|
|
3f6e21f15a | ||
|
|
46c4287c67 | ||
|
|
1ea1826a27 | ||
|
|
151457daf0 | ||
|
|
38cc21fa3a | ||
|
|
77f759f258 | ||
|
|
07c04061c2 | ||
|
|
d4bf6ed0c8 | ||
|
|
ebd46efe81 | ||
|
|
24d193efb0 | ||
|
|
3b2a63178f | ||
|
|
78f60afb85 | ||
|
|
52a7957789 | ||
|
|
6870583b1c | ||
|
|
9ffe514350 | ||
|
|
fc6e04497a | ||
|
|
cfb3f9a3ca | ||
|
|
d47fac791e | ||
|
|
490b70c2d3 | ||
|
|
3eecdd9ada | ||
|
|
7bdbc5417c | ||
|
|
2cd07dcb72 | ||
|
|
adb83ade67 | ||
|
|
a90f5da8b0 | ||
|
|
38937a4f83 | ||
|
|
31f35a23ee | ||
|
|
74de010d3c | ||
|
|
a9e4c880df | ||
|
|
b7fe265604 | ||
|
|
25c4af5a9f | ||
|
|
b3ecf702e1 | ||
|
|
c34a3cc7e7 | ||
|
|
158783f2d1 | ||
|
|
624192d301 | ||
|
|
e9be139ed0 | ||
|
|
2b9195ed9c | ||
|
|
dfdfecba57 | ||
|
|
2d6fec13fb | ||
|
|
216f340468 | ||
|
|
a4211a7e55 | ||
|
|
d6a2488fde | ||
|
|
d4d60439b6 | ||
|
|
75edd0d8ef | ||
|
|
b4e6e21094 | ||
|
|
8c48bc926e | ||
|
|
031b6fb30d | ||
|
|
647542e462 | ||
|
|
dbf28d83f3 | ||
|
|
142acdd42f | ||
|
|
ce103d30d3 | ||
|
|
556d65e8b4 | ||
|
|
e0cf070bd0 | ||
|
|
70c5a336c2 | ||
|
|
f82d5fbd2d | ||
|
|
31418ba6f7 | ||
|
|
3c10bb2669 | ||
|
|
0e009a2762 | ||
|
|
67dfd6b036 | ||
|
|
162eb0c958 | ||
|
|
a2dcc42f68 | ||
|
|
6b7f6dcb19 | ||
|
|
066e783a37 | ||
|
|
3e1bf001c7 | ||
|
|
722e18c07d | ||
|
|
a66ec00587 | ||
|
|
2b5100c019 | ||
|
|
74da05e6e8 | ||
|
|
af24e3b284 | ||
|
|
fb68d0bff3 | ||
|
|
d3a2ba26ba | ||
|
|
2f70ec5cb6 | ||
|
|
9173e9e56a | ||
|
|
11ad8a8398 | ||
|
|
0d518e44c7 | ||
|
|
7d8a5a2bdf |
14
.readthedocs.yaml
Normal file
14
.readthedocs.yaml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# .readthedocs.yaml
|
||||||
|
# Read the Docs configuration file
|
||||||
|
# See https://docs.readthedocs.io/en/stable/config-file/v2.html for details
|
||||||
|
|
||||||
|
# Required
|
||||||
|
version: 2
|
||||||
|
|
||||||
|
# Build documentation in the docs/ directory with Sphinx
|
||||||
|
sphinx:
|
||||||
|
configuration: mRemoteNGDocumentation/conf.py
|
||||||
|
|
||||||
|
# Optionally build your docs in additional formats such as PDF
|
||||||
|
formats:
|
||||||
|
- pdf
|
||||||
39
CHANGELOG.md
39
CHANGELOG.md
@@ -3,35 +3,62 @@ All notable changes to this project will be documented in this file.
|
|||||||
|
|
||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
## [Unreleased]
|
## [1.77.2]
|
||||||
### Added
|
### Added
|
||||||
- #1427: Fix RDP local desktop scale not taking effect on remote
|
- #2086: Replace WebClient with async HttpClient for updater.
|
||||||
|
- #1850: Minify config xml
|
||||||
- #1770: Added missing RDP performance settings
|
- #1770: Added missing RDP performance settings
|
||||||
|
- #1516: added API to access credential vault (Thycotic Secret Server) by specifying SSAPI:ID as username
|
||||||
|
- #1476: Configurable backups. Can now edit/set backup frequency, backup path, and max number of backup files.
|
||||||
|
- #1427: Fix RDP local desktop scale not taking effect on remote
|
||||||
- #1332: Added option to hide menu strip container
|
- #1332: Added option to hide menu strip container
|
||||||
|
- #870: Added option to push inheritance settings to child nodes recursively
|
||||||
- #545: Option to minimize to system tray on closing
|
- #545: Option to minimize to system tray on closing
|
||||||
|
- #503: SSH Execute a single command after login
|
||||||
- #420: SSH tunneling implemented
|
- #420: SSH tunneling implemented
|
||||||
|
- #327: Added Alternative Shell for RDP settings
|
||||||
- #319: Override quick connect username when using user@domain
|
- #319: Override quick connect username when using user@domain
|
||||||
- #283: Support for native PowerShell remoting as new protocol
|
- #283: Support for native PowerShell remoting as new protocol
|
||||||
- #1850: Minify config xml
|
- #xxx: Add external connector to retrieve ip address from Amazon EC2 Instance IDs
|
||||||
### Changed
|
### Changed
|
||||||
|
- #2102: Extended the field RenderingEngine from 10 chars to 16
|
||||||
|
- #2022: Replaced CefSharp with WebView2
|
||||||
|
- #2014: Revised icons
|
||||||
|
- #2013: Removed components check
|
||||||
|
- #2011: Removed screenshot manager
|
||||||
|
- #2010: Redesigned menus
|
||||||
|
- #2005: Removed in-app documentation
|
||||||
- #1777: Cleaned up VisualStudio project structure
|
- #1777: Cleaned up VisualStudio project structure
|
||||||
- #1767: Turned about window into a simple popup form
|
- #1767: Turned about window into a simple popup form
|
||||||
- #1766: Converted components check page into options page
|
|
||||||
- #1690: Replaced GeckoFX (Firefox) with CefSharp (Chromium)
|
- #1690: Replaced GeckoFX (Firefox) with CefSharp (Chromium)
|
||||||
- #1325: Language resource files cleanup
|
- #1325: Language resource files cleanup
|
||||||
|
- #xxxx: Secret Server connector via new field "API User ID" instead of SSAPI: prefix
|
||||||
### Fixed
|
### Fixed
|
||||||
|
- #2125: Fixed string parsing logic for Quick Connect toolbar.
|
||||||
|
- #2122: Fix to avoid throwing exception incase if not able decrypt connections and ask to open another one or create a new.
|
||||||
|
- #2117: Fix of broken Links due migration to .NET 6 and branch renaming
|
||||||
|
- #2098: Fix failed BinaryFileTest
|
||||||
|
- #2097: Fix failed tests related to mRemoteNGTests.UI.Window.ConfigWindowTests
|
||||||
|
- #2096: Corrected encryption code of LegacyRijndaelCryptographyProvider
|
||||||
|
- #2089: Fixed the exception thrown by menu buttons "Documentation" and "Website"
|
||||||
|
- #2087: Fixed application crash, when the update file is launched from the application
|
||||||
|
- #2079: Fixed theme files not being copied to output directory
|
||||||
|
- #2012: Updated PuTTYNG to v0.76
|
||||||
|
- #1884: Allow setting Port when using MSSQL
|
||||||
- #1783: Added missing inheritance properties to SQL scripts
|
- #1783: Added missing inheritance properties to SQL scripts
|
||||||
- #1773: Connection issue with mysql - Missing fields in
|
- #1773: Connection issue with MySql - Missing fields in
|
||||||
- #1756: Cannot type any character on MultiSSH toolbar
|
- #1756: Cannot type any character on MultiSSH toolbar
|
||||||
- #1720: Show configuration file name in title of password prompt form
|
- #1720: Show configuration file name in title of password prompt form
|
||||||
- #1713: Sound redirection does not work if Clipboard redirection is set to No
|
- #1713: Sound redirection does not work if Clipboard redirection is set to No
|
||||||
- #1632: 1.77.1 breaks RDP drive and sound redirection
|
- #1632: 1.77.1 breaks RDP drive and sound redirection
|
||||||
- #1610: Menu bar changes to english when cancelling options form
|
- #1610: Menu bar changes to English when canceling options form
|
||||||
- #1595: Unhandled exception when trying to browse through non existent multi ssh history with keyboard key strokes
|
- #1595: Unhandled exception when trying to browse through non existent multi ssh history with keyboard key strokes
|
||||||
- #1589: Update SQL tables instead of rewriting them
|
- #1589: Update SQL tables instead of rewriting them
|
||||||
- #1465: REGRESSION: Smart Cards redirection to Remote Desktop not working
|
- #1465: REGRESSION: Smart Cards redirection to Remote Desktop not working
|
||||||
|
- #1363: Don't show "Disk Usage" button in installer
|
||||||
- #1337: Unhandled exception after closing mRemoteNG
|
- #1337: Unhandled exception after closing mRemoteNG
|
||||||
- #359: Making a VNC connection to an unreachable host causes the application to not respond for 20-30 seconds
|
- #359: Making a VNC connection to an unreachable host causes the application to not respond for 20-30 seconds
|
||||||
|
- #618: Do not break the Windows Clipboard Chain when exiting.
|
||||||
|
|
||||||
## [1.77.1] - 2019-09-02
|
## [1.77.1] - 2019-09-02
|
||||||
### Added
|
### Added
|
||||||
|
|||||||
@@ -278,62 +278,3 @@ PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
|||||||
POSSIBILITY OF SUCH DAMAGES.
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
How to Apply These Terms to Your New Programs
|
|
||||||
|
|
||||||
If you develop a new program, and you want it to be of the greatest
|
|
||||||
possible use to the public, the best way to achieve this is to make it
|
|
||||||
free software which everyone can redistribute and change under these terms.
|
|
||||||
|
|
||||||
To do so, attach the following notices to the program. It is safest
|
|
||||||
to attach them to the start of each source file to most effectively
|
|
||||||
convey the exclusion of warranty; and each file should have at least
|
|
||||||
the "copyright" line and a pointer to where the full notice is found.
|
|
||||||
|
|
||||||
<one line to give the program's name and a brief idea of what it does.>
|
|
||||||
Copyright (C) <year> <name of author>
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation; either version 2 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along
|
|
||||||
with this program; if not, write to the Free Software Foundation, Inc.,
|
|
||||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
|
||||||
|
|
||||||
If the program is interactive, make it output a short notice like this
|
|
||||||
when it starts in an interactive mode:
|
|
||||||
|
|
||||||
Gnomovision version 69, Copyright (C) year name of author
|
|
||||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
|
||||||
This is free software, and you are welcome to redistribute it
|
|
||||||
under certain conditions; type `show c' for details.
|
|
||||||
|
|
||||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
|
||||||
parts of the General Public License. Of course, the commands you use may
|
|
||||||
be called something other than `show w' and `show c'; they could even be
|
|
||||||
mouse-clicks or menu items--whatever suits your program.
|
|
||||||
|
|
||||||
You should also get your employer (if you work as a programmer) or your
|
|
||||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
|
||||||
necessary. Here is a sample; alter the names:
|
|
||||||
|
|
||||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
|
||||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
|
||||||
|
|
||||||
<signature of Ty Coon>, 1 April 1989
|
|
||||||
Ty Coon, President of Vice
|
|
||||||
|
|
||||||
This General Public License does not permit incorporating your program into
|
|
||||||
proprietary programs. If your program is a subroutine library, you may
|
|
||||||
consider it more useful to permit linking proprietary applications with the
|
|
||||||
library. If this is what you want to do, use the GNU Lesser General
|
|
||||||
Public License instead of this License.
|
|
||||||
180
ExternalConnectors/AWS/AWSConnectionForm.Designer.cs
generated
Normal file
180
ExternalConnectors/AWS/AWSConnectionForm.Designer.cs
generated
Normal file
@@ -0,0 +1,180 @@
|
|||||||
|
namespace ExternalConnectors.AWS
|
||||||
|
{
|
||||||
|
partial class AWSConnectionForm
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Required designer variable.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Clean up any resources being used.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Windows Form Designer generated code
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Required method for Designer support - do not modify
|
||||||
|
/// the contents of this method with the code editor.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
this.tbAccesKeyID = new System.Windows.Forms.TextBox();
|
||||||
|
this.tbAccesKey = new System.Windows.Forms.TextBox();
|
||||||
|
this.btnOK = new System.Windows.Forms.Button();
|
||||||
|
this.btnCancel = new System.Windows.Forms.Button();
|
||||||
|
this.tableLayoutPanel1 = new System.Windows.Forms.TableLayoutPanel();
|
||||||
|
this.label1 = new System.Windows.Forms.Label();
|
||||||
|
this.label2 = new System.Windows.Forms.Label();
|
||||||
|
this.tableLayoutPanel2 = new System.Windows.Forms.TableLayoutPanel();
|
||||||
|
this.tableLayoutPanel1.SuspendLayout();
|
||||||
|
this.tableLayoutPanel2.SuspendLayout();
|
||||||
|
this.SuspendLayout();
|
||||||
|
//
|
||||||
|
// tbAccesKeyID
|
||||||
|
//
|
||||||
|
this.tbAccesKeyID.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbAccesKeyID.Location = new System.Drawing.Point(152, 4);
|
||||||
|
this.tbAccesKeyID.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.tbAccesKeyID.Name = "tbAccesKeyID";
|
||||||
|
this.tbAccesKeyID.Size = new System.Drawing.Size(490, 23);
|
||||||
|
this.tbAccesKeyID.TabIndex = 0;
|
||||||
|
//
|
||||||
|
// tbAccesKey
|
||||||
|
//
|
||||||
|
this.tbAccesKey.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbAccesKey.Location = new System.Drawing.Point(152, 43);
|
||||||
|
this.tbAccesKey.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.tbAccesKey.Name = "tbAccesKey";
|
||||||
|
this.tbAccesKey.Size = new System.Drawing.Size(490, 23);
|
||||||
|
this.tbAccesKey.TabIndex = 2;
|
||||||
|
//
|
||||||
|
// btnOK
|
||||||
|
//
|
||||||
|
this.btnOK.Anchor = System.Windows.Forms.AnchorStyles.Right;
|
||||||
|
this.btnOK.DialogResult = System.Windows.Forms.DialogResult.OK;
|
||||||
|
this.btnOK.Location = new System.Drawing.Point(219, 12);
|
||||||
|
this.btnOK.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.btnOK.Name = "btnOK";
|
||||||
|
this.btnOK.Size = new System.Drawing.Size(88, 26);
|
||||||
|
this.btnOK.TabIndex = 10;
|
||||||
|
this.btnOK.Text = "OK";
|
||||||
|
this.btnOK.UseVisualStyleBackColor = true;
|
||||||
|
//
|
||||||
|
// btnCancel
|
||||||
|
//
|
||||||
|
this.btnCancel.Anchor = System.Windows.Forms.AnchorStyles.Left;
|
||||||
|
this.btnCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel;
|
||||||
|
this.btnCancel.Location = new System.Drawing.Point(338, 12);
|
||||||
|
this.btnCancel.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.btnCancel.Name = "btnCancel";
|
||||||
|
this.btnCancel.Size = new System.Drawing.Size(88, 26);
|
||||||
|
this.btnCancel.TabIndex = 11;
|
||||||
|
this.btnCancel.Text = "Cancel";
|
||||||
|
this.btnCancel.UseVisualStyleBackColor = true;
|
||||||
|
//
|
||||||
|
// tableLayoutPanel1
|
||||||
|
//
|
||||||
|
this.tableLayoutPanel1.ColumnCount = 2;
|
||||||
|
this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 22.92994F));
|
||||||
|
this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 77.07006F));
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label1, 0, 0);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label2, 0, 1);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbAccesKeyID, 1, 0);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbAccesKey, 1, 1);
|
||||||
|
this.tableLayoutPanel1.Dock = System.Windows.Forms.DockStyle.Top;
|
||||||
|
this.tableLayoutPanel1.Location = new System.Drawing.Point(0, 0);
|
||||||
|
this.tableLayoutPanel1.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.tableLayoutPanel1.Name = "tableLayoutPanel1";
|
||||||
|
this.tableLayoutPanel1.RowCount = 3;
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Absolute, 23F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Absolute, 23F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Absolute, 23F));
|
||||||
|
this.tableLayoutPanel1.Size = new System.Drawing.Size(646, 102);
|
||||||
|
this.tableLayoutPanel1.TabIndex = 12;
|
||||||
|
//
|
||||||
|
// label1
|
||||||
|
//
|
||||||
|
this.label1.AutoSize = true;
|
||||||
|
this.label1.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label1.Location = new System.Drawing.Point(4, 0);
|
||||||
|
this.label1.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label1.Name = "label1";
|
||||||
|
this.label1.Size = new System.Drawing.Size(140, 39);
|
||||||
|
this.label1.TabIndex = 2;
|
||||||
|
this.label1.Text = "Access Key ID";
|
||||||
|
this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// label2
|
||||||
|
//
|
||||||
|
this.label2.AutoSize = true;
|
||||||
|
this.label2.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label2.Location = new System.Drawing.Point(4, 39);
|
||||||
|
this.label2.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label2.Name = "label2";
|
||||||
|
this.label2.Size = new System.Drawing.Size(140, 39);
|
||||||
|
this.label2.TabIndex = 4;
|
||||||
|
this.label2.Text = "Access Key";
|
||||||
|
this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// tableLayoutPanel2
|
||||||
|
//
|
||||||
|
this.tableLayoutPanel2.ColumnCount = 5;
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 93F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 23F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 93F));
|
||||||
|
this.tableLayoutPanel2.Controls.Add(this.btnOK, 1, 0);
|
||||||
|
this.tableLayoutPanel2.Controls.Add(this.btnCancel, 3, 0);
|
||||||
|
this.tableLayoutPanel2.Dock = System.Windows.Forms.DockStyle.Bottom;
|
||||||
|
this.tableLayoutPanel2.Location = new System.Drawing.Point(0, 112);
|
||||||
|
this.tableLayoutPanel2.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.tableLayoutPanel2.Name = "tableLayoutPanel2";
|
||||||
|
this.tableLayoutPanel2.RowCount = 1;
|
||||||
|
this.tableLayoutPanel2.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 100F));
|
||||||
|
this.tableLayoutPanel2.Size = new System.Drawing.Size(646, 50);
|
||||||
|
this.tableLayoutPanel2.TabIndex = 13;
|
||||||
|
//
|
||||||
|
// AWSConnectionForm
|
||||||
|
//
|
||||||
|
this.AcceptButton = this.btnOK;
|
||||||
|
this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
||||||
|
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||||
|
this.ClientSize = new System.Drawing.Size(646, 162);
|
||||||
|
this.Controls.Add(this.tableLayoutPanel2);
|
||||||
|
this.Controls.Add(this.tableLayoutPanel1);
|
||||||
|
this.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4);
|
||||||
|
this.Name = "AWSConnectionForm";
|
||||||
|
this.Text = "AWS EC2 API Login Data";
|
||||||
|
this.Activated += new System.EventHandler(this.AWSConnectionForm_Activated);
|
||||||
|
this.tableLayoutPanel1.ResumeLayout(false);
|
||||||
|
this.tableLayoutPanel1.PerformLayout();
|
||||||
|
this.tableLayoutPanel2.ResumeLayout(false);
|
||||||
|
this.ResumeLayout(false);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
public System.Windows.Forms.TextBox tbAccesKeyID;
|
||||||
|
public System.Windows.Forms.TextBox tbAccesKey;
|
||||||
|
private System.Windows.Forms.Button btnOK;
|
||||||
|
private System.Windows.Forms.Button btnCancel;
|
||||||
|
private System.Windows.Forms.TableLayoutPanel tableLayoutPanel1;
|
||||||
|
private System.Windows.Forms.Label label2;
|
||||||
|
private System.Windows.Forms.Label label1;
|
||||||
|
private System.Windows.Forms.TableLayoutPanel tableLayoutPanel2;
|
||||||
|
}
|
||||||
|
}
|
||||||
16
ExternalConnectors/AWS/AWSConnectionForm.cs
Normal file
16
ExternalConnectors/AWS/AWSConnectionForm.cs
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
namespace ExternalConnectors.AWS
|
||||||
|
{
|
||||||
|
public partial class AWSConnectionForm : Form
|
||||||
|
{
|
||||||
|
public AWSConnectionForm()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void AWSConnectionForm_Activated(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
tbAccesKeyID.Focus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
60
ExternalConnectors/AWS/AWSConnectionForm.resx
Normal file
60
ExternalConnectors/AWS/AWSConnectionForm.resx
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
</root>
|
||||||
119
ExternalConnectors/AWS/EC2FetchDataService.cs
Normal file
119
ExternalConnectors/AWS/EC2FetchDataService.cs
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
using Amazon;
|
||||||
|
using Amazon.EC2;
|
||||||
|
using Amazon.EC2.Model;
|
||||||
|
using Microsoft.Win32;
|
||||||
|
|
||||||
|
namespace ExternalConnectors.AWS
|
||||||
|
{
|
||||||
|
public class EC2FetchDataService
|
||||||
|
{
|
||||||
|
private static DateTime lastFetch;
|
||||||
|
private static List<InstanceInfo>? lastData;
|
||||||
|
|
||||||
|
// input must be in format "AWSAPI:instanceid" where instanceid is the ec2 instance id, e.g. i-066f750a76c97583d
|
||||||
|
public static async Task<string> GetEC2InstanceDataAsync(string input, string region)
|
||||||
|
{
|
||||||
|
// get secret id
|
||||||
|
if (!input.StartsWith("AWSAPI:"))
|
||||||
|
throw new Exception("calling this function requires AWSAPI: input");
|
||||||
|
string InstanceID = input[7..];
|
||||||
|
|
||||||
|
// init connection credentials, display popup if necessary
|
||||||
|
AWSConnectionData.Init();
|
||||||
|
var alldata = await GetEC2IPDataAsync(region);
|
||||||
|
var found = alldata.Where(x => x.InstanceId == InstanceID).SingleOrDefault();
|
||||||
|
return (found == null) ? "" : found.PublicIP;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static async Task<List<InstanceInfo>> GetEC2IPDataAsync(string region)
|
||||||
|
{
|
||||||
|
// caching
|
||||||
|
TimeSpan timeSpan = DateTime.Now - lastFetch;
|
||||||
|
if (timeSpan.TotalMinutes < 1 && lastData != null)
|
||||||
|
return lastData;
|
||||||
|
|
||||||
|
//AWSConfigs.AWSRegion = AWSConnectionData.region;
|
||||||
|
AWSConfigs.AWSRegion = region;
|
||||||
|
string awsAccessKeyId = AWSConnectionData.awsKeyID;
|
||||||
|
string awsSecretAccessKey = AWSConnectionData.awsKey;
|
||||||
|
|
||||||
|
var _client = new AmazonEC2Client(awsAccessKeyId, awsSecretAccessKey, RegionEndpoint.EUCentral1);
|
||||||
|
bool done = false;
|
||||||
|
|
||||||
|
List<InstanceInfo> instanceList = new();
|
||||||
|
var request = new DescribeInstancesRequest();
|
||||||
|
while (!done)
|
||||||
|
{
|
||||||
|
DescribeInstancesResponse response = await _client.DescribeInstancesAsync(request);
|
||||||
|
|
||||||
|
foreach (var reservation in response.Reservations)
|
||||||
|
{
|
||||||
|
foreach (var instance in reservation.Instances)
|
||||||
|
{
|
||||||
|
string vmname = "";
|
||||||
|
foreach (var tag in instance.Tags)
|
||||||
|
{
|
||||||
|
if (tag.Key == "Name")
|
||||||
|
{
|
||||||
|
vmname = tag.Value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
InstanceInfo inf = new(instance, vmname);
|
||||||
|
instanceList.Add(inf);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
request.NextToken = response.NextToken;
|
||||||
|
|
||||||
|
if (response.NextToken == null)
|
||||||
|
{
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lastData = instanceList.OrderBy(x => x.Name).ToList();
|
||||||
|
lastFetch = DateTime.Now;
|
||||||
|
return lastData;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static class AWSConnectionData
|
||||||
|
{
|
||||||
|
private static readonly RegistryKey key = Registry.CurrentUser.CreateSubKey(@"SOFTWARE\mRemoteAWSInterface");
|
||||||
|
|
||||||
|
public static string awsKeyID = "";
|
||||||
|
public static string awsKey = "";
|
||||||
|
//public static string _region = "eu-central-1";
|
||||||
|
|
||||||
|
public static void Init()
|
||||||
|
{
|
||||||
|
if (awsKey != "")
|
||||||
|
return;
|
||||||
|
// display gui and ask for data
|
||||||
|
AWSConnectionForm f = new();
|
||||||
|
f.tbAccesKeyID.Text = "" + key.GetValue("KeyID");
|
||||||
|
f.tbAccesKey.Text = "" + key.GetValue("Key");
|
||||||
|
//f.tbRegion.Text = "" + key.GetValue("Region");
|
||||||
|
//if (f.tbRegion.Text == null || f.tbRegion.Text.Length < 2)
|
||||||
|
// f.tbRegion.Text = region;
|
||||||
|
_ = f.ShowDialog();
|
||||||
|
|
||||||
|
if (f.DialogResult != DialogResult.OK)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// store values to memory
|
||||||
|
awsKeyID = f.tbAccesKeyID.Text;
|
||||||
|
awsKey = f.tbAccesKey.Text;
|
||||||
|
//region = f.tbRegion.Text;
|
||||||
|
|
||||||
|
|
||||||
|
// write values to registry
|
||||||
|
key.SetValue("KeyID", awsKeyID);
|
||||||
|
key.SetValue("Key", awsKey);
|
||||||
|
//key.SetValue("Region", region);
|
||||||
|
key.Close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
34
ExternalConnectors/AWS/InstanceInfo.cs
Normal file
34
ExternalConnectors/AWS/InstanceInfo.cs
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
using Amazon.EC2.Model;
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace ExternalConnectors.AWS
|
||||||
|
{
|
||||||
|
public class InstanceInfo
|
||||||
|
{
|
||||||
|
public string InstanceId { get; }
|
||||||
|
public string Name { get; }
|
||||||
|
public string Status { get; }
|
||||||
|
public string PublicIP { get; }
|
||||||
|
public string PrivateIP { get; }
|
||||||
|
public InstanceInfo(Instance instance, string name)
|
||||||
|
{
|
||||||
|
InstanceId = instance.InstanceId;
|
||||||
|
Name = name;
|
||||||
|
|
||||||
|
switch(instance.State.Code)
|
||||||
|
{
|
||||||
|
case 0: Status = "Pending"; break;
|
||||||
|
case 16: Status = "Running"; break;
|
||||||
|
case 32: Status = "Shutdown"; break;
|
||||||
|
case 48: Status = "Terminated"; break;
|
||||||
|
case 64: Status = "Stopping"; break;
|
||||||
|
case 80: Status = "Stopped"; break;
|
||||||
|
default: Status = "Unknown"; break;
|
||||||
|
};
|
||||||
|
|
||||||
|
PublicIP = instance.PublicIpAddress ?? "";
|
||||||
|
PrivateIP = instance.PrivateIpAddress ?? "";
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
28
ExternalConnectors/ExternalConnectors.csproj
Normal file
28
ExternalConnectors/ExternalConnectors.csproj
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net6.0-windows</TargetFramework>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<OutputType>Library</OutputType>
|
||||||
|
<UseWindowsForms>True</UseWindowsForms>
|
||||||
|
<Platforms>x64</Platforms>
|
||||||
|
<Configurations>Debug;Release;Debug Portable;Release Portable</Configurations>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="AWSSDK.Core" Version="3.7.6" />
|
||||||
|
<PackageReference Include="AWSSDK.EC2" Version="3.7.55.3" />
|
||||||
|
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<Compile Update="AWS\AWSConnectionForm.cs">
|
||||||
|
<SubType>Form</SubType>
|
||||||
|
</Compile>
|
||||||
|
<Compile Update="TSS\SSConnectionForm.cs">
|
||||||
|
<SubType>Form</SubType>
|
||||||
|
</Compile>
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
||||||
280
ExternalConnectors/TSS/SSConnectionForm.Designer.cs
generated
Normal file
280
ExternalConnectors/TSS/SSConnectionForm.Designer.cs
generated
Normal file
@@ -0,0 +1,280 @@
|
|||||||
|
namespace ExternalConnectors.TSS
|
||||||
|
{
|
||||||
|
partial class SSConnectionForm
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Required designer variable.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Clean up any resources being used.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Windows Form Designer generated code
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Required method for Designer support - do not modify
|
||||||
|
/// the contents of this method with the code editor.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(SSConnectionForm));
|
||||||
|
this.tbSSURL = new System.Windows.Forms.TextBox();
|
||||||
|
this.tbUsername = new System.Windows.Forms.TextBox();
|
||||||
|
this.label3 = new System.Windows.Forms.Label();
|
||||||
|
this.tbPassword = new System.Windows.Forms.TextBox();
|
||||||
|
this.btnOK = new System.Windows.Forms.Button();
|
||||||
|
this.btnCancel = new System.Windows.Forms.Button();
|
||||||
|
this.tableLayoutPanel1 = new System.Windows.Forms.TableLayoutPanel();
|
||||||
|
this.label5 = new System.Windows.Forms.Label();
|
||||||
|
this.label1 = new System.Windows.Forms.Label();
|
||||||
|
this.label2 = new System.Windows.Forms.Label();
|
||||||
|
this.cbUseSSO = new System.Windows.Forms.CheckBox();
|
||||||
|
this.label6 = new System.Windows.Forms.Label();
|
||||||
|
this.tbOTP = new System.Windows.Forms.TextBox();
|
||||||
|
this.tableLayoutPanel2 = new System.Windows.Forms.TableLayoutPanel();
|
||||||
|
this.label4 = new System.Windows.Forms.Label();
|
||||||
|
this.tableLayoutPanel1.SuspendLayout();
|
||||||
|
this.tableLayoutPanel2.SuspendLayout();
|
||||||
|
this.SuspendLayout();
|
||||||
|
//
|
||||||
|
// tbSSURL
|
||||||
|
//
|
||||||
|
this.tbSSURL.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbSSURL.Location = new System.Drawing.Point(260, 4);
|
||||||
|
this.tbSSURL.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.tbSSURL.Name = "tbSSURL";
|
||||||
|
this.tbSSURL.Size = new System.Drawing.Size(536, 23);
|
||||||
|
this.tbSSURL.TabIndex = 0;
|
||||||
|
//
|
||||||
|
// tbUsername
|
||||||
|
//
|
||||||
|
this.tbUsername.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbUsername.Location = new System.Drawing.Point(260, 35);
|
||||||
|
this.tbUsername.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.tbUsername.Name = "tbUsername";
|
||||||
|
this.tbUsername.Size = new System.Drawing.Size(536, 23);
|
||||||
|
this.tbUsername.TabIndex = 2;
|
||||||
|
//
|
||||||
|
// label3
|
||||||
|
//
|
||||||
|
this.label3.AutoSize = true;
|
||||||
|
this.label3.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label3.Location = new System.Drawing.Point(4, 62);
|
||||||
|
this.label3.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label3.Name = "label3";
|
||||||
|
this.label3.Size = new System.Drawing.Size(248, 31);
|
||||||
|
this.label3.TabIndex = 5;
|
||||||
|
this.label3.Text = "Password";
|
||||||
|
this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// tbPassword
|
||||||
|
//
|
||||||
|
this.tbPassword.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbPassword.Location = new System.Drawing.Point(260, 66);
|
||||||
|
this.tbPassword.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.tbPassword.Name = "tbPassword";
|
||||||
|
this.tbPassword.Size = new System.Drawing.Size(536, 23);
|
||||||
|
this.tbPassword.TabIndex = 4;
|
||||||
|
this.tbPassword.UseSystemPasswordChar = true;
|
||||||
|
//
|
||||||
|
// btnOK
|
||||||
|
//
|
||||||
|
this.btnOK.Anchor = System.Windows.Forms.AnchorStyles.Right;
|
||||||
|
this.btnOK.DialogResult = System.Windows.Forms.DialogResult.OK;
|
||||||
|
this.btnOK.Location = new System.Drawing.Point(296, 12);
|
||||||
|
this.btnOK.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.btnOK.Name = "btnOK";
|
||||||
|
this.btnOK.Size = new System.Drawing.Size(88, 26);
|
||||||
|
this.btnOK.TabIndex = 6;
|
||||||
|
this.btnOK.Text = "OK";
|
||||||
|
this.btnOK.UseVisualStyleBackColor = true;
|
||||||
|
//
|
||||||
|
// btnCancel
|
||||||
|
//
|
||||||
|
this.btnCancel.Anchor = System.Windows.Forms.AnchorStyles.Left;
|
||||||
|
this.btnCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel;
|
||||||
|
this.btnCancel.Location = new System.Drawing.Point(415, 12);
|
||||||
|
this.btnCancel.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.btnCancel.Name = "btnCancel";
|
||||||
|
this.btnCancel.Size = new System.Drawing.Size(88, 26);
|
||||||
|
this.btnCancel.TabIndex = 11;
|
||||||
|
this.btnCancel.Text = "Cancel";
|
||||||
|
this.btnCancel.UseVisualStyleBackColor = true;
|
||||||
|
//
|
||||||
|
// tableLayoutPanel1
|
||||||
|
//
|
||||||
|
this.tableLayoutPanel1.ColumnCount = 2;
|
||||||
|
this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 32.06997F));
|
||||||
|
this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 67.93003F));
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label5, 1, 4);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label1, 0, 0);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label2, 0, 1);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label3, 0, 2);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbSSURL, 1, 0);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.cbUseSSO, 0, 4);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbUsername, 1, 1);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbPassword, 1, 2);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.label6, 0, 3);
|
||||||
|
this.tableLayoutPanel1.Controls.Add(this.tbOTP, 1, 3);
|
||||||
|
this.tableLayoutPanel1.Dock = System.Windows.Forms.DockStyle.Top;
|
||||||
|
this.tableLayoutPanel1.Location = new System.Drawing.Point(0, 0);
|
||||||
|
this.tableLayoutPanel1.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.tableLayoutPanel1.Name = "tableLayoutPanel1";
|
||||||
|
this.tableLayoutPanel1.RowCount = 5;
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 20F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 20F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 20F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 20F));
|
||||||
|
this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 20F));
|
||||||
|
this.tableLayoutPanel1.Size = new System.Drawing.Size(800, 159);
|
||||||
|
this.tableLayoutPanel1.TabIndex = 12;
|
||||||
|
//
|
||||||
|
// label5
|
||||||
|
//
|
||||||
|
this.label5.AutoSize = true;
|
||||||
|
this.label5.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label5.Location = new System.Drawing.Point(260, 124);
|
||||||
|
this.label5.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label5.Name = "label5";
|
||||||
|
this.label5.Size = new System.Drawing.Size(536, 35);
|
||||||
|
this.label5.TabIndex = 15;
|
||||||
|
this.label5.Text = "For SSO to work, additional IIS configuration is required!";
|
||||||
|
this.label5.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// label1
|
||||||
|
//
|
||||||
|
this.label1.AutoSize = true;
|
||||||
|
this.label1.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label1.Location = new System.Drawing.Point(4, 0);
|
||||||
|
this.label1.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label1.Name = "label1";
|
||||||
|
this.label1.Size = new System.Drawing.Size(248, 31);
|
||||||
|
this.label1.TabIndex = 2;
|
||||||
|
this.label1.Text = "Secret Server URL";
|
||||||
|
this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// label2
|
||||||
|
//
|
||||||
|
this.label2.AutoSize = true;
|
||||||
|
this.label2.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label2.Location = new System.Drawing.Point(4, 31);
|
||||||
|
this.label2.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label2.Name = "label2";
|
||||||
|
this.label2.Size = new System.Drawing.Size(248, 31);
|
||||||
|
this.label2.TabIndex = 4;
|
||||||
|
this.label2.Text = "DOMAIN\\Username";
|
||||||
|
this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// cbUseSSO
|
||||||
|
//
|
||||||
|
this.cbUseSSO.AutoSize = true;
|
||||||
|
this.cbUseSSO.Location = new System.Drawing.Point(4, 128);
|
||||||
|
this.cbUseSSO.Margin = new System.Windows.Forms.Padding(4, 4, 4, 0);
|
||||||
|
this.cbUseSSO.Name = "cbUseSSO";
|
||||||
|
this.cbUseSSO.Size = new System.Drawing.Size(69, 19);
|
||||||
|
this.cbUseSSO.TabIndex = 14;
|
||||||
|
this.cbUseSSO.Text = "Use SSO";
|
||||||
|
this.cbUseSSO.UseVisualStyleBackColor = true;
|
||||||
|
this.cbUseSSO.CheckedChanged += new System.EventHandler(this.cbUseSSO_CheckedChanged);
|
||||||
|
//
|
||||||
|
// label6
|
||||||
|
//
|
||||||
|
this.label6.AutoSize = true;
|
||||||
|
this.label6.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label6.Location = new System.Drawing.Point(3, 93);
|
||||||
|
this.label6.Name = "label6";
|
||||||
|
this.label6.Size = new System.Drawing.Size(250, 31);
|
||||||
|
this.label6.TabIndex = 15;
|
||||||
|
this.label6.Text = "2FA OTP (Optional)";
|
||||||
|
//
|
||||||
|
// tbOTP
|
||||||
|
//
|
||||||
|
this.tbOTP.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.tbOTP.Location = new System.Drawing.Point(259, 96);
|
||||||
|
this.tbOTP.Name = "tbOTP";
|
||||||
|
this.tbOTP.Size = new System.Drawing.Size(538, 23);
|
||||||
|
this.tbOTP.TabIndex = 5;
|
||||||
|
//
|
||||||
|
// tableLayoutPanel2
|
||||||
|
//
|
||||||
|
this.tableLayoutPanel2.ColumnCount = 5;
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 93F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 23F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F));
|
||||||
|
this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 93F));
|
||||||
|
this.tableLayoutPanel2.Controls.Add(this.btnOK, 1, 0);
|
||||||
|
this.tableLayoutPanel2.Controls.Add(this.btnCancel, 3, 0);
|
||||||
|
this.tableLayoutPanel2.Dock = System.Windows.Forms.DockStyle.Bottom;
|
||||||
|
this.tableLayoutPanel2.Location = new System.Drawing.Point(0, 225);
|
||||||
|
this.tableLayoutPanel2.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.tableLayoutPanel2.Name = "tableLayoutPanel2";
|
||||||
|
this.tableLayoutPanel2.RowCount = 1;
|
||||||
|
this.tableLayoutPanel2.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 100F));
|
||||||
|
this.tableLayoutPanel2.Size = new System.Drawing.Size(800, 50);
|
||||||
|
this.tableLayoutPanel2.TabIndex = 13;
|
||||||
|
//
|
||||||
|
// label4
|
||||||
|
//
|
||||||
|
this.label4.AutoSize = true;
|
||||||
|
this.label4.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||||
|
this.label4.Location = new System.Drawing.Point(0, 159);
|
||||||
|
this.label4.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
|
||||||
|
this.label4.Name = "label4";
|
||||||
|
this.label4.Size = new System.Drawing.Size(341, 15);
|
||||||
|
this.label4.TabIndex = 14;
|
||||||
|
this.label4.Text = "URL is the base URL, like https://cred.domain.local/SecretServer";
|
||||||
|
this.label4.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
|
||||||
|
//
|
||||||
|
// SSConnectionForm
|
||||||
|
//
|
||||||
|
this.AcceptButton = this.btnOK;
|
||||||
|
this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
||||||
|
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||||
|
this.ClientSize = new System.Drawing.Size(800, 275);
|
||||||
|
this.Controls.Add(this.label4);
|
||||||
|
this.Controls.Add(this.tableLayoutPanel2);
|
||||||
|
this.Controls.Add(this.tableLayoutPanel1);
|
||||||
|
this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon")));
|
||||||
|
this.Margin = new System.Windows.Forms.Padding(4);
|
||||||
|
this.Name = "SSConnectionForm";
|
||||||
|
this.Text = "Secret Server API Login Data";
|
||||||
|
this.Activated += new System.EventHandler(this.SSConnectionForm_Activated);
|
||||||
|
this.tableLayoutPanel1.ResumeLayout(false);
|
||||||
|
this.tableLayoutPanel1.PerformLayout();
|
||||||
|
this.tableLayoutPanel2.ResumeLayout(false);
|
||||||
|
this.ResumeLayout(false);
|
||||||
|
this.PerformLayout();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
private System.Windows.Forms.Label label3;
|
||||||
|
|
||||||
|
public System.Windows.Forms.TextBox tbSSURL;
|
||||||
|
public System.Windows.Forms.TextBox tbUsername;
|
||||||
|
public System.Windows.Forms.TextBox tbPassword;
|
||||||
|
private System.Windows.Forms.Button btnOK;
|
||||||
|
private System.Windows.Forms.Button btnCancel;
|
||||||
|
private System.Windows.Forms.TableLayoutPanel tableLayoutPanel1;
|
||||||
|
private System.Windows.Forms.Label label2;
|
||||||
|
private System.Windows.Forms.Label label1;
|
||||||
|
private System.Windows.Forms.TableLayoutPanel tableLayoutPanel2;
|
||||||
|
public System.Windows.Forms.CheckBox cbUseSSO;
|
||||||
|
private System.Windows.Forms.Label label4;
|
||||||
|
private Label label5;
|
||||||
|
private Label label6;
|
||||||
|
public TextBox tbOTP;
|
||||||
|
}
|
||||||
|
}
|
||||||
30
ExternalConnectors/TSS/SSConnectionForm.cs
Normal file
30
ExternalConnectors/TSS/SSConnectionForm.cs
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
namespace ExternalConnectors.TSS
|
||||||
|
{
|
||||||
|
public partial class SSConnectionForm : Form
|
||||||
|
{
|
||||||
|
public SSConnectionForm()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SSConnectionForm_Activated(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
SetVisibility();
|
||||||
|
if (cbUseSSO.Checked)
|
||||||
|
btnOK.Focus();
|
||||||
|
else
|
||||||
|
tbPassword.Focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void cbUseSSO_CheckedChanged(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
SetVisibility();
|
||||||
|
}
|
||||||
|
private void SetVisibility()
|
||||||
|
{
|
||||||
|
bool ch = cbUseSSO.Checked;
|
||||||
|
tbPassword.Enabled = !ch;
|
||||||
|
tbUsername.Enabled = !ch;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
615
ExternalConnectors/TSS/SSConnectionForm.resx
Normal file
615
ExternalConnectors/TSS/SSConnectionForm.resx
Normal file
@@ -0,0 +1,615 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<assembly alias="System.Drawing" name="System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
|
||||||
|
<data name="$this.Icon" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
|
||||||
|
<value>
|
||||||
|
AAABAAQAQEAAAAEAIAAoQAAARgAAACAgAAABACAAKBAAAG5AAAAYGAAAAQAgACgJAACWUAAAEBAAAAEA
|
||||||
|
IAAoBAAAvlkAACgAAABAAAAAgAAAAAEAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD9/f3e/f397vz9
|
||||||
|
/e79/f3u7ezr7p6Xju5XTEHuNScV7i8hCe4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHAjuKx8I7jYoFu5XTUHumJGO7u3r6+79/f3u/f397v39
|
||||||
|
/e79/f3e/f399P//////////u7Wy/0M1KP8jEwD/KRgA/ywdBv8tHwj/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8sHAT/KRcA/yAR
|
||||||
|
AP9DNSX/ubOt/////////////f399Pv8/e7/////m5aK/xoMAP8lFAD/LSAI/y0gCv8uIAr/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cv8uIAr/LB4J/ysfCf8uIQj/JBYA/xoLAP+elYz///////z9/O79/f3uvLWw/xsNAP8rHAX/LiAK/y0f
|
||||||
|
Cf8tHwj/LR8I/y0fCf8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCf8tHwn/LR8J/y4gCv8pGgP/GgsA/7y3sP/9/f3u6unp7kM0
|
||||||
|
I/8nFwH/LiEL/yweCP8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAr/LR8J/yIU
|
||||||
|
AP9DNSL/6+nq7pqUju4fEQD/LiAI/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAf/HxAA/5qTju5YTT7uJRYA/ywgCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/Kx8I/ygXAP9YTkDuOCkV7iweBv8sHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sHQX/NykW7ioc
|
||||||
|
CO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8uIAn/Lh8I/yocCO4qHAjuLyEK/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8K/y4gCf8rHAjuKx8I7i4gCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8J/y0fCP8tHwn/LR8J/y0f
|
||||||
|
CP8tHwn/LR8J/y0fCP8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
CP8tHwj/LR8J/y0fCf8tHwj/LR8J/y0fCf8tHwn/LR8J/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8uIAj/Kx8I7isfCO4uIAn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8I/y8fCP8uHwj/LR8G/yweCP8uHgn/LR4H/yweB/8rHgf/Kx4H/yweCP8sHgj/Kx4I/yse
|
||||||
|
CP8sHgj/LB4I/yweCP8sHgn/LB4J/yoeCP8qHgj/LB4I/y4fCP8sIQj/LB8H/y0eCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysf
|
||||||
|
CO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tIAn/LiAK/y0WAf8sFgH/LRsG/ywbBv8uGwX/MR0B/y8cAv8uGwX/LRkG/ysZ
|
||||||
|
Bf8qGQX/KhkF/ygaBP8oGgX/JxoF/ycaBf8pGgX/KRkG/ykZBv8nGQT/JxkF/ygZCv8jFAb/IBUG/ywe
|
||||||
|
Cf8tHwf/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/Lh0I/y0XA/84Qyf/P31P/0aSXP9KkVv/UpJT/2OV
|
||||||
|
Sv93mUf/jJ9A/6CjPP+vpjv/rac4/6ilN/+ppDn/qaQ4/62jOP+uozj/sKI2/7KiNv+yojX/s6Az/7Wi
|
||||||
|
NP+0oDP/mIUs/1pIFv8lFQb/Kh4I/y4gCf8sHgn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR4I/ygWA/83b0X/SsOE/0zC
|
||||||
|
f/9QvHf/Ubp0/1e4b/9YtGz/WrJl/2KwZP96tWD/lL9X/7fNUf/b2E//3NhP/9nWTP/X00v/29NL/9vS
|
||||||
|
Sv/d0Ur/39FJ/9/RSP/j0Ej/5tBD/+3VRP/r0EX/jHYl/yMUBv8sHwb/LB4I/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/ysV
|
||||||
|
AP8zWTb/ScmH/0e8ef9Ltnb/TrRx/1Cyb/9VsGr/Wa1m/1mrYf9dqV3/XqRc/1yfWf9ooVL/g6tQ/7XD
|
||||||
|
Tf/R0Ur/ys1H/87LR//Oykb/0MlG/9PKRf/Uy0X/18pF/9jJQf/byEH/4MtD/+7VRv9rWxz/HxMC/y8h
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/Kx8I/y0cBv8vHQj/QKFs/0fEgP9IuHX/TLZ0/0+0cP9UsW3/Vq9o/1isZP9cqWD/X6hc/2Ok
|
||||||
|
Wf9loVX/aKBT/2iZUP9um0j/obZJ/87RTP/SzUz/yspI/8zLSP/Qykj/0stH/9XJR//VyUT/2clE/9fH
|
||||||
|
RP/izkn/vao2/ywdBv8rHAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tGwX/MCoV/0azfP9Fvnv/Sbh2/0y2c/9PtG//VbFs/1av
|
||||||
|
Z/9YrGT/XKlg/2KnXP9kpVr/ZaJX/2mhU/9unkz/bZtK/2qVR/+asUj/zdJM/8nOSf/JzUv/zcxJ/8/L
|
||||||
|
R//Rykf/0cpE/9XKRP/WykX/3c5G/9DBQv86Kw//KRoH/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LiAI/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwr/LRoE/ywsGP9Dt3//R7x6/0q3
|
||||||
|
dv9OtHL/ULNu/1Wwa/9Xrmb/Watj/12pXv9hplv/ZaRY/2eiVP9qoFH/bp5M/3OcSf9ymUb/b5BC/6m5
|
||||||
|
SP/L0k7/yM5M/8vNS//LzEn/z8xJ/87LR//Rykf/08tH/9nNSP/RxkT/PS8R/ygZBv8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4g
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LB8K/y4a
|
||||||
|
A/8uLRj/RLZ9/0e8ev9LtnX/ULNy/1Gybf9VsGr/Wa5l/1mrYv9dqVz/YKZa/2WkVv9oolL/aqBQ/2+e
|
||||||
|
S/9zm0n/dJpE/3SUQ/+Dmj7/wMxM/8fPTP/IzUz/yc5L/8zNS//LzEr/z8tK/8/LSP/UzUj/0MZG/z0u
|
||||||
|
EP8oGgX/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8uIAj/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/ywfCv8uGgP/Li0Y/0W2fP9Iu3n/TLZ0/1Czcf9Rsm3/VbBq/1muZf9aq2L/Xqlc/2Gm
|
||||||
|
Wv9lpFb/aKJS/2ugUP9wnkv/c5tI/3WaQ/95l0H/do07/6m6Rf/F007/xM5N/8XOTP/IzUz/yM5L/8zN
|
||||||
|
S//MzEn/0c9J/83HR/89LhD/KBoG/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwr/LRsE/zAsGP9HtHr/S7p3/061cv9Qs2//U7Fr/1Wv
|
||||||
|
af9arGP/XKlh/2GnW/9lpFn/ZaNV/2igUf9unk7/cpxK/3WbRv91mEH/e5Y//3mPOP+YrEH/wtVT/7/O
|
||||||
|
Uf/CzlD/xc1Q/8TOTP/IzUz/yc5L/87QTP/HyEn/PS8P/ykZBv8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8K/y0bBP8wLBj/R7R6/0u6
|
||||||
|
d/9OtXL/ULNv/1Oxa/9Vr2n/Wqxj/1ypYf9hp1v/ZaRZ/2WjVf9ooFH/bp5O/3KcSv91m0b/dZhB/3yW
|
||||||
|
P/97kDj/j6I9/7/VV/+90VH/wNBR/8PPUf/Bz0z/xM5M/8XOS//K0Uz/xclJ/z0vD/8pGQb/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isf
|
||||||
|
CO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tGwT/MCwa/0qzef9MuXb/TrRx/1Kybv9Tr2n/V61k/12qYP9fqF3/YKZZ/2SkVv9qoVL/bKBP/26d
|
||||||
|
TP9ym0b/dJpE/3iWQf98lD7/fY43/42gPf+111v/t9RU/7nSU/+/z1L/vtBQ/8HPUP/Cz03/xtFN/8HJ
|
||||||
|
TP88MA//KhsF/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LRsE/zAsGv9Ks3n/TLl2/060cf9Ssm7/U69p/1etZP9dqmD/X6hd/2Cm
|
||||||
|
Wf9kpFb/aqFS/2ygT/9unUz/cptG/3SaRP94lkH/fJQ+/36NNv+LpkP/qNxh/6zYWv+v1Ff/ttFV/7zS
|
||||||
|
Uf/A0VL/wNFP/8TUT//Ayk3/PDAP/yobBP8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4cA/8wLBn/SrN2/024dP9Ps3D/VLFs/1eu
|
||||||
|
Z/9Zq2T/XKlf/2KnXf9jpVj/ZaNV/2qgUf9unk7/cJ1K/3KbRf92mUP/e5U+/3mUPP9/jDP/ibRM/5zi
|
||||||
|
aP+g2mD/pdhe/6zVW/+01Ff/utNU/7vSUv/D1VH/vctN/zswEf8pGgb/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8uHQL/MCwY/0qz
|
||||||
|
df9NuHP/T7Nv/1Wwa/9arWb/Wqtj/1qpX/9jplz/ZKRY/2WiVf9qoFH/b55N/3CdSf9ym0T/d5hC/3yW
|
||||||
|
Pf98kjn/g441/4nRZP+N4mv/ld5n/5rcZf+g22D/p9hd/63XWf+y1Fb/utZU/7jMTv86MBH/KBoG/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LiAI/ysf
|
||||||
|
CO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/Lh0D/zAsF/9LsnT/Trdz/1Gybv9WsGr/WK1l/1uqYv9dqV3/YqZb/2WkVv9nolT/aqBQ/2+e
|
||||||
|
TP9ynEn/c5pD/3aXQf97lT3/gokz/3uvT/986nr/g+Rw/4nibf+O32v/lN5n/5rcY/+h22D/ptdd/6/Y
|
||||||
|
Wv+xzlX/Oi8R/ygZBv8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4cBf8wLRb/TbFz/1C2cv9TsWz/V7Bo/1etZP9cqmH/Yahb/2Gl
|
||||||
|
Wv9mo1T/aKFS/2ugTv9wnUr/dJpI/3WZQ/98kz3/gYo3/3WsUP9s7ID/but8/3fneP995XT/geJy/4fh
|
||||||
|
bf+O32r/lN5m/5rbZP+j3GL/pdJd/zkvEv8pFwX/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHAX/MC0W/02xc/9QtnL/U7Fs/1ev
|
||||||
|
aP9YrWT/XKpg/1+oW/9hpVr/ZqNV/2mhUv9sn03/cJxJ/3WVRP95kT3/eJZA/2TAYf9Y8Yj/XPOI/2fs
|
||||||
|
gv9r637/cel7/3bneP995XT/g+Nw/4nibP+P32r/l+Bo/5jXYf85MBL/KhgG/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/KhsE/zAs
|
||||||
|
FP9NsXH/UbVv/1awav9arWf/Wqxi/12oXv9jo1v/Y6FU/2mcUP9tm0r/bptI/2+cSv9rp1P/YMNo/1Do
|
||||||
|
hf9G/ZX/SfaO/1PyjP9b8Ir/X+6F/2btgv9s637/cul6/3fmeP995XT/g+Nw/4vlbv+O22n/NjAU/yca
|
||||||
|
BP8uHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/yobBP8wLBT/TbJy/1G1b/9WsGr/Wq1n/1uoX/9dp13/YKlf/2CvXv9gt2X/XcBq/1XQ
|
||||||
|
dv9P4YP/SPCO/0T3lP9J85L/R/SR/0n1kf9L9ZD/TfSP/1Tzi/9b8Yj/Yu+E/2ftgP9r637/cel6/3jn
|
||||||
|
dv+A6XT/geBs/zgxFf8pGwX/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y8fCf8rHAL/LisU/02ucv9Vs23/VLBp/1ipYP9XuGr/TtOA/0fg
|
||||||
|
if9H5Ir/RuqO/0Xukf9G7pL/Ru2Q/0Ttjf9J7I7/R+6N/0nwj/9L8ZD/S/KR/0nzkP9I85D/TPSN/1X0
|
||||||
|
if9d8If/Ye6D/2fsf/9s6nz/cux7/3Xic/81MRb/KxkE/ywfCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sHwn/Lh0D/y4gCP9PnWP/Vbdx/1eq
|
||||||
|
ZP9TwXP/RuSM/0fmjv9F4ov/Q+SJ/0bliv9F5or/RuaM/0bojP9G6or/R+uM/0jtjP9J7o3/SO+O/0nw
|
||||||
|
j/9I8o//RvKP/0f0j/9K947/S/WN/1Tyif9b8YT/YO6D/2n2hP9kz27/KyEM/y4dBv8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LB8J/y4e
|
||||||
|
B/8sFgH/PGU2/1i9dP9Utm3/RN6J/0Leif9J3on/SN+K/0Xgif9H4ov/R+KL/0fjjP9I5Yz/R+eL/0jo
|
||||||
|
jP9I6o3/SeuO/0jsjf9J7Y7/SO+O/0jwjv9J8Y//S/OQ/0r0kf9M9ZD/T/SO/1Pziv9h/5X/SIJE/yoP
|
||||||
|
Af8sHwf/LR8K/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8uIAn/Kx8I7isfCO4uIAj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwn/LBwH/ywdCf9IfEf/Tsx8/0Ddif9F14X/RduH/0bdiP9E3on/Rd+K/0fl
|
||||||
|
jf9I6JD/SOqQ/0jsj/9J7ZD/SO6R/0nvkv9H8JD/SPKR/0n0kf9K84//SPCP/0fxkP9J8pH/SvWS/0r3
|
||||||
|
lP9M/pn/RKxh/y0YBv8sHAf/LR8J/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LiAI/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sGgX/KhUE/0GsbP9E4Y7/QteG/0TZ
|
||||||
|
h/9F2oj/RdyI/0Teiv9Ez3//RMp7/0XNe/9Eznr/RM97/0TQff9F0H3/Q9J7/0PTfP9E0n3/SNyC/0zq
|
||||||
|
iv9M6Yr/TeqL/0zsiv9P8Iz/S7Vp/ywWB/8sGgT/LiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sHwn/Lh8G/ywR
|
||||||
|
BP87m2b/ReCR/0PUiP9E1oj/RtiJ/0bZh/9D5o//Nlk1/ywZB/8vJg3/LyYM/y8mDP8vJQ3/LyUN/ywm
|
||||||
|
DP8sJgz/KhgH/z9sO/9c2Hr/Vslx/1fJcf9YyXL/XdF3/0yRUv8pEwT/LyEJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isf
|
||||||
|
CO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LB8J/y0eBv8sEwX/PJ1n/0Tej/9D0of/Q9SG/0TWiP9F2Ib/QuWO/zVPLv8sDgD/MBsI/y8b
|
||||||
|
B/8vGwb/LhsE/y4bBP8sGgb/KxoG/ywKAP87Zjr/U+CD/1HQe/9R0Hv/UtB7/1Pcg/9En17/KxMD/y4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4fCf8sHwj/LhUD/0CbZP9F2o7/RM+H/0TQhv9F0of/Q9WG/0bk
|
||||||
|
kf8yVzL/KxEA/y4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tDgD/O3ZF/0zslP9I2ob/SdqG/0na
|
||||||
|
hv9L5o7/QaNm/ywVAv8uHgf/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sHwj/LiAJ/ywUAf89jlf/Q9qO/0LN
|
||||||
|
hf9Dz4T/RNCG/0LRg/9H4I//O4dQ/yoOAP8tIAj/LR8J/y0fCf8tHwn/LR8J/y0fCP8tHgj/LBMC/z+n
|
||||||
|
ZP9H6pH/RN+K/0Tfiv9E34r/RuyT/z2bXv8uEwH/LR8H/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LB8J/y0f
|
||||||
|
Cf8rDwD/NXNF/0PZjP9DyYX/RcuF/0XNhv9EzYT/RdSJ/0TFfv8uKRH/LBYC/ywfCP8tHwn/LR8J/ywf
|
||||||
|
Cf8sHwj/KBAA/zZAIf9H34n/R+GL/0Xdif9F3Yn/Rd2I/0nvlv86gU3/Kg4A/y0eCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysf
|
||||||
|
CO4rHwjuLiAI/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCf8rHwj/LRMB/zZRLv9H0ov/QsmE/0LKhP9Ey4X/Q8uE/0XMhP9H3I7/Pppj/ysa
|
||||||
|
Bv8sEQD/Lh0I/y0fB/8tGgX/Kg4A/y0lD/9AuXH/R+qQ/0Lci/9D34n/Rd6J/0PdiP9C65H/M1wx/y8U
|
||||||
|
Av8uIAf/LR8J/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y4gCP8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LB4I/y4bBv8uJQ//QLV4/0LNh/9Bx4P/Q8iE/0PJ
|
||||||
|
g/9Ey4P/RMuG/0Xajv9EpGn/MEoo/ysfC/8uFgr/LiUN/zNULf8+vHf/SOWQ/0TYh/9F3Ij/Rt6J/0fe
|
||||||
|
i/9E44z/Rc9//y0qDv8vGQX/LSAH/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCf8tHwn/KxEA/zt2
|
||||||
|
Sv9F047/QcOC/0PFg/9Cx4L/RMmD/0PKgv9EzIP/RdaL/0fUif8/t3P/Pqpv/0C+dv9H3I//Rt6O/0HW
|
||||||
|
hv9E1oj/RdiI/0Tah/9G3In/R+6U/zuET/8sDwD/LR8J/y0fCf8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LiAI/ysfCO4rHwjuLiAJ/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0aBP8wKhH/QLV4/0HKhv9BxIP/QsWB/0LHgv9CyIL/QsmD/0XKg/9FzoT/Q9KH/0LY
|
||||||
|
iP9G14r/Q9CH/0XRhf9F0oX/RNSI/0LXiP9C14X/ReGM/0XOgv8uKxT/KxgF/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8rHwjuKx8I7i4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwf/LRYA/zRTL/9Dy4v/QcWG/0HCgf9CxIL/QsSC/0PE
|
||||||
|
g/9CxoP/Q8iC/0TKhP9Dy4T/RsyF/0PNhf9Cz4b/RNCH/0XSiP9H0oj/QtiJ/0jikP8yWjX/KxAA/ywg
|
||||||
|
B/8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LSAH/y8gBv8vEgD/OWlC/0PL
|
||||||
|
if8+xYP/P8KA/0DCgf9Bw4L/QsaC/0LHgf9DyIL/QsqC/0PLg/9CzIT/Q82F/0TOhf9Fz4X/RdaK/0fg
|
||||||
|
lf85dkf/KhEA/yseB/8uHwj/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8vHwn/Kh4I/y8WAP82Yzj/P7+C/0LLiP9CwoL/QMGC/0HFhP9BxIH/Q8WD/0PGhP9Ex4X/RMmE/0bK
|
||||||
|
hf9DzYT/QtyN/0nTiP86aj3/LRIA/y4eCP8sIAr/Lh8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuKx8I7i4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8rIAj/KhQA/zU/IP9Bl2X/RseI/0LLiv8/x4b/QMaD/0DF
|
||||||
|
g/9CxoT/Q8mG/0LOh/9G1o3/RtSK/0WjaP8yQiD/LBEA/y8eCP8sIAn/LR8I/y0fCP8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8uIAn/Kx8I7isfCO4uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sHwn/LR4I/y4gCv8sFQD/KxoE/zRJ
|
||||||
|
Kf9Cg1P/Q6tv/0O6ev9EwoL/QsOC/0a+fv9FsHD/QoZS/zZJJ/8sGgT/KxMB/y4fCf8wIAj/Lh8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LiAJ/ysfCO4rHwjuLiAI/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8J/y0f
|
||||||
|
Cf8tHwj/LR8J/y0dCP8rEwL/LBQA/zEjCf8yLxP/Njce/zQ3H/8yMBT/MiMJ/y8UAP8rEgD/LB0H/y4g
|
||||||
|
Cf8tHwn/LB8J/y0fCf8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y4gCP8rHwjuKx8I7i4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAI/yseB/8rHQj/LBoF/ysXAv8sGAP/KxsF/ygb
|
||||||
|
Bv8wHgf/LR8J/y4fCv8uIAr/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/Kx8I7isf
|
||||||
|
CO4uIAj/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8I/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LB8J/y0fCf8tHwj/LR8I/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LiAJ/ysfCO4rHwjuLyEJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHwjuLh8J7i8hCP8tIAj/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwj/LyEJ7jgqFu4sHgX/LR8H/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/LB4G/zUn
|
||||||
|
FO5YTT7uJhUA/y4gCv8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LSAL/yoZAP9XTD7um5SO7iMRAP8vIAn/LR8J/y0fCf8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwn/LR8I/ywfBv8iEgD/npeO7urq6e5ENSX/JBQA/y0hCP8tIAf/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/Kx0H/y4gCv8lFQD/QzYm/+vr6e79/f3uvLax/xoM
|
||||||
|
AP8pGwL/LiEI/y0fCf8tHwj/LR8J/y0fCf8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0f
|
||||||
|
CP8tHwj/LR8I/y0fCP8tHwj/LR8I/y0fCP8tHwj/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHQX/Gw0A/723
|
||||||
|
tP/9/f3u+vv87v////+ak4n/GQsA/yQUAP8uHwn/LR8J/y0fCP8uIAn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0eCf8sHgj/LB8J/y4g
|
||||||
|
B/8mFwD/Gw0A/5qViv//////+/z87v39/fT//////////7q1sP9DNCb/IxEA/ycWAP8rHgX/LiAH/y8h
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/zAh
|
||||||
|
Cv8uHwj/LB0G/yQWAP8fEQD/QzQm/7q0r/////////////39/fT9/f3e/f397vz9/e79/f3u6+rp7puU
|
||||||
|
ju5YTj/uOCkW7i4fCu4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isfCO4rHwjuKx8I7isf
|
||||||
|
CO4rHwjuKx8I7isfCO4rHwjuKyAI7jcpFu5YTj7umpOO7uvr6u79/f3u/Pz97v39/e79/f3eKAAAACAA
|
||||||
|
AABAAAAAAQAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP39/dzt6+vtdGte7TQmFu0rHQjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7SsdBu00Jhbtc2le7e3r6e39/f3c6ubl81ZKOP8dDgD/LB4G/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LyAK/ywdBf8dDgD/VUk4/+rn5vN0a13tHg4A/y4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8dDQD/dWtd7TQm
|
||||||
|
Eu0rHQb/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/ywd
|
||||||
|
Bf80JhLtKx0G7S8gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LiAJ/ysdBu0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwj/LBcC/ysT
|
||||||
|
AP8pFAH/JhMC/yISA/8hEQP/IBID/yASA/8gEgT/HxIE/x8RBP8jFgb/LB4I/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR4I/ywY
|
||||||
|
BP81QiP/Olw1/0RbLP9WXSb/bGMj/3RnIP9vZCD/bmIg/3FiIP9yYh7/dWMf/1ZFFv8lFwb/LB4I/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8rFgL/N2c//0vDgf9SwHr/W7pv/2a2Zf9+t13/p8RT/9bYT//g20z/3tZL/+LWSv/p10f/69RF/39r
|
||||||
|
Iv8iFQT/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LBwG/y4lD/9Esnb/Sr55/1Kybv9XrWf/Xahe/1+iWP9imlH/faJJ/8DHSv/Pz0r/z8tI/9PK
|
||||||
|
Rf/f0Uf/z75A/zQmC/8pGwj/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8sGgX/Ly0W/0S0ef9NuHb/U7Fs/1itZP9ep1z/ZqNW/2yfTv9slUb/hqFE/8fP
|
||||||
|
TP/Lzkv/zcxJ/9TOSf/Ow0T/PS4P/ygaB/8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/ywbBf8wLBX/RrF1/0+4dP9UsGv/Wqxj/2CmWv9molT/b55N/3WZ
|
||||||
|
RP93kTz/r8BI/8fST//Hzkz/zdFM/8bERv87LQ7/KRoH/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0f
|
||||||
|
CO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LBsF/zAsFf9Jr3T/ULdz/1WvaP9dqmD/YqVZ/2mg
|
||||||
|
Uv9wnEv/dplD/3mOOf+iuEn/wNZV/8HPT//H0k7/v8ZJ/zstDv8pGgf/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8sGwX/MCwV/0mvc/9RtnH/Vq1m/16p
|
||||||
|
Xv9jpFf/bKBQ/3CcSP93mEH/fIw2/5bCU/+q3F//tdNW/8HWUv+7yEv/Oi4O/ykaB/8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/ywbBf8wLRT/S65w/1O1
|
||||||
|
bv9ZrGT/YKdc/2ajVv9sn0//cpxG/3uPOf+AmT7/hd5t/5Hhav+e22L/rdtc/6/KUf85LQ//KRoH/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LBsG/zAs
|
||||||
|
E/9NrW7/VrRt/1qrYf9ipFj/aZ5R/3GXR/94kj//dKFI/2bddv9t74H/eeZ2/4Xib/+U4mr/mdFe/zgt
|
||||||
|
EP8qGQb/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8sGwb/LiwU/06ubf9ZsGn/Xahf/2CqXv9jr13/YLtj/1jRdP9K8o7/SvqT/1byi/9j7oP/b+p8/3zq
|
||||||
|
d/+D22r/NjAS/yoaBv8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/ywcBv8vJw7/Ualp/1e3bP9N0n//R+GJ/0bojf9E75H/RPKR/0jwj/9J8ZD/R/OR/0z1
|
||||||
|
jv9W8on/ZfWF/2vhd/8yKg//KxoG/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8I/ysXAv9CaTr/TNSC/0PijP9F34n/RueP/0n0lv9J95b/SvqY/0n9
|
||||||
|
mP9J+5b/R/OR/0j4lP9Q/pb/RI5N/ysTAv8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0f
|
||||||
|
CO0uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LRwG/ywbB/9Aunf/RN6M/0bijf9At3D/OXJC/zp7
|
||||||
|
Rf86fEb/NnhD/z+SUv9S3H//U+KD/068bf8sGgj/LRsH/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHQf/LRwI/0CydP9E2oz/RuWR/zqO
|
||||||
|
Vv8qAAD/LA8A/ywOAP8pAgD/Mzkb/0/bhP9Q24T/SLRs/y0dCP8tHQf/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0eCP8tGQT/PqZp/0TW
|
||||||
|
jP9F1or/Qbh0/ywbBv8sFQL/LBwG/ykGAP86eEX/Ru6U/0Xpkf9At3H/LRkE/y0eB/8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/ysR
|
||||||
|
AP86fk//RNeP/0TJg/9G14z/PI1Y/y4pEP8tHQn/M1ky/0TWhv9F4Yz/R/CV/zqOU/8sEAD/LR8I/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LBcD/zE5HP9CxoX/QsqF/0PIgv9F1ov/QsR+/0C7d/9F2oz/RNmK/0Xdiv9G34z/MT0d/ywW
|
||||||
|
A/8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LBQA/zdmPf9C0Iz/QcmG/0LFgv9DzIX/RNGI/0POhv9F14v/R+WU/zdv
|
||||||
|
Qv8qEQD/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHgj/LBUB/zVeNv9Ct3v/Q8+M/0LRjP9E1I7/RteO/0TE
|
||||||
|
fv84ZDr/LRQB/y0eCP8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHgj/LBMA/y8qEf84Xjb/O3lM/zt6
|
||||||
|
Tf86YDf/MCoR/ysSAP8tHgj/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LiAJ/y0f
|
||||||
|
CO0tHwjtLiAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LBoF/ysT
|
||||||
|
AP8sEQD/KxEA/ysSAP8sGgX/LSAJ/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8uIAn/LR8I7SweBu0vIAn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8rHQbtNCYT7SwdBv8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LB4G/zQmEu11a17tHQ4A/y4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0gCf8dDgD/dmxe7ern5vNVSTf/Hg4A/ywdBv8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8rHQX/Hg4A/1ZKOP/q5+fz/f393Ozr6e10aV7tNSYU7Swe
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLB4I7TQmFO1zaV7t7evp7f39/dwoAAAAGAAAADAA
|
||||||
|
AAABACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/f393JSPhO00JhbtKx0G7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0rHQbtMyUW7ZSO
|
||||||
|
g+39/f3ckouC8yESAP8qHAT/LyAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8vIAn/KhwE/yERAP+Si4LzMyUR7SocBP8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/yocBP8zJRLtKx0F7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0eCP8sGgX/KxoG/yka
|
||||||
|
B/8oGgf/KBoH/ygaB/8nGgf/KBoH/yweCP8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8rHQXtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LRwH/y0aBf8wLRP/Ni8Q/0ExDv9FMw3/PjAN/z4vDv8/MA3/PS4N/ycZ
|
||||||
|
B/8qHAj/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHQf/LB8K/z6E
|
||||||
|
VP9NsnL/Wapi/3GoVv+bskv/x8VG/87FRP/PwkL/2cZB/6GMLf8tHwj/Kx0I/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8sFgH/MkYn/0nIhP9Rt3L/WK9m/16nXf9jnlP/iKlK/8nO
|
||||||
|
S//T0Er/2M9H/+jYSv9XSRf/IxUF/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8sFQH/M0os/0vBfv9Tsm3/Wqxi/2OlWP9sn07/bJJD/5uuRP/M0k3/y81L/9nWTP9cTxv/IhQF/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8rFQH/NEkq/02+e/9UsGr/Xalg/2Wj
|
||||||
|
Vv9unkz/dJRB/4ufPv+/01P/xM9O/8/XT/9YThr/IxQE/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8rFgH/NUkp/068ef9Xrmf/X6dc/2iiVP9wnUn/eI86/4ilRP+k3mL/tNVX/8ba
|
||||||
|
U/9WTxv/JBQE/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8rFgH/Nkgo/1K7
|
||||||
|
dv9ZrWT/YqRZ/2ycTf93kj//epU+/3bVa/+D53T/lN5n/63hYv9RTx//JRMD/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8qFQL/NUop/1a6c/9cqWH/Yatd/2SwW/9gv2b/UeeE/1L4
|
||||||
|
kP9k7oL/dOh5/4vvdf9JViX/JxIC/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8rFwP/NT4e/1a5cP9N0H3/R+GI/0fwkv9F+5n/SPuY/0j7lv9J95H/VfaM/2f6iP88SyH/KhQC/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHgj/LBUC/z6ETv9E6JL/Rd+L/0LG
|
||||||
|
ef9DwHP/QsR1/0LHdP9L4oX/T/aS/0KaV/8rFgT/LR4I/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/Kw8A/zVgOv9F4pL/Rd+N/zJGJP8tEAD/LRoF/ywaBv9Lum3/VOeL/zle
|
||||||
|
M/8qDwD/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/KxMA/zVX
|
||||||
|
Mf9F2I7/RtuO/zl3R/8qBQD/KQQA/zJDIv9F4Iv/RvCW/zVfNf8rEQD/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LBoF/zAtE/9Cv3//RNCJ/0TNhf86g1D/N29C/0LF
|
||||||
|
fP9G6JH/RNeF/y8wFP8sGQT/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/ywTAP82Yzv/QtKN/0PPif9F2I3/Rd2Q/0XekP9H5ZP/N2w//ysRAP8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0eCP8sFQH/NVs1/0Cu
|
||||||
|
dP9CxoT/RMqG/0O3dv83YTj/LBQB/y0eCP8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHgj/LBMA/y4iC/8zPB7/Mj0e/y8hCv8rEgD/LR4I/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4gCf8tHwjtKx0F7S4gCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/ywcB/8sFwP/LBcD/ywcB/8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y4g
|
||||||
|
Cf8rHQbtNCUS7SocBP8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0f
|
||||||
|
Cf8tHwn/LR8J/y0fCf8tHwn/LR8J/y0fCf8tHwn/LR8J/yocBP80JhLtkouD8yERAP8qHAT/LyAJ/y4g
|
||||||
|
Cf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8vIAn/KhwE/yERAP+VjITz/f393JSOhO00JhbtKx0G7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0rHQbtMyUW7ZSOg+39/f3cKAAAABAA
|
||||||
|
AAAgAAAAAQAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL65stw/MR/tKBkF7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0oGQXtPzEf7b65stw8MR3zJxgA/y8gCf8uIAn/LiAJ/y4g
|
||||||
|
Cf8uHwn/Lh8J/y4fCf8uHwn/LiAJ/y4gCf8uIAn/LyAJ/ycYAP88MR3zKBoE7S8gCf8tHwn/LSAJ/ywa
|
||||||
|
Bf8rFAH/LBcD/ysXBP8kFQT/IxUF/yATBP8oGgf/LiAJ/y0fCf8vIQn/KBkE7S0fCO0uIAn/LR8J/ywa
|
||||||
|
Bf8wMxj/QYNR/1OFSP94iTr/npg0/6aYM/+hji7/RDQP/ycaB/8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0f
|
||||||
|
Cf8rEQD/OW9F/1LNhP9dtGj/aahY/5u2TP/Z2U3/7+ZP/4V2KP8eEAT/LR8J/y4gCf8tHwjtLR8I7S4g
|
||||||
|
Cf8tHwn/KxIA/ztvRf9Tv3f/Xqhd/2ufT/91kj7/tMNK/9fgU/+AeSr/IBAD/y0fCf8uIAn/LR8I7S0f
|
||||||
|
CO0uIAn/LR8J/ysTAP89bUL/Vrxz/2OjWP9ylkX/fZQ7/5XTX/+952D/d3ot/yEQA/8tHwn/LiAJ/y0f
|
||||||
|
CO0tHwjtLiAJ/y0fCf8qEwD/P29C/1y6bv9iqlv/Z7Fa/1zad/9l8oX/ifZ6/2OGPP8lDgH/LR8J/y4g
|
||||||
|
Cf8tHwjtLR8I7S4gCf8tHwn/KhQB/zxULf9P0oD/SOSL/0b1lf9F/Jn/SPaS/1j7kP9DbTb/KRAB/y0f
|
||||||
|
Cf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0cB/8uIwz/QcuC/0HCef8zRSL/MD0e/0SmYP9M0n7/LSMN/ywc
|
||||||
|
Bv8tHwn/LiAJ/y0fCO0tHwjtLiAJ/y0fCf8tHQj/LRsG/0Cxc/9Ez4b/MDca/yweCf9Cxnr/Qsd6/y0b
|
||||||
|
Bv8tHQj/LR8J/y4gCf8tHwjtLR8I7S4gCf8tHwn/LR8J/ywUAf81XTf/RNiR/0TTiv9E1In/R+2Y/zZn
|
||||||
|
Ov8rEgH/LR8J/y0fCf8uIAn/LR8I7S0fCO0uIAn/LR8J/y0fCf8tHgj/LBcC/zRWMv8+nWb/P6Jo/zZb
|
||||||
|
NP8sFgL/LR4I/y0fCf8tHwn/LiAJ/y0fCO0oGgTtLyEJ/y0fCf8tHwn/LR8J/y0fCP8sFAH/LBYC/ywW
|
||||||
|
Av8rEwD/LR4I/y0fCf8tHwn/LR8J/y8hCf8oGQTtPTEd8ycYAP8vIAn/LiAJ/y4gCf8uIAn/LiAJ/y4f
|
||||||
|
CP8uHwn/LiAJ/y4gCf8uIAn/LiAJ/y8gCf8nGAD/PTEd87u5stw/MR/tKBkF7S0fCO0tHwjtLR8I7S0f
|
||||||
|
CO0tHwjtLR8I7S0fCO0tHwjtLR8I7S0fCO0oGQXtPzEf7b65stwAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
|
||||||
|
</value>
|
||||||
|
</data>
|
||||||
|
</root>
|
||||||
383
ExternalConnectors/TSS/SecretServerAuthentication.cs
Normal file
383
ExternalConnectors/TSS/SecretServerAuthentication.cs
Normal file
@@ -0,0 +1,383 @@
|
|||||||
|
//----------------------
|
||||||
|
// <auto-generated>
|
||||||
|
// Generated using the NSwag toolchain v13.14.8.0 (NJsonSchema v10.5.2.0 (Newtonsoft.Json v11.0.0.0)) (http://NSwag.org)
|
||||||
|
// </auto-generated>
|
||||||
|
//----------------------
|
||||||
|
|
||||||
|
#pragma warning disable 108 // Disable "CS0108 '{derivedDto}.ToJson()' hides inherited member '{dtoBase}.ToJson()'. Use the new keyword if hiding was intended."
|
||||||
|
#pragma warning disable 114 // Disable "CS0114 '{derivedDto}.RaisePropertyChanged(String)' hides inherited member 'dtoBase.RaisePropertyChanged(String)'. To make the current member override that implementation, add the override keyword. Otherwise add the new keyword."
|
||||||
|
#pragma warning disable 472 // Disable "CS0472 The result of the expression is always 'false' since a value of type 'Int32' is never equal to 'null' of type 'Int32?'
|
||||||
|
#pragma warning disable 1573 // Disable "CS1573 Parameter '...' has no matching param tag in the XML comment for ...
|
||||||
|
#pragma warning disable 1591 // Disable "CS1591 Missing XML comment for publicly visible type or member ..."
|
||||||
|
#pragma warning disable 8073 // Disable "CS8073 The result of the expression is always 'false' since a value of type 'T' is never equal to 'null' of type 'T?'"
|
||||||
|
#pragma warning disable 3016 // Disable "CS3016 Arrays as attribute arguments is not CLS-compliant"
|
||||||
|
|
||||||
|
namespace SecretServerAuthentication.TSS
|
||||||
|
{
|
||||||
|
using System = global::System;
|
||||||
|
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NSwag", "13.14.8.0 (NJsonSchema v10.5.2.0 (Newtonsoft.Json v11.0.0.0))")]
|
||||||
|
public partial class OAuth2ServiceClient
|
||||||
|
{
|
||||||
|
private string _baseUrl = "";
|
||||||
|
private System.Net.Http.HttpClient _httpClient;
|
||||||
|
private System.Lazy<Newtonsoft.Json.JsonSerializerSettings> _settings;
|
||||||
|
|
||||||
|
public OAuth2ServiceClient(string baseUrl, System.Net.Http.HttpClient httpClient)
|
||||||
|
{
|
||||||
|
BaseUrl = baseUrl;
|
||||||
|
_httpClient = httpClient;
|
||||||
|
_settings = new System.Lazy<Newtonsoft.Json.JsonSerializerSettings>(CreateSerializerSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Newtonsoft.Json.JsonSerializerSettings CreateSerializerSettings()
|
||||||
|
{
|
||||||
|
var settings = new Newtonsoft.Json.JsonSerializerSettings();
|
||||||
|
UpdateJsonSerializerSettings(settings);
|
||||||
|
return settings;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string BaseUrl
|
||||||
|
{
|
||||||
|
get { return _baseUrl; }
|
||||||
|
set { _baseUrl = value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Newtonsoft.Json.JsonSerializerSettings JsonSerializerSettings { get { return _settings.Value; } }
|
||||||
|
|
||||||
|
partial void UpdateJsonSerializerSettings(Newtonsoft.Json.JsonSerializerSettings settings);
|
||||||
|
|
||||||
|
|
||||||
|
partial void PrepareRequest(System.Net.Http.HttpClient client, System.Net.Http.HttpRequestMessage request, string url);
|
||||||
|
partial void PrepareRequest(System.Net.Http.HttpClient client, System.Net.Http.HttpRequestMessage request, System.Text.StringBuilder urlBuilder);
|
||||||
|
partial void ProcessResponse(System.Net.Http.HttpClient client, System.Net.Http.HttpResponseMessage response);
|
||||||
|
/// <summary>Retrieve or Refresh Access Token</summary>
|
||||||
|
/// <param name="grant_type">Authentication grant type. Use 'password' when authenticating, and 'refresh_token' when refreshing a token.</param>
|
||||||
|
/// <param name="username">Secret Server authentication username. Required when authenticating.</param>
|
||||||
|
/// <param name="password">Secret Server authentication password. Required when authenticating.</param>
|
||||||
|
/// <param name="refresh_token">The refresh token. Required when refreshing a token.</param>
|
||||||
|
/// <returns>Successful retrieval of an access token</returns>
|
||||||
|
/// <exception cref="ApiException">A server side error occurred.</exception>
|
||||||
|
public System.Threading.Tasks.Task<TokenResponse> AuthorizeAsync(Grant_type grant_type, string username, string password, string refresh_token, string OTP)
|
||||||
|
{
|
||||||
|
return AuthorizeAsync(grant_type, username, password, refresh_token, System.Threading.CancellationToken.None, OTP);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <param name="cancellationToken">A cancellation token that can be used by other objects or threads to receive notice of cancellation.</param>
|
||||||
|
/// <summary>Retrieve or Refresh Access Token</summary>
|
||||||
|
/// <param name="grant_type">Authentication grant type. Use 'password' when authenticating, and 'refresh_token' when refreshing a token.</param>
|
||||||
|
/// <param name="username">Secret Server authentication username. Required when authenticating.</param>
|
||||||
|
/// <param name="password">Secret Server authentication password. Required when authenticating.</param>
|
||||||
|
/// <param name="refresh_token">The refresh token. Required when refreshing a token.</param>
|
||||||
|
/// <returns>Successful retrieval of an access token</returns>
|
||||||
|
/// <exception cref="ApiException">A server side error occurred.</exception>
|
||||||
|
public async System.Threading.Tasks.Task<TokenResponse> AuthorizeAsync(Grant_type grant_type, string username, string password, string refresh_token, System.Threading.CancellationToken cancellationToken, string OTP)
|
||||||
|
{
|
||||||
|
var urlBuilder_ = new System.Text.StringBuilder();
|
||||||
|
urlBuilder_.Append(BaseUrl != null ? BaseUrl.TrimEnd('/') : "").Append("/oauth2/token");
|
||||||
|
|
||||||
|
var client_ = _httpClient;
|
||||||
|
var disposeClient_ = false;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
using (var request_ = new System.Net.Http.HttpRequestMessage())
|
||||||
|
{
|
||||||
|
var keyValues_ = new System.Collections.Generic.List<System.Collections.Generic.KeyValuePair<string, string>>();
|
||||||
|
if (grant_type == null)
|
||||||
|
throw new System.ArgumentNullException("grant_type");
|
||||||
|
else
|
||||||
|
keyValues_.Add(new System.Collections.Generic.KeyValuePair<string, string>("grant_type", ConvertToString(grant_type, System.Globalization.CultureInfo.InvariantCulture)));
|
||||||
|
if (username != null)
|
||||||
|
keyValues_.Add(new System.Collections.Generic.KeyValuePair<string, string>("username", ConvertToString(username, System.Globalization.CultureInfo.InvariantCulture)));
|
||||||
|
if (password != null)
|
||||||
|
keyValues_.Add(new System.Collections.Generic.KeyValuePair<string, string>("password", ConvertToString(password, System.Globalization.CultureInfo.InvariantCulture)));
|
||||||
|
if (refresh_token != null)
|
||||||
|
keyValues_.Add(new System.Collections.Generic.KeyValuePair<string, string>("refresh_token", ConvertToString(refresh_token, System.Globalization.CultureInfo.InvariantCulture)));
|
||||||
|
if (OTP != null)
|
||||||
|
request_.Headers.Add("OTP", ConvertToString(OTP, System.Globalization.CultureInfo.InvariantCulture));
|
||||||
|
|
||||||
|
request_.Content = new System.Net.Http.FormUrlEncodedContent(keyValues_);
|
||||||
|
request_.Method = new System.Net.Http.HttpMethod("POST");
|
||||||
|
request_.Headers.Accept.Add(System.Net.Http.Headers.MediaTypeWithQualityHeaderValue.Parse("application/json"));
|
||||||
|
|
||||||
|
PrepareRequest(client_, request_, urlBuilder_);
|
||||||
|
|
||||||
|
var url_ = urlBuilder_.ToString();
|
||||||
|
request_.RequestUri = new System.Uri(url_, System.UriKind.RelativeOrAbsolute);
|
||||||
|
|
||||||
|
PrepareRequest(client_, request_, url_);
|
||||||
|
|
||||||
|
var response_ = await client_.SendAsync(request_, System.Net.Http.HttpCompletionOption.ResponseHeadersRead, cancellationToken).ConfigureAwait(false);
|
||||||
|
var disposeResponse_ = true;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var headers_ = System.Linq.Enumerable.ToDictionary(response_.Headers, h_ => h_.Key, h_ => h_.Value);
|
||||||
|
if (response_.Content != null && response_.Content.Headers != null)
|
||||||
|
{
|
||||||
|
foreach (var item_ in response_.Content.Headers)
|
||||||
|
headers_[item_.Key] = item_.Value;
|
||||||
|
}
|
||||||
|
|
||||||
|
ProcessResponse(client_, response_);
|
||||||
|
|
||||||
|
var status_ = (int)response_.StatusCode;
|
||||||
|
if (status_ == 200)
|
||||||
|
{
|
||||||
|
var objectResponse_ = await ReadObjectResponseAsync<TokenResponse>(response_, headers_, cancellationToken).ConfigureAwait(false);
|
||||||
|
if (objectResponse_.Object == null)
|
||||||
|
{
|
||||||
|
throw new ApiException("Response was null which was not expected.", status_, objectResponse_.Text, headers_, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
return objectResponse_.Object;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
if (status_ == 400)
|
||||||
|
{
|
||||||
|
var objectResponse_ = await ReadObjectResponseAsync<TokenErrorResponse>(response_, headers_, cancellationToken).ConfigureAwait(false);
|
||||||
|
if (objectResponse_.Object == null)
|
||||||
|
{
|
||||||
|
throw new ApiException("Response was null which was not expected.", status_, objectResponse_.Text, headers_, null);
|
||||||
|
}
|
||||||
|
throw new ApiException<TokenErrorResponse>("An error occurred", status_, objectResponse_.Text, headers_, objectResponse_.Object, null);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var responseData_ = response_.Content == null ? null : await response_.Content.ReadAsStringAsync().ConfigureAwait(false);
|
||||||
|
throw new ApiException("The HTTP status code of the response was not expected (" + status_ + ").", status_, responseData_, headers_, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (disposeResponse_)
|
||||||
|
response_.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (disposeClient_)
|
||||||
|
client_.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected struct ObjectResponseResult<T>
|
||||||
|
{
|
||||||
|
public ObjectResponseResult(T responseObject, string responseText)
|
||||||
|
{
|
||||||
|
this.Object = responseObject;
|
||||||
|
this.Text = responseText;
|
||||||
|
}
|
||||||
|
|
||||||
|
public T Object { get; }
|
||||||
|
|
||||||
|
public string Text { get; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool ReadResponseAsString { get; set; }
|
||||||
|
|
||||||
|
protected virtual async System.Threading.Tasks.Task<ObjectResponseResult<T>> ReadObjectResponseAsync<T>(System.Net.Http.HttpResponseMessage response, System.Collections.Generic.IReadOnlyDictionary<string, System.Collections.Generic.IEnumerable<string>> headers, System.Threading.CancellationToken cancellationToken)
|
||||||
|
{
|
||||||
|
if (response == null || response.Content == null)
|
||||||
|
{
|
||||||
|
return new ObjectResponseResult<T>(default(T), string.Empty);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ReadResponseAsString)
|
||||||
|
{
|
||||||
|
var responseText = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var typedBody = Newtonsoft.Json.JsonConvert.DeserializeObject<T>(responseText, JsonSerializerSettings);
|
||||||
|
return new ObjectResponseResult<T>(typedBody, responseText);
|
||||||
|
}
|
||||||
|
catch (Newtonsoft.Json.JsonException exception)
|
||||||
|
{
|
||||||
|
var message = "Could not deserialize the response body string as " + typeof(T).FullName + ".";
|
||||||
|
throw new ApiException(message, (int)response.StatusCode, responseText, headers, exception);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
using (var responseStream = await response.Content.ReadAsStreamAsync().ConfigureAwait(false))
|
||||||
|
using (var streamReader = new System.IO.StreamReader(responseStream))
|
||||||
|
using (var jsonTextReader = new Newtonsoft.Json.JsonTextReader(streamReader))
|
||||||
|
{
|
||||||
|
var serializer = Newtonsoft.Json.JsonSerializer.Create(JsonSerializerSettings);
|
||||||
|
var typedBody = serializer.Deserialize<T>(jsonTextReader);
|
||||||
|
return new ObjectResponseResult<T>(typedBody, string.Empty);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Newtonsoft.Json.JsonException exception)
|
||||||
|
{
|
||||||
|
var message = "Could not deserialize the response body stream as " + typeof(T).FullName + ".";
|
||||||
|
throw new ApiException(message, (int)response.StatusCode, string.Empty, headers, exception);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private string ConvertToString(object value, System.Globalization.CultureInfo cultureInfo)
|
||||||
|
{
|
||||||
|
if (value == null)
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value is System.Enum)
|
||||||
|
{
|
||||||
|
var name = System.Enum.GetName(value.GetType(), value);
|
||||||
|
if (name != null)
|
||||||
|
{
|
||||||
|
var field = System.Reflection.IntrospectionExtensions.GetTypeInfo(value.GetType()).GetDeclaredField(name);
|
||||||
|
if (field != null)
|
||||||
|
{
|
||||||
|
var attribute = System.Reflection.CustomAttributeExtensions.GetCustomAttribute(field, typeof(System.Runtime.Serialization.EnumMemberAttribute))
|
||||||
|
as System.Runtime.Serialization.EnumMemberAttribute;
|
||||||
|
if (attribute != null)
|
||||||
|
{
|
||||||
|
return attribute.Value != null ? attribute.Value : name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var converted = System.Convert.ToString(System.Convert.ChangeType(value, System.Enum.GetUnderlyingType(value.GetType()), cultureInfo));
|
||||||
|
return converted == null ? string.Empty : converted;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (value is bool)
|
||||||
|
{
|
||||||
|
return System.Convert.ToString((bool)value, cultureInfo).ToLowerInvariant();
|
||||||
|
}
|
||||||
|
else if (value is byte[])
|
||||||
|
{
|
||||||
|
return System.Convert.ToBase64String((byte[])value);
|
||||||
|
}
|
||||||
|
else if (value.GetType().IsArray)
|
||||||
|
{
|
||||||
|
var array = System.Linq.Enumerable.OfType<object>((System.Array)value);
|
||||||
|
return string.Join(",", System.Linq.Enumerable.Select(array, o => ConvertToString(o, cultureInfo)));
|
||||||
|
}
|
||||||
|
|
||||||
|
var result = System.Convert.ToString(value, cultureInfo);
|
||||||
|
return result == null ? "" : result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>API access token response</summary>
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.5.2.0 (Newtonsoft.Json v11.0.0.0)")]
|
||||||
|
public partial class TokenResponse
|
||||||
|
{
|
||||||
|
/// <summary>Authentication token</summary>
|
||||||
|
[Newtonsoft.Json.JsonProperty("access_token", Required = Newtonsoft.Json.Required.Always)]
|
||||||
|
[System.ComponentModel.DataAnnotations.Required(AllowEmptyStrings = true)]
|
||||||
|
public string Access_token { get; set; }
|
||||||
|
|
||||||
|
/// <summary>Authentication token type</summary>
|
||||||
|
[Newtonsoft.Json.JsonProperty("token_type", Required = Newtonsoft.Json.Required.Always)]
|
||||||
|
[System.ComponentModel.DataAnnotations.Required(AllowEmptyStrings = true)]
|
||||||
|
[Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.StringEnumConverter))]
|
||||||
|
public TokenResponseToken_type Token_type { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
private string _Expires_in;
|
||||||
|
/// <summary>Authentication token expiration time, in seconds</summary>
|
||||||
|
[Newtonsoft.Json.JsonProperty("expires_in", Required = Newtonsoft.Json.Required.Always)]
|
||||||
|
[System.ComponentModel.DataAnnotations.Required(AllowEmptyStrings = true)]
|
||||||
|
// public string Expires_in { get; set; }
|
||||||
|
|
||||||
|
public string Expires_in
|
||||||
|
{
|
||||||
|
get { return _Expires_in; }
|
||||||
|
set
|
||||||
|
{
|
||||||
|
_Expires_in = value;
|
||||||
|
Expires_on = DateTime.UtcNow.AddSeconds(Double.Parse(value) - 60);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>Authentication token expiration time in UTC</summary>
|
||||||
|
public DateTime Expires_on { get; set; }
|
||||||
|
|
||||||
|
/// <summary>Refresh token. This is only provided when the server is set to allow refresh tokens for web services and when the session timeout duration is not set to Unlimited.</summary>
|
||||||
|
[Newtonsoft.Json.JsonProperty("refresh_token", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
|
||||||
|
public string Refresh_token { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>API access token error response</summary>
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.5.2.0 (Newtonsoft.Json v11.0.0.0)")]
|
||||||
|
public partial class TokenErrorResponse
|
||||||
|
{
|
||||||
|
/// <summary>Authentication token</summary>
|
||||||
|
[Newtonsoft.Json.JsonProperty("message", Required = Newtonsoft.Json.Required.Always)]
|
||||||
|
[System.ComponentModel.DataAnnotations.Required(AllowEmptyStrings = true)]
|
||||||
|
public string Message { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>Authentication grant type. Use 'password' when authenticating, and 'refresh_token' when refreshing a token.</summary>
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.5.2.0 (Newtonsoft.Json v11.0.0.0)")]
|
||||||
|
public enum Grant_type
|
||||||
|
{
|
||||||
|
[System.Runtime.Serialization.EnumMember(Value = @"password")]
|
||||||
|
Password = 0,
|
||||||
|
|
||||||
|
[System.Runtime.Serialization.EnumMember(Value = @"refresh_token")]
|
||||||
|
Refresh_token = 1,
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "10.5.2.0 (Newtonsoft.Json v11.0.0.0)")]
|
||||||
|
public enum TokenResponseToken_type
|
||||||
|
{
|
||||||
|
[System.Runtime.Serialization.EnumMember(Value = @"bearer")]
|
||||||
|
Bearer = 0,
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NSwag", "13.14.8.0 (NJsonSchema v10.5.2.0 (Newtonsoft.Json v11.0.0.0))")]
|
||||||
|
public partial class ApiException : System.Exception
|
||||||
|
{
|
||||||
|
public int StatusCode { get; private set; }
|
||||||
|
|
||||||
|
public string Response { get; private set; }
|
||||||
|
|
||||||
|
public System.Collections.Generic.IReadOnlyDictionary<string, System.Collections.Generic.IEnumerable<string>> Headers { get; private set; }
|
||||||
|
|
||||||
|
public ApiException(string message, int statusCode, string response, System.Collections.Generic.IReadOnlyDictionary<string, System.Collections.Generic.IEnumerable<string>> headers, System.Exception innerException)
|
||||||
|
: base(message + "\n\nStatus: " + statusCode + "\nResponse: \n" + ((response == null) ? "(null)" : response.Substring(0, response.Length >= 512 ? 512 : response.Length)), innerException)
|
||||||
|
{
|
||||||
|
StatusCode = statusCode;
|
||||||
|
Response = response;
|
||||||
|
Headers = headers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string ToString()
|
||||||
|
{
|
||||||
|
return string.Format("HTTP Response: \n\n{0}\n\n{1}", Response, base.ToString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[System.CodeDom.Compiler.GeneratedCode("NSwag", "13.14.8.0 (NJsonSchema v10.5.2.0 (Newtonsoft.Json v11.0.0.0))")]
|
||||||
|
public partial class ApiException<TResult> : ApiException
|
||||||
|
{
|
||||||
|
public TResult Result { get; private set; }
|
||||||
|
|
||||||
|
public ApiException(string message, int statusCode, string response, System.Collections.Generic.IReadOnlyDictionary<string, System.Collections.Generic.IEnumerable<string>> headers, TResult result, System.Exception innerException)
|
||||||
|
: base(message, statusCode, response, headers, innerException)
|
||||||
|
{
|
||||||
|
Result = result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#pragma warning restore 1591
|
||||||
|
#pragma warning restore 1573
|
||||||
|
#pragma warning restore 472
|
||||||
|
#pragma warning restore 114
|
||||||
|
#pragma warning restore 108
|
||||||
|
#pragma warning restore 3016
|
||||||
237
ExternalConnectors/TSS/SecretServerInterface.cs
Normal file
237
ExternalConnectors/TSS/SecretServerInterface.cs
Normal file
@@ -0,0 +1,237 @@
|
|||||||
|
using Microsoft.Win32;
|
||||||
|
using SecretServerAuthentication.TSS;
|
||||||
|
using SecretServerRestClient.TSS;
|
||||||
|
|
||||||
|
namespace ExternalConnectors.TSS
|
||||||
|
{
|
||||||
|
public class SecretServerInterface
|
||||||
|
{
|
||||||
|
private static class SSConnectionData
|
||||||
|
{
|
||||||
|
public static string ssUsername = "";
|
||||||
|
public static string ssPassword = "";
|
||||||
|
public static string ssUrl = "";
|
||||||
|
public static string ssOTP = "";
|
||||||
|
public static bool ssSSO = false;
|
||||||
|
public static bool initdone = false;
|
||||||
|
|
||||||
|
//token
|
||||||
|
public static string ssTokenBearer = "";
|
||||||
|
public static DateTime ssTokenExpiresOn = DateTime.UtcNow;
|
||||||
|
public static string ssTokenRefresh = "";
|
||||||
|
|
||||||
|
public static void Init()
|
||||||
|
{
|
||||||
|
if (ssPassword != "" || initdone == true)
|
||||||
|
return;
|
||||||
|
|
||||||
|
RegistryKey key = Registry.CurrentUser.CreateSubKey(@"SOFTWARE\mRemoteSSInterface");
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// display gui and ask for data
|
||||||
|
SSConnectionForm f = new SSConnectionForm();
|
||||||
|
string? un = key.GetValue("Username") as string;
|
||||||
|
f.tbUsername.Text = un ?? "";
|
||||||
|
|
||||||
|
string? url = key.GetValue("URL") as string;
|
||||||
|
if (url == null || !url.Contains("://"))
|
||||||
|
url = "https://cred.domain.local/SecretServer";
|
||||||
|
f.tbSSURL.Text = url;
|
||||||
|
|
||||||
|
var b = key.GetValue("SSO");
|
||||||
|
if (b == null || (string)b != "True")
|
||||||
|
ssSSO = false;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ssSSO = true;
|
||||||
|
initdone = true;
|
||||||
|
}
|
||||||
|
f.cbUseSSO.Checked = ssSSO;
|
||||||
|
|
||||||
|
// show dialog
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
_ = f.ShowDialog();
|
||||||
|
|
||||||
|
if (f.DialogResult != DialogResult.OK)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// store values to memory
|
||||||
|
ssUsername = f.tbUsername.Text;
|
||||||
|
ssPassword = f.tbPassword.Text;
|
||||||
|
ssUrl = f.tbSSURL.Text;
|
||||||
|
ssSSO = f.cbUseSSO.Checked;
|
||||||
|
ssOTP = f.tbOTP.Text;
|
||||||
|
// check connection first
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (TestCredentials() == true)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
MessageBox.Show("Test Credentials failed - please check your credentials");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// write values to registry
|
||||||
|
key.SetValue("Username", ssUsername);
|
||||||
|
key.SetValue("URL", ssUrl);
|
||||||
|
key.SetValue("SSO", ssSSO);
|
||||||
|
}
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
key.Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static bool TestCredentials()
|
||||||
|
{
|
||||||
|
if (SSConnectionData.ssSSO)
|
||||||
|
{
|
||||||
|
// checking creds doesn't really make sense here, as we can't modify them anyway if something is wrong
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
if (!String.IsNullOrEmpty(GetToken()))
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void FetchSecret(int secretID, out string secretUsername, out string secretPassword, out string secretDomain)
|
||||||
|
{
|
||||||
|
string baseURL = SSConnectionData.ssUrl;
|
||||||
|
|
||||||
|
SecretModel secret;
|
||||||
|
if (SSConnectionData.ssSSO)
|
||||||
|
{
|
||||||
|
// REQUIRES IIS CONFIG! https://docs.thycotic.com/ss/11.0.0/api-scripting/webservice-iwa-powershell
|
||||||
|
var handler = new HttpClientHandler() { UseDefaultCredentials = true };
|
||||||
|
using (var httpClient = new HttpClient(handler))
|
||||||
|
{
|
||||||
|
// Call REST API:
|
||||||
|
var client = new SecretsServiceClient($"{baseURL}/winauthwebservices/api", httpClient);
|
||||||
|
secret = client.GetSecretAsync(false, true, secretID, null).Result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
using (var httpClient = new HttpClient())
|
||||||
|
{
|
||||||
|
|
||||||
|
var token = GetToken();
|
||||||
|
// Set credentials (token):
|
||||||
|
httpClient.DefaultRequestHeaders.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", token);
|
||||||
|
|
||||||
|
// Call REST API:
|
||||||
|
var client = new SecretsServiceClient($"{baseURL}/api", httpClient);
|
||||||
|
secret = client.GetSecretAsync(false, true, secretID, null).Result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// clear return variables
|
||||||
|
secretDomain = "";
|
||||||
|
secretUsername = "";
|
||||||
|
secretPassword = "";
|
||||||
|
|
||||||
|
// parse data and extract what we need
|
||||||
|
foreach (var item in secret.Items)
|
||||||
|
{
|
||||||
|
if (item.FieldName.ToLower().Equals("domain"))
|
||||||
|
secretDomain = item.ItemValue;
|
||||||
|
else if (item.FieldName.ToLower().Equals("username"))
|
||||||
|
secretUsername = item.ItemValue;
|
||||||
|
else if (item.FieldName.ToLower().Equals("password"))
|
||||||
|
secretPassword = item.ItemValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static string GetToken()
|
||||||
|
{
|
||||||
|
|
||||||
|
string authUsername = SSConnectionData.ssUsername;
|
||||||
|
string authPassword = SSConnectionData.ssPassword;
|
||||||
|
string baseURL = SSConnectionData.ssUrl;
|
||||||
|
string OTP = SSConnectionData.ssOTP;
|
||||||
|
string Bearer = SSConnectionData.ssTokenBearer;
|
||||||
|
string Refresh = SSConnectionData.ssTokenRefresh;
|
||||||
|
DateTime ExpiresOn = SSConnectionData.ssTokenExpiresOn;
|
||||||
|
|
||||||
|
|
||||||
|
//Check if current token is valid
|
||||||
|
if (!String.IsNullOrEmpty(Bearer))
|
||||||
|
{
|
||||||
|
if (ExpiresOn >= DateTime.UtcNow)
|
||||||
|
{
|
||||||
|
return Bearer;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//try using refresh token
|
||||||
|
using (var httpClient = new HttpClient())
|
||||||
|
{
|
||||||
|
var tokenClient = new OAuth2ServiceClient(baseURL, httpClient);
|
||||||
|
var token = tokenClient.AuthorizeAsync(Grant_type.Refresh_token, null, null, Refresh, null).Result;
|
||||||
|
var tokenResult = token.Access_token;
|
||||||
|
|
||||||
|
SSConnectionData.ssTokenBearer = tokenResult;
|
||||||
|
return tokenResult;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
using (var httpClient = new HttpClient())
|
||||||
|
{
|
||||||
|
// Authenticate:
|
||||||
|
var tokenClient = new OAuth2ServiceClient(baseURL, httpClient);
|
||||||
|
// call below will throw an exception if the creds are invalid
|
||||||
|
var token = tokenClient.AuthorizeAsync(Grant_type.Password, authUsername, authPassword, null, OTP).Result;
|
||||||
|
// here we can be sure the creds are ok - return success state
|
||||||
|
var tokenResult = token.Access_token;
|
||||||
|
|
||||||
|
SSConnectionData.ssTokenBearer = tokenResult;
|
||||||
|
SSConnectionData.ssTokenRefresh = token.Refresh_token;
|
||||||
|
SSConnectionData.ssTokenExpiresOn = token.Expires_on;
|
||||||
|
return tokenResult;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// input must be in form "SSAPI:xxxx" where xxx is the secret id to fetch
|
||||||
|
public static void FetchSecretFromServer(string input, out string username, out string password, out string domain)
|
||||||
|
{
|
||||||
|
// get secret id
|
||||||
|
if (!input.StartsWith("SSAPI:"))
|
||||||
|
throw new Exception("calling this function requires SSAPI: input");
|
||||||
|
int secretID = Int32.Parse(input.Substring(6));
|
||||||
|
|
||||||
|
// init connection credentials, display popup if necessary
|
||||||
|
SSConnectionData.Init();
|
||||||
|
|
||||||
|
// get the secret
|
||||||
|
FetchSecret(secretID, out username, out password, out domain);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
130342
ExternalConnectors/TSS/SecretServerRestClient.cs
Normal file
130342
ExternalConnectors/TSS/SecretServerRestClient.cs
Normal file
File diff suppressed because it is too large
Load Diff
BIN
ExternalConnectors/TSS/TSS.ico
Normal file
BIN
ExternalConnectors/TSS/TSS.ico
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 32 KiB |
63
Jenkinsfile
vendored
63
Jenkinsfile
vendored
@@ -1,63 +0,0 @@
|
|||||||
#!groovy
|
|
||||||
node('windows') {
|
|
||||||
def jobDir = pwd()
|
|
||||||
def solutionFilePath = "\"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
def msBuild = "C:\\Program Files (x86)\\Microsoft Visual Studio\\2017\\Community\\MSBuild\\15.0\\Bin\\msbuild.exe"
|
|
||||||
def nunitConsolePath = "${jobDir}\\packages\\NUnit.ConsoleRunner.3.7.0\\tools\\nunit3-console.exe"
|
|
||||||
def openCoverPath = "${jobDir}\\packages\\OpenCover.4.6.519\\tools\\OpenCover.Console.exe"
|
|
||||||
def reportGeneratorPath = "${jobDir}\\packages\\ReportGenerator.3.0.2\\tools\\ReportGenerator.exe"
|
|
||||||
def testResultFilePrefix = "TestResult"
|
|
||||||
def testResultFileNormal = "${testResultFilePrefix}_UnitTests_normal.xml"
|
|
||||||
def testResultFilePortable = "${testResultFilePrefix}_UnitTests_portable.xml"
|
|
||||||
def testResultFileAcceptance = "${testResultFilePrefix}_AcceptanceTests.xml"
|
|
||||||
def coverageReport = "code_coverage_report.xml"
|
|
||||||
def codeCoverageHtml = "CodeCoverageReport.html"
|
|
||||||
|
|
||||||
stage ('Checkout Branch') {
|
|
||||||
checkout scm
|
|
||||||
bat "del /Q \"${jobDir}\\${testResultFilePrefix}*.xml\""
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Restore NuGet Packages') {
|
|
||||||
def nugetPath = "C:\\nuget.exe"
|
|
||||||
bat "${nugetPath} restore ${solutionFilePath}"
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Build mRemoteNG (Normal)') {
|
|
||||||
bat "\"${msBuild}\" /nologo /p:Platform=x86 \"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Build mRemoteNG (Portable)') {
|
|
||||||
bat "\"${msBuild}\" /nologo /p:Configuration=\"Debug Portable\";Platform=x86 \"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Run Unit Tests (Normal, w/coverage)') {
|
|
||||||
try {
|
|
||||||
bat "\"${openCoverPath}\" -register:user -target:\"${nunitConsolePath}\" -targetargs:\"\"${jobDir}\\mRemoteNGTests\\bin\\debug\\mRemoteNGTests.dll\" --result=${testResultFileNormal} --x86\" -output:\"${coverageReport}\""
|
|
||||||
}
|
|
||||||
catch (ex) {
|
|
||||||
nunit testResultsPattern: "${testResultFilePrefix}*.xml"
|
|
||||||
throw ex
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Run Unit Tests (Portable)') {
|
|
||||||
try {
|
|
||||||
bat "\"${nunitConsolePath}\" \"${jobDir}\\mRemoteNGTests\\bin\\debug portable\\mRemoteNGTests.dll\" --result=${testResultFilePortable} --x86"
|
|
||||||
}
|
|
||||||
catch (ex) {
|
|
||||||
nunit testResultsPattern: "${testResultFilePrefix}*.xml"
|
|
||||||
throw ex
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Run Acceptance Tests') {
|
|
||||||
try {
|
|
||||||
bat "\"${nunitConsolePath}\" \"${jobDir}\\mRemoteNG.Specs\\bin\\debug\\mRemoteNG.Specs.dll\" --result=${testResultFileAcceptance} --x86"
|
|
||||||
}
|
|
||||||
catch (ex) {
|
|
||||||
nunit testResultsPattern: "${testResultFilePrefix}*.xml"
|
|
||||||
throw ex
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,71 +0,0 @@
|
|||||||
node('windows') {
|
|
||||||
def jobDir = pwd()
|
|
||||||
def solutionFilePath = "\"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
def msBuild = "C:\\Program Files (x86)\\Microsoft Visual Studio\\2017\\Community\\MSBuild\\15.0\\Bin\\msbuild.exe"
|
|
||||||
def nunitConsolePath = "${jobDir}\\packages\\NUnit.ConsoleRunner.3.10.0\\tools\\nunit3-console.exe"
|
|
||||||
def openCoverPath = "${jobDir}\\packages\\OpenCover.4.6.519\\tools\\OpenCover.Console.exe"
|
|
||||||
def testResultFilePrefix = "TestResult"
|
|
||||||
def testResultFileNormal = "${testResultFilePrefix}_UnitTests_normal.xml"
|
|
||||||
def testResultFilePortable = "${testResultFilePrefix}_UnitTests_portable.xml"
|
|
||||||
def coverageReport = "code_coverage_report.xml"
|
|
||||||
|
|
||||||
|
|
||||||
stage ('Clean output dir') {
|
|
||||||
bat script: "rmdir /S /Q \"${jobDir}\\Release\" 2>nul", returnStatus: true
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Checkout Branch') {
|
|
||||||
checkout([
|
|
||||||
$class: 'GitSCM',
|
|
||||||
branches: [[name: '*/${TargetBranch}']],
|
|
||||||
doGenerateSubmoduleConfigurations: false,
|
|
||||||
extensions: [],
|
|
||||||
submoduleCfg: [],
|
|
||||||
userRemoteConfigs: [[
|
|
||||||
credentialsId: '9c3fbff4-5b90-402f-a298-00e607fcec87',
|
|
||||||
url: 'https://github.com/mRemoteNG/mRemoteNG.git'
|
|
||||||
]]
|
|
||||||
])
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Restore NuGet Packages') {
|
|
||||||
def nugetPath = "C:\\nuget.exe"
|
|
||||||
bat "${nugetPath} restore ${solutionFilePath}"
|
|
||||||
}
|
|
||||||
|
|
||||||
withCredentials([file(credentialsId: '9b674d57-6792-48e3-984a-4d1bab2abb64', variable: 'CODE_SIGNING_CERT')]) {
|
|
||||||
withCredentials([usernamePassword(credentialsId: '05b7449b-05c0-490f-8661-236242526e62', passwordVariable: 'MRNG_CERT_PASSWORD', usernameVariable: 'NO_USERNAME')]) {
|
|
||||||
stage ('Build mRemoteNG (Normal - MSI)') {
|
|
||||||
bat "\"${msBuild}\" /nologo /t:Clean,Build /p:Configuration=\"Release Installer\" /p:Platform=x86 /p:CertPath=\"${env.CODE_SIGNING_CERT}\" /p:CertPassword=${env.MRNG_CERT_PASSWORD} \"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
archiveArtifacts artifacts: "Release\\*.msi", caseSensitive: false, onlyIfSuccessful: true, fingerprint: true
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Build mRemoteNG (Portable)') {
|
|
||||||
bat "\"${msBuild}\" /nologo /t:Clean,Build /p:Configuration=\"Release Portable\" /p:Platform=x86 /p:CertPath=\"${env.CODE_SIGNING_CERT}\" /p:CertPassword=${env.MRNG_CERT_PASSWORD} \"${jobDir}\\mRemoteV1.sln\""
|
|
||||||
archiveArtifacts artifacts: "Release\\*.zip", caseSensitive: false, onlyIfSuccessful: true, fingerprint: true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Run Unit Tests (Normal - MSI)') {
|
|
||||||
bat "\"${nunitConsolePath}\" \"${jobDir}\\mRemoteNGTests\\bin\\release\\mRemoteNGTests.dll\" --result=${testResultFileNormal} --x86"
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Run Unit Tests (Portable)') {
|
|
||||||
bat "\"${nunitConsolePath}\" \"${jobDir}\\mRemoteNGTests\\bin\\release portable\\mRemoteNGTests.dll\" --result=${testResultFilePortable} --x86"
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Generate UpdateCheck Files') {
|
|
||||||
bat "powershell -ExecutionPolicy Bypass -File \"${jobDir}\\Tools\\create_upg_chk_files.ps1\" -TagName \"${env.TagName}\" -UpdateChannel \"${env.UpdateChannel}\""
|
|
||||||
archiveArtifacts artifacts: "Release\\*.txt", caseSensitive: false, onlyIfSuccessful: true
|
|
||||||
}
|
|
||||||
|
|
||||||
stage ('Publish to GitHub') {
|
|
||||||
withCredentials([string(credentialsId: '5443a369-dbe8-42d3-b4e8-04d0b4e9039a', variable: 'GH_AUTH_TOKEN')]) {
|
|
||||||
def releaseFolder = "${jobDir}\\Release"
|
|
||||||
// because batch files suck at handling newline characters, we have to convert to base64 in groovy and back to text in powershell
|
|
||||||
def base64Description = env.ReleaseDescription.bytes.encodeBase64().toString()
|
|
||||||
bat "powershell -ExecutionPolicy Bypass -File \"${jobDir}\\Tools\\publish_to_github.ps1\" -Owner \"mRemoteNG\" -Repository \"mRemoteNG\" -ReleaseTitle \"${env.ReleaseTitle}\" -TagName \"${env.TagName}\" -TargetCommitish \"${env.TargetBranch}\" -Description \"${base64Description}\" -IsDraft ${env.IsDraft} -IsPrerelease ${env.IsPreRelease} -ReleaseFolderPath \"${releaseFolder}\" -AuthToken \"${env.GH_AUTH_TOKEN}\" -DescriptionIsBase64Encoded"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
**NOTICE: This project is currently stalled and we are transitioning to a new maintainer. Please see [this stickied issue](https://github.com/mRemoteNG/mRemoteNG/issues/1949) for more details. Development help would be greatly appreciated.**
|
**NOTICE: This project currently transited to a new maintainer. Development help would be greatly appreciated.**
|
||||||
|
|
||||||
<br/><br/>
|
<br/><br/>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<img width="500" src="https://raw.githubusercontent.com/mRemoteNG/mRemoteNG/develop/Tools/img/logo.png">
|
<img width="450" src="https://github.com/mRemoteNG/mRemoteNG/blob/mRemoteNGProjectFiles/Header_dark.png">
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p align="center">
|
<p align="center">
|
||||||
@@ -23,7 +23,9 @@
|
|||||||
<a href="https://gitter.im/mRemoteNG/PublicChat">
|
<a href="https://gitter.im/mRemoteNG/PublicChat">
|
||||||
<img alt="Gitter" src="https://img.shields.io/gitter/room/mRemoteNG/PublicChat?label=Join%20the%20Chat&logo=Gitter&style=flat-square">
|
<img alt="Gitter" src="https://img.shields.io/gitter/room/mRemoteNG/PublicChat?label=Join%20the%20Chat&logo=Gitter&style=flat-square">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://www.paypal.me/DavidSparer">
|
</p>
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://www.paypal.com/paypalme/mremoteng">
|
||||||
<img alt="PayPal" src="https://img.shields.io/badge/%24-PayPal-blue.svg?label=Donate&logo=PayPal&style=flat-square">
|
<img alt="PayPal" src="https://img.shields.io/badge/%24-PayPal-blue.svg?label=Donate&logo=PayPal&style=flat-square">
|
||||||
</a>
|
</a>
|
||||||
<a href="bitcoin:16fUnHUM3k7W9Fvpc6dug7TAdfeGEcLbSg">
|
<a href="bitcoin:16fUnHUM3k7W9Fvpc6dug7TAdfeGEcLbSg">
|
||||||
@@ -45,10 +47,11 @@
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
| Update Channel | Build Status | Downloads |
|
| Channel | Build Status | Downloads |
|
||||||
| ---------------|--------------|-----------|
|
| ---------------|--------------|-----------|
|
||||||
| Stable | [](https://ci.appveyor.com/project/mremoteng/mremoteng/branch/master) | [](https://github.com/mRemoteNG/mRemoteNG/releases/tag/v1.76.20) |
|
| Stable |  | [](https://github.com/mRemoteNG/mRemoteNG/releases/tag/v1.76.20) |
|
||||||
| Prerelease | [](https://ci.appveyor.com/project/mremoteng/mremoteng/branch/develop) | [](https://github.com/mRemoteNG/mRemoteNG/releases/tag/v1.77.1) |
|
| Preview |  | [](https://github.com/mRemoteNG/mRemoteNG/releases/tag/v1.77.1) |
|
||||||
|
| Nightly |  | [](https://github.com/mRemoteNG/mRemoteNG/releases/tag/2022.01.07-1.77.2-nb) |
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
@@ -69,26 +72,14 @@ For a detailed feature list and general usage support, refer to the [Documentati
|
|||||||
|
|
||||||
### Supported Operating Systems
|
### Supported Operating Systems
|
||||||
|
|
||||||
|
- [Windows 11](https://en.wikipedia.org/wiki/Windows_11)
|
||||||
- [Windows 10](https://en.wikipedia.org/wiki/Windows_10)
|
- [Windows 10](https://en.wikipedia.org/wiki/Windows_10)
|
||||||
- [Windows 8.1](https://en.wikipedia.org/wiki/Windows_8.1)
|
- [Windows 8.1](https://en.wikipedia.org/wiki/Windows_8.1)
|
||||||
|
- [Windows Server 2022](https://en.wikipedia.org/wiki/Windows_Server_2022)
|
||||||
- [Windows Server 2019](https://en.wikipedia.org/wiki/Windows_Server_2019)
|
- [Windows Server 2019](https://en.wikipedia.org/wiki/Windows_Server_2019)
|
||||||
- [Windows Server 2016](https://en.wikipedia.org/wiki/Windows_Server_2016)
|
- [Windows Server 2016](https://en.wikipedia.org/wiki/Windows_Server_2016)
|
||||||
- [Windows Server 2012 R2](https://en.wikipedia.org/wiki/Windows_Server_2012_R2)
|
- [Windows Server 2012 R2](https://en.wikipedia.org/wiki/Windows_Server_2012_R2)
|
||||||
|
|
||||||
### Packaging
|
|
||||||
|
|
||||||
Downloads are provided in three different packages.
|
|
||||||
|
|
||||||
#### Binary package
|
|
||||||
|
|
||||||
The binary package of mRemoteNG is a compiled version of mRemoteNG which comes in an MSI installer.
|
|
||||||
This is the most common way to install mRemoteNG and get up and running.
|
|
||||||
|
|
||||||
#### Portable package
|
|
||||||
|
|
||||||
The portable package contains a modified version of the executable which stores and loads all your settings from files in the application's directory.
|
|
||||||
This package can be used to run mRemoteNG from a USB stick and preserve your configuration wherever you go.
|
|
||||||
|
|
||||||
#### Source package
|
#### Source package
|
||||||
|
|
||||||
This contains the source code from which mRemoteNG is build.
|
This contains the source code from which mRemoteNG is build.
|
||||||
@@ -96,12 +87,10 @@ You will need to compile it yourself using Visual Studio.
|
|||||||
|
|
||||||
### Minimum Requirements
|
### Minimum Requirements
|
||||||
|
|
||||||
* [Microsoft Visual C++ Redistributable for Visual Studio 2015, 2017 and 2019](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads)
|
* [Microsoft Visual C++ Redistributable for Visual Studio 2015 - 2022](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads)
|
||||||
* [Microsoft .NET Framework 4.0](https://www.microsoft.com/en-us/download/details.aspx?id=17851)
|
* [Microsoft .NET 6.0](https://dotnet.microsoft.com/download/dotnet/6.0)
|
||||||
* Microsoft Terminal Service Client 6.0 or later
|
* Microsoft Terminal Service Client 6.0 or later
|
||||||
* Needed if you use RDP. mstscax.dll and/or msrdp.ocx be registered.
|
* Needed if you use RDP. mstscax.dll and/or msrdp.ocx be registered.
|
||||||
* [Citrix ICA Client](https://www.citrix.com/downloads/citrix-receiver.html)
|
|
||||||
* Needed if you use ICA. wfica.ocx must be registered
|
|
||||||
|
|
||||||
### Download
|
### Download
|
||||||
|
|
||||||
@@ -113,56 +102,36 @@ mRemoteNG is available as a redistributable MSI package or as a portable ZIP pac
|
|||||||
|
|
||||||
The MSI package of mRemoteNG can be installed using the command line:
|
The MSI package of mRemoteNG can be installed using the command line:
|
||||||
|
|
||||||
`msiexec /i C:\Path\To\mRemoteNG-Installer.exe [INSTALLDIR=value] [IGNOREPREREQUISITES=value]`
|
`msiexec /i [/qn] C:\Path\To\mRemoteNG-Installer.exe [INSTALLDIR=value] [IGNOREPREREQUISITES=value] [/lv* <log path>]`
|
||||||
|
|
||||||
| Property | Value | Description |
|
| Argument/Property | Value | Description |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| INSTALLDIR | `folder path` | This allows you to set the installation directory from the command line. For paths that contain spaces, enclose the path in double quotes (""). This overrides any value found in the registry. |
|
| /qn | `Silent Installation` | Will run the installer silently in the background. |
|
||||||
|
| /lv* | `Silent Installation` | Will write a logfile to the specified location. (For paths that contain spaces, enclose the path in double quotes) |
|
||||||
|
| INSTALLDIR | `folder path` | Allows you to set the installation directory from the command line. (For paths that contain spaces, enclose the path in double quotes) |
|
||||||
| IGNOREPREREQUISITES | `0` or `1` | When set to `1`, the installer will not be halted if any prerequisite check is not met. You must still run the installer as administrator. |
|
| IGNOREPREREQUISITES | `0` or `1` | When set to `1`, the installer will not be halted if any prerequisite check is not met. You must still run the installer as administrator. |
|
||||||
|
|
||||||
#### Examples
|
## Manual Uninstall
|
||||||
|
|
||||||
**Install to a custom folder**
|
|
||||||
|
|
||||||
`msiexec /i C:\Path\To\mRemoteNG-Installer.msi INSTALLDIR="D:\Work Apps\mRemoteNG"`
|
|
||||||
|
|
||||||
**Ignore prerequisites during a normal install**
|
|
||||||
|
|
||||||
`msiexec /i C:\Path\To\mRemoteNG-Installer.msi IGNOREPREREQUISITES=1`
|
|
||||||
|
|
||||||
**Ignore prerequisites during a silent install**
|
|
||||||
|
|
||||||
`msiexec /i C:\Path\To\mRemoteNG-Installer.msi /qn IGNOREPREREQUISITES=1`
|
|
||||||
|
|
||||||
### Troubleshooting installation
|
|
||||||
|
|
||||||
Turn on verbose logging by using the `/lv* <log path>` argument at the command line.
|
|
||||||
|
|
||||||
`msiexec /i C:\Path\To\mRemoteNG-Installer.msi /l*v C:\mremoteng_install.log`
|
|
||||||
|
|
||||||
## Uninstall
|
|
||||||
|
|
||||||
### Standard Uninstall
|
|
||||||
|
|
||||||
mRemoteNG basic binary package can be uninstalled with Windows Control Panel. If for some reason it does not work please
|
|
||||||
follow information provided below for Manual Uninstall.
|
|
||||||
|
|
||||||
### Manual Uninstall
|
|
||||||
|
|
||||||
_If you are using the Portable version, simply deleting the folder that contains mRemoteNG should be sufficient. These uninstall instructions are only necessary for the normal binary .MSI installed version of mRemoteNG_
|
_If you are using the Portable version, simply deleting the folder that contains mRemoteNG should be sufficient. These uninstall instructions are only necessary for the normal binary .MSI installed version of mRemoteNG_
|
||||||
|
|
||||||
* Delete the folder where mRemoteNG was installed. By default, this is:
|
* Delete the folder where mRemoteNG was installed. By default, this is:
|
||||||
`%PROGRAMFILES%\mRemoteNG`
|
`%PROGRAMFILES%\mRemoteNG` (for versions before 1.77 on a x64 Windows its `%programfiles(x86)%\mRemoteNG`)
|
||||||
|
|
||||||
* Delete the mRemoteNG install entry from one of the following locations. Search for "mRemoteNG" in the DisplayName field:
|
* Delete the mRemoteNG install entry from the following location. You may search for "mRemoteNG" in the DisplayName field:
|
||||||
* x86: ``HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\``
|
* x86 Windows or mRemoteNG starting with v1.77: `HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\`
|
||||||
* x64: ``HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\``
|
* x64 Windows and mRemoteNG before 1.77: `HKLM\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\`
|
||||||
|
* Remove the following registry key: `HKLM\SOFTWARE\mRemoteNG` (on x64 Windows with mRemoteNG before 1.77 it's `HKLM\SOFTWARE\WOW6432Node\mRemoteNG`)
|
||||||
|
|
||||||
* (Optional) If you would also like to delete user data remove `%LOCALAPPDATA%\mRemoteNG`
|
* (Optional) If you would also like to delete user data remove `%LOCALAPPDATA%\mRemoteNG`
|
||||||
|
* (Optional) If you would also like to remove the connection configuration, delete `%APPDATA%\mRemoteNG`
|
||||||
|
|
||||||
|
* (Optional) If no other software uses it, the "Microsoft Windows Desktop Runtime" may be uninstalled too.
|
||||||
|
|
||||||
## Featured Projects
|
## Featured Projects
|
||||||
|
|
||||||
* [PSmRemoteNG](https://github.com/realslacker/PSmRemoteNG) A module to create mRemoteNG connection files from PowerShell.
|
* [PSmRemoteNG](https://github.com/realslacker/PSmRemoteNG) A module to create mRemoteNG connection files from PowerShell.
|
||||||
|
* [mRemoteNGOpenVPN](https://github.com/T3los/mRemoteNGOpenVPN) A script that can be embedded as an external tool to control OpenVPN.
|
||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
|
|
||||||
@@ -176,5 +145,5 @@ Check out the [Wiki page](https://github.com/mRemoteNG/mRemoteNG/wiki) on how to
|
|||||||
|
|
||||||
</br>
|
</br>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<img alt="Developed with ReSharper" src="https://raw.githubusercontent.com/mRemoteNG/mRemoteNG/develop/Tools/img/icon_ReSharper.png">
|
<img alt="Developed with ReSharper" src="https://github.com/mRemoteNG/mRemoteNG/blob/mRemoteNGProjectFiles/icon_ReSharper.png">
|
||||||
</p>
|
</p>
|
||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -1,31 +0,0 @@
|
|||||||
7-Zip Extra
|
|
||||||
~~~~~~~~~~~
|
|
||||||
License for use and distribution
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
Copyright (C) 1999-2019 Igor Pavlov.
|
|
||||||
|
|
||||||
7-Zip Extra files are under the GNU LGPL license.
|
|
||||||
|
|
||||||
|
|
||||||
Notes:
|
|
||||||
You can use 7-Zip Extra on any computer, including a computer in a commercial
|
|
||||||
organization. You don't need to register or pay for 7-Zip.
|
|
||||||
|
|
||||||
|
|
||||||
GNU LGPL information
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Lesser General Public
|
|
||||||
License as published by the Free Software Foundation; either
|
|
||||||
version 2.1 of the License, or (at your option) any later version.
|
|
||||||
|
|
||||||
This library is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Lesser General Public License for more details.
|
|
||||||
|
|
||||||
You can receive a copy of the GNU Lesser General Public License from
|
|
||||||
http://www.gnu.org/
|
|
||||||
|
|
||||||
@@ -1,111 +0,0 @@
|
|||||||
7-Zip Extra history
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
This file contains only information about changes related to that package exclusively.
|
|
||||||
The full history of changes is listed in history.txt in main 7-Zip program.
|
|
||||||
|
|
||||||
|
|
||||||
19.00 2019-02-21
|
|
||||||
-------------------------
|
|
||||||
- Encryption strength for 7z archives was increased:
|
|
||||||
the size of random initialization vector was increased from 64-bit to 128-bit,
|
|
||||||
and the pseudo-random number generator was improved.
|
|
||||||
- Some bugs were fixed.
|
|
||||||
|
|
||||||
|
|
||||||
18.06 2018-12-30
|
|
||||||
-------------------------
|
|
||||||
- The speed for LZMA/LZMA2 compressing was increased by 3-10%,
|
|
||||||
and there are minor changes in compression ratio.
|
|
||||||
- Some bugs were fixed.
|
|
||||||
|
|
||||||
|
|
||||||
18.05 2018-04-30
|
|
||||||
-------------------------
|
|
||||||
- The speed for LZMA/LZMA2 compressing was increased
|
|
||||||
by 8% for fastest/fast compression levels and
|
|
||||||
by 3% for normal/maximum compression levels.
|
|
||||||
|
|
||||||
|
|
||||||
18.03 beta 2018-03-04
|
|
||||||
-------------------------
|
|
||||||
- The speed for single-thread LZMA/LZMA2 decoding
|
|
||||||
was increased by 30% in x64 version and by 3% in x86 version.
|
|
||||||
- 7-Zip now can use multi-threading for 7z/LZMA2 decoding,
|
|
||||||
if there are multiple independent data chunks in LZMA2 stream.
|
|
||||||
|
|
||||||
|
|
||||||
9.35 beta 2014-12-07
|
|
||||||
------------------------------
|
|
||||||
- SFX modules were moved to LZMA SDK package.
|
|
||||||
|
|
||||||
|
|
||||||
9.34 alpha 2014-06-22
|
|
||||||
------------------------------
|
|
||||||
- Minimum supported system now is Windows 2000 for EXE and DLL files.
|
|
||||||
- all EXE and DLL files use msvcrt.dll.
|
|
||||||
- 7zr.exe now support AES encryption.
|
|
||||||
|
|
||||||
|
|
||||||
9.18 2010-11-02
|
|
||||||
------------------------------
|
|
||||||
- New small SFX module for installers.
|
|
||||||
|
|
||||||
|
|
||||||
9.17 2010-10-04
|
|
||||||
------------------------------
|
|
||||||
- New 7-Zip plugin for FAR Manager x64.
|
|
||||||
|
|
||||||
|
|
||||||
9.10 2009-12-30
|
|
||||||
------------------------------
|
|
||||||
- 7-Zip for installers now supports LZMA2.
|
|
||||||
|
|
||||||
|
|
||||||
9.09 2009-12-12
|
|
||||||
------------------------------
|
|
||||||
- LZMA2 compression method support.
|
|
||||||
- Some bugs were fixed.
|
|
||||||
|
|
||||||
|
|
||||||
4.65 2009-02-03
|
|
||||||
------------------------------
|
|
||||||
- Some bugs were fixed.
|
|
||||||
|
|
||||||
|
|
||||||
4.38 beta 2006-04-13
|
|
||||||
------------------------------
|
|
||||||
- SFX for installers now supports new properties in config file:
|
|
||||||
Progress, Directory, ExecuteFile, ExecuteParameters.
|
|
||||||
|
|
||||||
|
|
||||||
4.34 beta 2006-02-27
|
|
||||||
------------------------------
|
|
||||||
- ISetProperties::SetProperties:
|
|
||||||
it's possible to specify desirable number of CPU threads:
|
|
||||||
PROPVARIANT: name=L"mt", vt = VT_UI4, ulVal = NumberOfThreads
|
|
||||||
If "mt" is not defined, 7za.dll will check number of processors in system to set
|
|
||||||
number of desirable threads.
|
|
||||||
Now 7za.dll can use:
|
|
||||||
2 threads for LZMA compressing
|
|
||||||
N threads for BZip2 compressing
|
|
||||||
4 threads for BZip2 decompressing
|
|
||||||
Other codecs use only one thread.
|
|
||||||
Note: 7za.dll can use additional "small" threads with low CPU load.
|
|
||||||
- It's possible to call ISetProperties::SetProperties to specify "mt" property for decoder.
|
|
||||||
|
|
||||||
|
|
||||||
4.33 beta 2006-02-05
|
|
||||||
------------------------------
|
|
||||||
- Compressing speed and Memory requirements were increased.
|
|
||||||
Default dictionary size was increased: Fastest: 64 KB, Fast: 1 MB,
|
|
||||||
Normal: 4 MB, Max: 16 MB, Ultra: 64 MB.
|
|
||||||
- 7z/LZMA now can use only these match finders: HC4, BT2, BT3, BT4
|
|
||||||
|
|
||||||
|
|
||||||
4.27 2005-09-21
|
|
||||||
------------------------------
|
|
||||||
- Some GUIDs/interfaces were changed.
|
|
||||||
IStream.h:
|
|
||||||
ISequentialInStream::Read now works as old ReadPart
|
|
||||||
ISequentialOutStream::Write now works as old WritePart
|
|
||||||
@@ -1,124 +0,0 @@
|
|||||||
7-Zip Extra 19.00
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
7-Zip Extra is package of extra modules of 7-Zip.
|
|
||||||
|
|
||||||
7-Zip Copyright (C) 1999-2019 Igor Pavlov.
|
|
||||||
|
|
||||||
7-Zip is free software. Read License.txt for more information about license.
|
|
||||||
|
|
||||||
Source code of binaries can be found at:
|
|
||||||
http://www.7-zip.org/
|
|
||||||
|
|
||||||
This package contains the following files:
|
|
||||||
|
|
||||||
7za.exe - standalone console version of 7-Zip with reduced formats support.
|
|
||||||
7za.dll - library for working with 7z archives
|
|
||||||
7zxa.dll - library for extracting from 7z archives
|
|
||||||
License.txt - license information
|
|
||||||
readme.txt - this file
|
|
||||||
|
|
||||||
Far\ - plugin for Far Manager
|
|
||||||
x64\ - binaries for x64
|
|
||||||
|
|
||||||
|
|
||||||
All 32-bit binaries can work in:
|
|
||||||
Windows 2000 / 2003 / 2008 / XP / Vista / 7 / 8 / 10
|
|
||||||
and in any Windows x64 version with WoW64 support.
|
|
||||||
All x64 binaries can work in any Windows x64 version.
|
|
||||||
|
|
||||||
All binaries use msvcrt.dll.
|
|
||||||
|
|
||||||
7za.exe
|
|
||||||
-------
|
|
||||||
|
|
||||||
7za.exe - is a standalone console version of 7-Zip with reduced formats support.
|
|
||||||
|
|
||||||
Extra: 7za.exe : support for only some formats of 7-Zip.
|
|
||||||
7-Zip: 7z.exe with 7z.dll : support for all formats of 7-Zip.
|
|
||||||
|
|
||||||
7za.exe and 7z.exe from 7-Zip have same command line interface.
|
|
||||||
7za.exe doesn't use external DLL files.
|
|
||||||
|
|
||||||
You can read Help File (7-zip.chm) from 7-Zip package for description
|
|
||||||
of all commands and switches for 7za.exe and 7z.exe.
|
|
||||||
|
|
||||||
7za.exe features:
|
|
||||||
|
|
||||||
- High compression ratio in 7z format
|
|
||||||
- Supported formats:
|
|
||||||
- Packing / unpacking: 7z, xz, ZIP, GZIP, BZIP2 and TAR
|
|
||||||
- Unpacking only: Z, lzma, CAB.
|
|
||||||
- Highest compression ratio for ZIP and GZIP formats.
|
|
||||||
- Fast compression and decompression
|
|
||||||
- Strong AES-256 encryption in 7z and ZIP formats.
|
|
||||||
|
|
||||||
Note: LZMA SDK contains 7zr.exe - more reduced version of 7za.exe.
|
|
||||||
But you can use 7zr.exe as "public domain" code.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DLL files
|
|
||||||
---------
|
|
||||||
|
|
||||||
7za.dll and 7zxa.dll are reduced versions of 7z.dll from 7-Zip.
|
|
||||||
7za.dll and 7zxa.dll support only 7z format.
|
|
||||||
Note: 7z.dll is main DLL file that works with all archive types in 7-Zip.
|
|
||||||
|
|
||||||
7za.dll and 7zxa.dll support the following decoding methods:
|
|
||||||
- LZMA, LZMA2, PPMD, BCJ, BCJ2, COPY, 7zAES, BZip2, Deflate.
|
|
||||||
|
|
||||||
7za.dll also supports 7z encoding with the following encoding methods:
|
|
||||||
- LZMA, LZMA2, PPMD, BCJ, BCJ2, COPY, 7zAES.
|
|
||||||
|
|
||||||
7za.dll and 7zxa.dll work via COM interfaces.
|
|
||||||
But these DLLs don't use standard COM interfaces for objects creating.
|
|
||||||
|
|
||||||
Look also example code that calls DLL functions (in source code of 7-Zip):
|
|
||||||
|
|
||||||
7zip\UI\Client7z
|
|
||||||
|
|
||||||
Another example of binary that uses these interface is 7-Zip itself.
|
|
||||||
The following binaries from 7-Zip use 7z.dll:
|
|
||||||
- 7z.exe (console version)
|
|
||||||
- 7zG.exe (GUI version)
|
|
||||||
- 7zFM.exe (7-Zip File Manager)
|
|
||||||
|
|
||||||
Note: The source code of LZMA SDK also contains the code for similar DLLs
|
|
||||||
(DLLs without BZip2, Deflate support). And these files from LZMA SDK can be
|
|
||||||
used as "public domain" code. If you use LZMA SDK files, you don't need to
|
|
||||||
follow GNU LGPL rules, if you want to change the code.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
License FAQ
|
|
||||||
-----------
|
|
||||||
|
|
||||||
Can I use the EXE or DLL files from 7-Zip in a commercial application?
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
Yes, but you are required to specify in documentation for your application:
|
|
||||||
(1) that you used parts of the 7-Zip program,
|
|
||||||
(2) that 7-Zip is licensed under the GNU LGPL license and
|
|
||||||
(3) you must give a link to www.7-zip.org, where the source code can be found.
|
|
||||||
|
|
||||||
|
|
||||||
Can I use the source code of 7-Zip in a commercial application?
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
Since 7-Zip is licensed under the GNU LGPL you must follow the rules of that license.
|
|
||||||
In brief, it means that any LGPL'ed code must remain licensed under the LGPL.
|
|
||||||
For instance, you can change the code from 7-Zip or write a wrapper for some
|
|
||||||
code from 7-Zip and compile it into a DLL; but, the source code of that DLL
|
|
||||||
(including your modifications / additions / wrapper) must be licensed under
|
|
||||||
the LGPL or GPL.
|
|
||||||
Any other code in your application can be licensed as you wish. This scheme allows
|
|
||||||
users and developers to change LGPL'ed code and recompile that DLL. That is the
|
|
||||||
idea of free software. Read more here: http://www.gnu.org/.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Note: You can look also LZMA SDK, which is available under a more liberal license.
|
|
||||||
|
|
||||||
|
|
||||||
---
|
|
||||||
End of document
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
Write-Output "Copying PUTTYNG to correct directory"
|
|
||||||
Copy-Item -Path (Join-Path -Path $SolutionDir -ChildPath "mRemoteNG\Resources\PuTTYNG.exe") -Destination $TargetDir -Force
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
$SourcePath,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
$DestinationDir
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Host $SourcePath
|
|
||||||
Write-Host $DestinationDir
|
|
||||||
|
|
||||||
if (!(Test-Path -Path $DestinationDir))
|
|
||||||
{
|
|
||||||
New-Item -Path $DestinationDir -ItemType "directory"
|
|
||||||
}
|
|
||||||
|
|
||||||
$sourceFiles = Get-ChildItem -Path $SourcePath -Recurse | ?{$_.Extension -match "exe|msi"}
|
|
||||||
foreach ($item in $sourceFiles)
|
|
||||||
{
|
|
||||||
Copy-Item -Path $item.FullName -Destination $DestinationDir -Force
|
|
||||||
}
|
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
Write-Output "Copying THEMES folder to output"
|
|
||||||
|
|
||||||
$sourceFiles = [io.path]::combine($SolutionDir , 'mRemoteNG\Resources\Themes' )
|
|
||||||
$DestinationDir = [io.path]::combine($TargetDir , 'Themes')
|
|
||||||
|
|
||||||
robocopy $sourceFiles $DestinationDir *.vstheme /s
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
Write-Output "Copying TILES folder to output"
|
|
||||||
|
|
||||||
$sourceFiles = [io.path]::combine($SolutionDir , 'mRemoteNG\Resources\Tiles' )
|
|
||||||
robocopy $sourceFiles $TargetDir *.*
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 3.1 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 28 KiB |
@@ -25,9 +25,9 @@ param (
|
|||||||
$ExcludeFromSigning
|
$ExcludeFromSigning
|
||||||
)
|
)
|
||||||
|
|
||||||
Write-Output "+=================================================================+"
|
Write-Output "+===========================================================================================+"
|
||||||
Write-Output "| Beginning mRemoteNG Installer Post Build |"
|
Write-Output "| Beginning mRemoteNG Installer Post Build |"
|
||||||
Write-Output "+=================================================================+"
|
Write-Output "+===========================================================================================+"
|
||||||
Format-Table -AutoSize -Wrap -InputObject @{
|
Format-Table -AutoSize -Wrap -InputObject @{
|
||||||
"SolutionDir" = $SolutionDir
|
"SolutionDir" = $SolutionDir
|
||||||
"TargetDir" = $TargetDir
|
"TargetDir" = $TargetDir
|
||||||
@@ -40,5 +40,4 @@ Format-Table -AutoSize -Wrap -InputObject @{
|
|||||||
|
|
||||||
& "$PSScriptRoot\sign_binaries.ps1" -TargetDir $TargetDir -CertificatePath $CertificatePath -CertificatePassword $CertificatePassword -ConfigurationName $ConfigurationName -Exclude $ExcludeFromSigning -SolutionDir $SolutionDir
|
& "$PSScriptRoot\sign_binaries.ps1" -TargetDir $TargetDir -CertificatePath $CertificatePath -CertificatePassword $CertificatePassword -ConfigurationName $ConfigurationName -Exclude $ExcludeFromSigning -SolutionDir $SolutionDir
|
||||||
& "$PSScriptRoot\verify_binary_signatures.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName -CertificatePath $CertificatePath -SolutionDir $SolutionDir
|
& "$PSScriptRoot\verify_binary_signatures.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName -CertificatePath $CertificatePath -SolutionDir $SolutionDir
|
||||||
& "$PSScriptRoot\rename_installer_with_version.ps1" -SolutionDir $SolutionDir
|
& "$PSScriptRoot\rename_and_copy_installer.ps1" -SolutionDir $SolutionDir
|
||||||
& "$PSScriptRoot\copy_release_installer.ps1" -SourcePath $TargetDir -DestinationDir (Join-Path -Path $SolutionDir -ChildPath "Release")
|
|
||||||
|
|||||||
@@ -25,9 +25,9 @@ param (
|
|||||||
$ExcludeFromSigning
|
$ExcludeFromSigning
|
||||||
)
|
)
|
||||||
|
|
||||||
Write-Output "+=================================================================+"
|
Write-Output "+===========================================================================================+"
|
||||||
Write-Output "| Beginning mRemoteNG Post Build |"
|
Write-Output "| Beginning mRemoteNG Post Build |"
|
||||||
Write-Output "+=================================================================+"
|
Write-Output "+===========================================================================================+"
|
||||||
Format-Table -AutoSize -Wrap -InputObject @{
|
Format-Table -AutoSize -Wrap -InputObject @{
|
||||||
"SolutionDir" = $SolutionDir
|
"SolutionDir" = $SolutionDir
|
||||||
"TargetDir" = $TargetDir
|
"TargetDir" = $TargetDir
|
||||||
@@ -37,16 +37,25 @@ Format-Table -AutoSize -Wrap -InputObject @{
|
|||||||
"ExcludeFromSigning" = $ExcludeFromSigning
|
"ExcludeFromSigning" = $ExcludeFromSigning
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Move dlls resurses into folder
|
||||||
|
#Remove-Item -Path "$TargetDir\libs" -Recurse -ErrorAction Ignore
|
||||||
|
#New-Item -ItemType "directory" -Force -Path $TargetDir -Name "libs"
|
||||||
|
#Move-Item -Path "$TargetDir\*.dll" -Destination "$TargetDir\libs" -force
|
||||||
|
|
||||||
|
|
||||||
& "$PSScriptRoot\copy_puttyng.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir
|
###
|
||||||
& "$PSScriptRoot\copy_themes.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir
|
|
||||||
& "$PSScriptRoot\copy_tiles.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir
|
# Move lang resurses into folder
|
||||||
& "$PSScriptRoot\sphinx_docs.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir
|
#Remove-Item -Path "$TargetDir\languages" -Recurse -ErrorAction Ignore
|
||||||
|
#New-Item -ItemType "directory" -Force -Path $TargetDir -Name "languages"
|
||||||
|
#"cs-CZ,de,el,en-US,es-AR,es,fr,hu,it,lt,ja-JP,ko-KR,nb-NO,nl,pt,pt-BR,pl,ru,uk,tr-TR,zh-CN,zh-TW,fi-FI".Split(",") | ForEach {
|
||||||
|
# Move-Item -Path "$TargetDir\$_" -Destination "$TargetDir\languages" -force
|
||||||
|
# }
|
||||||
|
###
|
||||||
|
|
||||||
& "$PSScriptRoot\set_LargeAddressAware.ps1" -TargetDir $TargetDir -TargetFileName $TargetFileName
|
& "$PSScriptRoot\set_LargeAddressAware.ps1" -TargetDir $TargetDir -TargetFileName $TargetFileName
|
||||||
& "$PSScriptRoot\verify_LargeAddressAware.ps1" -TargetDir $TargetDir -TargetFileName $TargetFileName
|
& "$PSScriptRoot\verify_LargeAddressAware.ps1" -TargetDir $TargetDir -TargetFileName $TargetFileName
|
||||||
& "$PSScriptRoot\tidy_files_for_release.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName
|
& "$PSScriptRoot\tidy_files_for_release.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName
|
||||||
& "$PSScriptRoot\sign_binaries.ps1" -TargetDir $TargetDir -CertificatePath $CertificatePath -CertificatePassword $CertificatePassword -ConfigurationName $ConfigurationName -Exclude $ExcludeFromSigning -SolutionDir $SolutionDir
|
& "$PSScriptRoot\sign_binaries.ps1" -TargetDir $TargetDir -CertificatePath $CertificatePath -CertificatePassword $CertificatePassword -ConfigurationName $ConfigurationName -Exclude $ExcludeFromSigning -SolutionDir $SolutionDir
|
||||||
& "$PSScriptRoot\verify_binary_signatures.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName -CertificatePath $CertificatePath -SolutionDir $SolutionDir
|
& "$PSScriptRoot\verify_binary_signatures.ps1" -TargetDir $TargetDir -ConfigurationName $ConfigurationName -CertificatePath $CertificatePath -SolutionDir $SolutionDir
|
||||||
& "$PSScriptRoot\zip_symbols.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir -ConfigurationName $ConfigurationName
|
& "$PSScriptRoot\zip_files.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir -ConfigurationName $ConfigurationName
|
||||||
& "$PSScriptRoot\zip_portable_files.ps1" -SolutionDir $SolutionDir -TargetDir $TargetDir -ConfigurationName $ConfigurationName
|
|
||||||
|
|||||||
13
Tools/rename_and_copy_installer.ps1
Normal file
13
Tools/rename_and_copy_installer.ps1
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
param (
|
||||||
|
[string]
|
||||||
|
$SolutionDir
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
$targetVersionedFile = "$SolutionDir\mRemoteNG\bin\x64\Release\mRemoteNG.exe"
|
||||||
|
$version = &"$SolutionDir\Tools\exes\sigcheck.exe" /accepteula -q -n $targetVersionedFile
|
||||||
|
$src = $SolutionDir + "mRemoteNGInstaller\Installer\bin\Release\en-US\mRemoteNG-Installer.msi"
|
||||||
|
$dst = $SolutionDir + "mRemoteNG\bin\x64\Release\mRemoteNG-Installer-" + $version + ".msi"
|
||||||
|
|
||||||
|
# Copy file
|
||||||
|
Copy-Item $src -Destination $dst -Force
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
$SolutionDir
|
|
||||||
)
|
|
||||||
|
|
||||||
$renameTarget = $SolutionDir + "InstallerProjects\Installer\bin\Release\en-US\mRemoteNG-Installer.msi"
|
|
||||||
|
|
||||||
Write-Host $SolutionDir
|
|
||||||
Write-Host $renameTarget
|
|
||||||
|
|
||||||
$targetVersionedFile = "$SolutionDir\mRemoteNG\bin\Release\mRemoteNG.exe"
|
|
||||||
$version = &"$SolutionDir\Tools\exes\sigcheck.exe" /accepteula -q -n $targetVersionedFile
|
|
||||||
|
|
||||||
|
|
||||||
$renameTargetFileObject = Get-Item -Path $renameTarget -ErrorAction SilentlyContinue
|
|
||||||
if ($renameTargetFileObject)
|
|
||||||
{
|
|
||||||
# Build the new file name
|
|
||||||
$oldFileName = $renameTargetFileObject.Name
|
|
||||||
$newFileName = $oldFileName -replace "$("\"+$renameTargetFileObject.Extension)",$("-"+$version+$renameTargetFileObject.Extension)
|
|
||||||
Write-Host $oldFileName
|
|
||||||
Write-Host $newFileName
|
|
||||||
|
|
||||||
# Delete any items that already exist with the new name (effectively an overwrite)
|
|
||||||
Remove-Item -Path "$($renameTargetFileObject.Directory.FullName)\$newFileName" -ErrorAction SilentlyContinue
|
|
||||||
|
|
||||||
# Rename file
|
|
||||||
Rename-Item -Path $renameTarget -NewName $newFileName -ErrorAction SilentlyContinue
|
|
||||||
}
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
|
|
||||||
Write-Output "Building HTML-Documentation with Sphinx"
|
|
||||||
|
|
||||||
$path_HelpFilesDir = Join-Path -Path $TargetDir -ChildPath "Help"
|
|
||||||
$path_SphinxSourceDir = Join-Path -Path $SolutionDir -ChildPath "mRemoteNG\Documentation"
|
|
||||||
|
|
||||||
# Remove stale Help files, if they exist
|
|
||||||
if (Test-Path -Path $path_HelpFilesDir) {
|
|
||||||
Remove-Item -Path $path_HelpFilesDir -Recurse -Force
|
|
||||||
}
|
|
||||||
|
|
||||||
# Build docs
|
|
||||||
sphinx-build $path_SphinxSourceDir $path_HelpFilesDir
|
|
||||||
|
|
||||||
# Place dummy html file if build failed
|
|
||||||
if (-Not (Test-Path $path_HelpFilesDir\index.html -PathType Leaf)) {
|
|
||||||
New-Item -Path $path_HelpFilesDir -ItemType "directory"
|
|
||||||
New-Item $path_HelpFilesDir\index.html
|
|
||||||
Set-Content $path_HelpFilesDir\index.html 'Welcome to mRemoteNG!'
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
@@ -7,15 +7,15 @@ param (
|
|||||||
[Parameter(Mandatory=$true)]
|
[Parameter(Mandatory=$true)]
|
||||||
$ConfigurationName
|
$ConfigurationName
|
||||||
)
|
)
|
||||||
|
Write-Output ""
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
||||||
|
|
||||||
# Remove unnecessary files from Release versions
|
# Remove unnecessary files from Release versions
|
||||||
if ($ConfigurationName -match "Release") {
|
if ($ConfigurationName -match "Release")
|
||||||
Write-Output "Removing unnecessary files from Release versions"
|
{
|
||||||
|
|
||||||
$test = Join-Path -Path $TargetDir -ChildPath "app.publish"
|
$test = Join-Path -Path $TargetDir -ChildPath "app.publish"
|
||||||
if (Test-Path $test -PathType Container) {
|
if (Test-Path $test -PathType Container)
|
||||||
|
{
|
||||||
Remove-Item -Path (Join-Path -Path $TargetDir -ChildPath "app.publish") -Recurse -Force
|
Remove-Item -Path (Join-Path -Path $TargetDir -ChildPath "app.publish") -Recurse -Force
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -29,10 +29,18 @@ if ($ConfigurationName -match "Release") {
|
|||||||
) -Exclude @(
|
) -Exclude @(
|
||||||
"mRemoteNG.VisualElementsManifest.xml"
|
"mRemoteNG.VisualElementsManifest.xml"
|
||||||
)
|
)
|
||||||
Remove-Item -Path $filesToDelete.FullName
|
if ($filesToDelete)
|
||||||
Write-Output $filesToDelete.FullName
|
{
|
||||||
|
Write-Output "Unnecessary files are detected and will be removed"
|
||||||
|
Remove-Item -Path $filesToDelete.FullName
|
||||||
|
Write-Output $filesToDelete.FullName
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
Write-Output " No unnecessary files are detected"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
Write-Output "We will not remove anything - this is not a release build."
|
Write-Output "We will not remove anything - this is not a release build."
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ param (
|
|||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
||||||
|
|
||||||
|
|
||||||
# validate release versions and if the certificate value was passed
|
# validate release versions and if the certificate value was passed
|
||||||
if ($ConfigurationName -match "Release" -And ($CertificatePath)) {
|
if ($ConfigurationName -match "Release" -And ($CertificatePath)) {
|
||||||
|
|
||||||
|
|||||||
83
Tools/zip_files.ps1
Normal file
83
Tools/zip_files.ps1
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
param (
|
||||||
|
[string]
|
||||||
|
[Parameter(Mandatory=$true)]
|
||||||
|
$SolutionDir,
|
||||||
|
|
||||||
|
[string]
|
||||||
|
[Parameter(Mandatory=$true)]
|
||||||
|
$TargetDir,
|
||||||
|
|
||||||
|
[string]
|
||||||
|
[Parameter(Mandatory=$true)]
|
||||||
|
$ConfigurationName
|
||||||
|
)
|
||||||
|
|
||||||
|
Write-Output ""
|
||||||
|
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
||||||
|
|
||||||
|
$ConfigurationName = $ConfigurationName.Trim()
|
||||||
|
Write-Output "Config Name (trimmed): '$($ConfigurationName)'"
|
||||||
|
$exe = Join-Path -Path $TargetDir -ChildPath $TargetFileName
|
||||||
|
$Version = [System.Diagnostics.FileVersionInfo]::GetVersionInfo($exe).FileVersion
|
||||||
|
Write-Output "Version is $($version)"
|
||||||
|
|
||||||
|
# Fix for AppVeyor
|
||||||
|
if(!([string]::IsNullOrEmpty($Env:APPVEYOR_BUILD_FOLDER))) {
|
||||||
|
if(!(test-path "Release")) {
|
||||||
|
New-Item -ItemType Directory -Force -Path "Release" | Out-Null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Package debug symbols zip file
|
||||||
|
if ($ConfigurationName -match "Release") {
|
||||||
|
Write-Output "Packaging debug symbols"
|
||||||
|
|
||||||
|
if ($ConfigurationName -match "Portable") {
|
||||||
|
$zipFilePrefix = "mRemoteNG-Portable-symbols"
|
||||||
|
} else {
|
||||||
|
$zipFilePrefix = "mRemoteNG-symbols"
|
||||||
|
}
|
||||||
|
|
||||||
|
$debugFile = Join-Path -Path $TargetDir -ChildPath "mRemoteNG.pdb"
|
||||||
|
|
||||||
|
# AppVeyor build
|
||||||
|
if(!([string]::IsNullOrEmpty($Env:APPVEYOR_BUILD_FOLDER))) {
|
||||||
|
$outputZipPath = Join-Path -Path $SolutionDir -ChildPath "Release\$zipFilePrefix-$($version).zip"
|
||||||
|
7z a $outputZipPath $debugFile
|
||||||
|
}
|
||||||
|
# Local build
|
||||||
|
else {
|
||||||
|
if (!(Test-Path -Path $debugFile -PathType Leaf))
|
||||||
|
{
|
||||||
|
$outputZipPath = "$($SolutionDir)Release\$zipFilePrefix-$($version).zip"
|
||||||
|
Compress-Archive $debugFile $outputZipPath -Force
|
||||||
|
} else {
|
||||||
|
write-host "File do not exist:" $debugFile", nothing to compress"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Remove-Item $debugFile
|
||||||
|
}
|
||||||
|
|
||||||
|
# Package portable release zip file
|
||||||
|
if ($ConfigurationName -eq "Release Portable") {
|
||||||
|
Write-Output "Packaging portable ZIP file"
|
||||||
|
|
||||||
|
# AppVeyor build
|
||||||
|
if(!([string]::IsNullOrEmpty($Env:APPVEYOR_BUILD_FOLDER))) {
|
||||||
|
$outputZipPath = Join-Path -Path $SolutionDir -ChildPath "Release\mRemoteNG-Portable-$($version).zip"
|
||||||
|
7z a -bt -bd -bb1 -mx=9 -tzip -y -r $outputZipPath $TargetDir\*
|
||||||
|
}
|
||||||
|
# Local build
|
||||||
|
else {
|
||||||
|
if ($Source)
|
||||||
|
{
|
||||||
|
$outputZipPath="$($SolutionDir)\Release\mRemoteNG-Portable-$($version).zip"
|
||||||
|
Compress-Archive $Source $outputZipPath -Force
|
||||||
|
} else {
|
||||||
|
write-host "File do not exist:" $Source", nothing to compress"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Output ""
|
||||||
@@ -1,64 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$ConfigurationName
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
|
|
||||||
if(-not [string]::IsNullOrEmpty($Env:APPVEYOR_BUILD_FOLDER)) {
|
|
||||||
Write-Output "Too early to run via Appveyor - artifacts don't get generated properly. Exiting"
|
|
||||||
Exit
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Output "Solution Dir: '$($SolutionDir)'"
|
|
||||||
Write-Output "Target Dir: '$($TargetDir)'"
|
|
||||||
$ConfigurationName = $ConfigurationName.Trim()
|
|
||||||
Write-Output "Config Name (tirmmed): '$($ConfigurationName)'"
|
|
||||||
|
|
||||||
|
|
||||||
# Windows Sysinternals Sigcheck from http://technet.microsoft.com/en-us/sysinternals/bb897441
|
|
||||||
$SIGCHECK="$($SolutionDir)Tools\exes\sigcheck.exe"
|
|
||||||
$SEVENZIP="$($SolutionDir)Tools\7zip\7za.exe"
|
|
||||||
|
|
||||||
# Package Zip
|
|
||||||
if ($ConfigurationName -eq "Release Portable") {
|
|
||||||
Write-Output "Packaging Release Portable ZIP"
|
|
||||||
|
|
||||||
$version = & $SIGCHECK /accepteula -q -n "$($SolutionDir)mRemoteNG\bin\$($ConfigurationName)\mRemoteNG.exe"
|
|
||||||
|
|
||||||
Write-Output "Version is $($version)"
|
|
||||||
|
|
||||||
$PortableZip="$($SolutionDir)Release\mRemoteNG-Portable-$($version).zip"
|
|
||||||
|
|
||||||
$tempFolderPath = Join-Path -Path $SolutionDir -ChildPath "mRemoteNG\bin\package"
|
|
||||||
Remove-Item -Recurse $tempFolderPath -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
New-Item $tempFolderPath -ItemType "directory" | Out-Null
|
|
||||||
|
|
||||||
Copy-Item "$($SolutionDir)mRemoteNG\Resources\PuTTYNG.exe" -Destination $tempFolderPath
|
|
||||||
|
|
||||||
#Write-Output "$($SolutionDir)mRemoteNG\bin\$ConfigurationName"
|
|
||||||
#Write-Output "$($SolutionDir)mRemoteNG\bin\package"
|
|
||||||
Copy-Item "$($SolutionDir)mRemoteNG\bin\$ConfigurationName\*" -Destination $tempFolderPath -Recurse -Force
|
|
||||||
# Delete any PDB files that accidentally get copied into the temp folder
|
|
||||||
Get-ChildItem -Path $tempFolderPath -Filter "*.pdb" | Remove-Item
|
|
||||||
Copy-Item "$($SolutionDir)*.txt" -Destination $tempFolderPath
|
|
||||||
|
|
||||||
Write-Output "Creating portable ZIP file $($PortableZip)"
|
|
||||||
Remove-Item -Force $PortableZip -ErrorAction SilentlyContinue
|
|
||||||
& $SEVENZIP a -bt -bd -bb1 -mx=9 -tzip -y -r $PortableZip (Join-Path -Path $tempFolderPath -ChildPath "*.*")
|
|
||||||
#& $SEVENZIP a -bt -mx=9 -tzip -y $PortableZip "$($SolutionDir)*.TXT"
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Write-Output "We will not zip anything - this isnt a portable release build."
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
param (
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$SolutionDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$TargetDir,
|
|
||||||
|
|
||||||
[string]
|
|
||||||
[Parameter(Mandatory=$true)]
|
|
||||||
$ConfigurationName
|
|
||||||
)
|
|
||||||
|
|
||||||
Write-Output "===== Beginning $($PSCmdlet.MyInvocation.MyCommand) ====="
|
|
||||||
|
|
||||||
if(-not [string]::IsNullOrEmpty($Env:APPVEYOR_BUILD_FOLDER)) {
|
|
||||||
Write-Output "Too early to run via Appveyor - artifacts don't get generated properly. Exiting"
|
|
||||||
Exit
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Output "Solution Dir: '$($SolutionDir)'"
|
|
||||||
Write-Output "Target Dir: '$($TargetDir)'"
|
|
||||||
$ConfigurationName = $ConfigurationName.Trim()
|
|
||||||
Write-Output "Config Name (trimmed): '$($ConfigurationName)'"
|
|
||||||
|
|
||||||
|
|
||||||
# Windows Sysinternals Sigcheck from http://technet.microsoft.com/en-us/sysinternals/bb897441
|
|
||||||
$SIGCHECK="$($SolutionDir)Tools\exes\sigcheck.exe"
|
|
||||||
$SEVENZIP="$($SolutionDir)Tools\7zip\7za.exe"
|
|
||||||
|
|
||||||
# Package Zip
|
|
||||||
if ($ConfigurationName -match "Release") {
|
|
||||||
Write-Output "Packaging debug symbols"
|
|
||||||
|
|
||||||
$version = & $SIGCHECK /accepteula -q -n "$($SolutionDir)mRemoteNG\bin\$($ConfigurationName)\mRemoteNG.exe"
|
|
||||||
|
|
||||||
Write-Output "Version is $($version)"
|
|
||||||
|
|
||||||
if ($ConfigurationName -match "Portable") {
|
|
||||||
$zipFilePrefix = "mRemoteNG-Portable-symbols"
|
|
||||||
} else {
|
|
||||||
$zipFilePrefix = "mRemoteNG-symbols"
|
|
||||||
}
|
|
||||||
|
|
||||||
$outputZipPath="$($SolutionDir)Release\$zipFilePrefix-$($version).zip"
|
|
||||||
|
|
||||||
Write-Output "Creating debug symbols ZIP file $($outputZipPath)"
|
|
||||||
Remove-Item -Force $outputZipPath -ErrorAction SilentlyContinue
|
|
||||||
& $SEVENZIP a -bt -bd -bb1 -mx=9 -tzip -y -r $outputZipPath (Join-Path -Path $TargetDir -ChildPath "*.pdb")
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Write-Output "We will not package debug symbols - this isnt a release build."
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Output ""
|
|
||||||
157
mRemoteNG.sln
157
mRemoteNG.sln
@@ -1,11 +1,11 @@
|
|||||||
|
|
||||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
# Visual Studio Version 16
|
# Visual Studio Version 17
|
||||||
VisualStudioVersion = 16.0.28803.352
|
VisualStudioVersion = 17.0.31912.275
|
||||||
MinimumVisualStudioVersion = 14.0.25420.1
|
MinimumVisualStudioVersion = 14.0.25420.1
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "mRemoteNG", "mRemoteNG\mRemoteNG.csproj", "{4934A491-40BC-4E5B-9166-EA1169A220F6}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "mRemoteNG", "mRemoteNG\mRemoteNG.csproj", "{4934A491-40BC-4E5B-9166-EA1169A220F6}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "mRemoteNGTests", "mRemoteNGTests\mRemoteNGTests.csproj", "{1453B37F-8621-499E-B0B2-6091F76DC0BB}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "mRemoteNGTests", "mRemoteNGTests\mRemoteNGTests.csproj", "{1453B37F-8621-499E-B0B2-6091F76DC0BB}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "mRemoteNGInstaller", "mRemoteNGInstaller", "{4FE795BE-646E-4F1B-BAD0-A68EA26394DD}"
|
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "mRemoteNGInstaller", "mRemoteNGInstaller", "{4FE795BE-646E-4F1B-BAD0-A68EA26394DD}"
|
||||||
EndProject
|
EndProject
|
||||||
@@ -16,108 +16,63 @@ Project("{930C7802-8A8C-48F9-8165-68863BCCD9DD}") = "Installer", "mRemoteNGInsta
|
|||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04} = {5423D985-CB48-4344-B47F-E8C6D60C8B04}
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04} = {5423D985-CB48-4344-B47F-E8C6D60C8B04}
|
||||||
EndProjectSection
|
EndProjectSection
|
||||||
EndProject
|
EndProject
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "mRemoteNGSpecs", "mRemoteNGSpecs\mRemoteNGSpecs.csproj", "{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "mRemoteNGSpecs", "mRemoteNGSpecs\mRemoteNGSpecs.csproj", "{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}"
|
||||||
|
EndProject
|
||||||
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ExternalConnectors", "ExternalConnectors\ExternalConnectors.csproj", "{A56A2029-79B8-492A-ABE5-D2BFE05801BD}"
|
||||||
EndProject
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
Debug Portable|Any CPU = Debug Portable|Any CPU
|
Debug Portable|x64 = Debug Portable|x64
|
||||||
Debug Portable|x86 = Debug Portable|x86
|
Debug|x64 = Debug|x64
|
||||||
Debug|Any CPU = Debug|Any CPU
|
Release Installer|x64 = Release Installer|x64
|
||||||
Debug|x86 = Debug|x86
|
Release Portable|x64 = Release Portable|x64
|
||||||
Release Installer|Any CPU = Release Installer|Any CPU
|
Release|x64 = Release|x64
|
||||||
Release Installer|x86 = Release Installer|x86
|
|
||||||
Release Portable|Any CPU = Release Portable|Any CPU
|
|
||||||
Release Portable|x86 = Release Portable|x86
|
|
||||||
Release|Any CPU = Release|Any CPU
|
|
||||||
Release|x86 = Release|x86
|
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|Any CPU.ActiveCfg = Debug Portable|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|Any CPU.Build.0 = Debug Portable|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|x64.Build.0 = Debug Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|x86.ActiveCfg = Debug Portable|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug Portable|x86.Build.0 = Debug Portable|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|x64.Build.0 = Debug|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|Any CPU.ActiveCfg = Debug|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|Any CPU.Build.0 = Debug|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|x64.Build.0 = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|x86.ActiveCfg = Debug|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Debug|x86.Build.0 = Debug|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|x64.Build.0 = Release Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|Any CPU.ActiveCfg = Release|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|x64.ActiveCfg = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|Any CPU.Build.0 = Release|x86
|
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|x64.Build.0 = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|x86.ActiveCfg = Release|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Installer|x86.Build.0 = Release|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|Any CPU.ActiveCfg = Release Portable|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|Any CPU.Build.0 = Release Portable|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|x86.ActiveCfg = Release Portable|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|x64.Build.0 = Release Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release Portable|x86.Build.0 = Release Portable|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|x64.ActiveCfg = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|Any CPU.ActiveCfg = Release|x86
|
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|x64.Build.0 = Release|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|Any CPU.Build.0 = Release|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|x86.ActiveCfg = Release|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{4934A491-40BC-4E5B-9166-EA1169A220F6}.Release|x86.Build.0 = Release|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug Portable|Any CPU.ActiveCfg = Debug Portable|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|x64.Build.0 = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug Portable|Any CPU.Build.0 = Debug Portable|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug Portable|x86.ActiveCfg = Debug Portable|x86
|
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug Portable|x86.Build.0 = Debug Portable|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug|Any CPU.ActiveCfg = Debug|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug|Any CPU.Build.0 = Debug|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug|x86.ActiveCfg = Debug|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|x64.Build.0 = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Debug|x86.Build.0 = Debug|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Installer|Any CPU.ActiveCfg = Release|x86
|
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Installer|Any CPU.Build.0 = Release|x86
|
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Installer|x86.ActiveCfg = Release|x86
|
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Installer|x86.Build.0 = Release|x86
|
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|Any CPU.ActiveCfg = Release Portable|x86
|
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|Any CPU.Build.0 = Release Portable|x86
|
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|x86.ActiveCfg = Release Portable|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Debug Portable|x64.ActiveCfg = Debug Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release Portable|x86.Build.0 = Release Portable|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Debug Portable|x64.Build.0 = Debug Portable|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|Any CPU.ActiveCfg = Release|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|Any CPU.Build.0 = Release|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Debug|x64.Build.0 = Debug|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|x86.ActiveCfg = Release|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release Installer|x64.ActiveCfg = Release|x64
|
||||||
{1453B37F-8621-499E-B0B2-6091F76DC0BB}.Release|x86.Build.0 = Release|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release Installer|x64.Build.0 = Release|x64
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug Portable|Any CPU.ActiveCfg = Debug|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release Portable|x64.ActiveCfg = Release Portable|x64
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug Portable|Any CPU.Build.0 = Debug|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release Portable|x64.Build.0 = Release Portable|x64
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug Portable|x86.ActiveCfg = Debug|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release|x64.ActiveCfg = Release|x64
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug|Any CPU.ActiveCfg = Debug|x86
|
{A56A2029-79B8-492A-ABE5-D2BFE05801BD}.Release|x64.Build.0 = Release|x64
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug|x86.ActiveCfg = Debug|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Debug|x86.Build.0 = Debug|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|Any CPU.Build.0 = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|x86.ActiveCfg = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Installer|x86.Build.0 = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Portable|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release Portable|x86.ActiveCfg = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release|Any CPU.Build.0 = Release|x86
|
|
||||||
{5423D985-CB48-4344-B47F-E8C6D60C8B04}.Release|x86.ActiveCfg = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug Portable|Any CPU.ActiveCfg = Debug Portable|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug Portable|Any CPU.Build.0 = Debug Portable|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug Portable|x86.ActiveCfg = Debug Portable|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug|Any CPU.ActiveCfg = Debug|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Debug|x86.ActiveCfg = Debug|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|Any CPU.Build.0 = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|x86.ActiveCfg = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Installer|x86.Build.0 = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Portable|Any CPU.ActiveCfg = Release Portable|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release Portable|x86.ActiveCfg = Release Portable|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{F0168B9F-6815-40DF-BA53-46CEE7683B68}.Release|x86.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug Portable|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug Portable|Any CPU.Build.0 = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug Portable|x86.ActiveCfg = Debug|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug Portable|x86.Build.0 = Debug|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug|Any CPU.ActiveCfg = Debug|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug|x86.ActiveCfg = Debug|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Debug|x86.Build.0 = Debug|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Installer|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Installer|Any CPU.Build.0 = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Installer|x86.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Installer|x86.Build.0 = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Portable|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Portable|Any CPU.Build.0 = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Portable|x86.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release Portable|x86.Build.0 = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release|Any CPU.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release|x86.ActiveCfg = Release|x86
|
|
||||||
{16AA21E2-D6B7-427D-AB7D-AA8C611B724E}.Release|x86.Build.0 = Release|x86
|
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
|||||||
@@ -5,9 +5,9 @@ using Microsoft.Win32;
|
|||||||
using mRemoteNG.App.Info;
|
using mRemoteNG.App.Info;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
using mRemoteNG.UI.TaskDialog;
|
using mRemoteNG.UI.TaskDialog;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.App
|
namespace mRemoteNG.App
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ using mRemoteNG.Config.Import;
|
|||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.App
|
namespace mRemoteNG.App
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,10 +1,12 @@
|
|||||||
namespace mRemoteNG.App.Info
|
using System;
|
||||||
|
|
||||||
|
namespace mRemoteNG.App.Info
|
||||||
{
|
{
|
||||||
public static class ConnectionsFileInfo
|
public static class ConnectionsFileInfo
|
||||||
{
|
{
|
||||||
public static readonly string DefaultConnectionsPath = SettingsFileInfo.SettingsPath;
|
public static readonly string DefaultConnectionsPath = SettingsFileInfo.SettingsPath;
|
||||||
public static readonly string DefaultConnectionsFile = "confCons.xml";
|
public static readonly string DefaultConnectionsFile = "confCons.xml";
|
||||||
public static readonly string DefaultConnectionsFileNew = "confConsNew.xml";
|
public static readonly string DefaultConnectionsFileNew = "confConsNew.xml";
|
||||||
public static readonly double ConnectionFileVersion = 2.8;
|
public static readonly Version ConnectionFileVersion = new Version(2, 9);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -15,6 +15,7 @@ namespace mRemoteNG.App.Info
|
|||||||
public const string UrlDonate = "https://mremoteng.org/contribute";
|
public const string UrlDonate = "https://mremoteng.org/contribute";
|
||||||
public const string UrlForum = "https://www.reddit.com/r/mRemoteNG";
|
public const string UrlForum = "https://www.reddit.com/r/mRemoteNG";
|
||||||
public const string UrlBugs = "https://bugs.mremoteng.org";
|
public const string UrlBugs = "https://bugs.mremoteng.org";
|
||||||
|
public const string UrlDocumentation = "https://mremoteng.readthedocs.io/en/latest/";
|
||||||
public static string ApplicationVersion = Application.ProductVersion;
|
public static string ApplicationVersion = Application.ProductVersion;
|
||||||
public static readonly string ProductName = Application.ProductName;
|
public static readonly string ProductName = Application.ProductName;
|
||||||
|
|
||||||
@@ -27,6 +28,7 @@ namespace mRemoteNG.App.Info
|
|||||||
|
|
||||||
//public static string ReportingFilePath = "";
|
//public static string ReportingFilePath = "";
|
||||||
public static readonly string PuttyPath = HomePath + "\\PuTTYNG.exe";
|
public static readonly string PuttyPath = HomePath + "\\PuTTYNG.exe";
|
||||||
|
public static readonly string WinboxPath = HomePath + "\\winbox.exe";
|
||||||
|
|
||||||
public static string UserAgent
|
public static string UserAgent
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -8,17 +8,16 @@ namespace mRemoteNG.App.Info
|
|||||||
public static class UpdateChannelInfo
|
public static class UpdateChannelInfo
|
||||||
{
|
{
|
||||||
public const string STABLE = "Stable";
|
public const string STABLE = "Stable";
|
||||||
public const string BETA = "Beta";
|
public const string PREVIEW = "Preview";
|
||||||
public const string DEV = "Development";
|
public const string NIGHTLY = "Nightly";
|
||||||
|
|
||||||
/* no #if here since they are used for unit tests as well */
|
|
||||||
public const string STABLE_PORTABLE = "update-portable.txt";
|
public const string STABLE_PORTABLE = "update-portable.txt";
|
||||||
public const string BETA_PORTABLE = "beta-update-portable.txt";
|
public const string PREVIEW_PORTABLE = "preview-update-portable.txt";
|
||||||
public const string DEV_PORTABLE = "dev-update-portable.txt";
|
public const string NIGHTLY_PORTABLE = "nightly-update-portable.txt";
|
||||||
|
|
||||||
public const string STABLE_MSI = "update.txt";
|
public const string STABLE_MSI = "update.txt";
|
||||||
public const string BETA_MSI = "beta-update.txt";
|
public const string PREVIEW_MSI = "preview-update.txt";
|
||||||
public const string DEV_MSI = "dev-update.txt";
|
public const string NIGHTLY_MSI = "nightly-update.txt";
|
||||||
|
|
||||||
|
|
||||||
public static Uri GetUpdateChannelInfo()
|
public static Uri GetUpdateChannelInfo()
|
||||||
@@ -40,10 +39,10 @@ namespace mRemoteNG.App.Info
|
|||||||
{
|
{
|
||||||
case STABLE:
|
case STABLE:
|
||||||
return STABLE_MSI;
|
return STABLE_MSI;
|
||||||
case BETA:
|
case PREVIEW:
|
||||||
return BETA_MSI;
|
return PREVIEW_MSI;
|
||||||
case DEV:
|
case NIGHTLY:
|
||||||
return DEV_MSI;
|
return NIGHTLY_MSI;
|
||||||
default:
|
default:
|
||||||
return STABLE_MSI;
|
return STABLE_MSI;
|
||||||
}
|
}
|
||||||
@@ -55,10 +54,10 @@ namespace mRemoteNG.App.Info
|
|||||||
{
|
{
|
||||||
case STABLE:
|
case STABLE:
|
||||||
return STABLE_PORTABLE;
|
return STABLE_PORTABLE;
|
||||||
case BETA:
|
case PREVIEW:
|
||||||
return BETA_PORTABLE;
|
return PREVIEW_PORTABLE;
|
||||||
case DEV:
|
case NIGHTLY:
|
||||||
return DEV_PORTABLE;
|
return NIGHTLY_PORTABLE;
|
||||||
default:
|
default:
|
||||||
return STABLE_PORTABLE;
|
return STABLE_PORTABLE;
|
||||||
}
|
}
|
||||||
@@ -72,7 +71,7 @@ namespace mRemoteNG.App.Info
|
|||||||
|
|
||||||
private static bool IsValidChannel(string s)
|
private static bool IsValidChannel(string s)
|
||||||
{
|
{
|
||||||
return s.Equals(STABLE) || s.Equals(BETA) || s.Equals(DEV);
|
return s.Equals(STABLE) || s.Equals(PREVIEW) || s.Equals(NIGHTLY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using log4net;
|
using log4net;
|
||||||
using log4net.Appender;
|
using log4net.Appender;
|
||||||
@@ -35,6 +36,7 @@ namespace mRemoteNG.App
|
|||||||
public void SetLogPath(string path)
|
public void SetLogPath(string path)
|
||||||
{
|
{
|
||||||
var repository = LogManager.GetRepository("mRemoteNG");
|
var repository = LogManager.GetRepository("mRemoteNG");
|
||||||
|
XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));
|
||||||
var appenders = repository.GetAppenders();
|
var appenders = repository.GetAppenders();
|
||||||
|
|
||||||
foreach (var appender in appenders)
|
foreach (var appender in appenders)
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Drawing;
|
using System.Drawing;
|
||||||
using System.Runtime.ConstrainedExecution;
|
using System.Runtime.ConstrainedExecution;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
@@ -71,6 +71,12 @@ namespace mRemoteNG.App
|
|||||||
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
|
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
|
||||||
internal static extern IntPtr SetClipboardViewer(IntPtr hWndNewViewer);
|
internal static extern IntPtr SetClipboardViewer(IntPtr hWndNewViewer);
|
||||||
|
|
||||||
|
[DllImport("User32.dll", CharSet = CharSet.Auto)]
|
||||||
|
internal static extern bool ChangeClipboardChain(
|
||||||
|
IntPtr hWndRemove, // handle to window to remove
|
||||||
|
IntPtr hWndNewNext // handle to next window
|
||||||
|
);
|
||||||
|
|
||||||
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
|
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
|
||||||
internal static extern bool SetForegroundWindow(IntPtr hWnd);
|
internal static extern bool SetForegroundWindow(IntPtr hWnd);
|
||||||
|
|
||||||
@@ -106,7 +112,6 @@ namespace mRemoteNG.App
|
|||||||
internal static extern bool SetWindowPlacement(IntPtr hWnd, ref WINDOWPLACEMENT lpwndpl);
|
internal static extern bool SetWindowPlacement(IntPtr hWnd, ref WINDOWPLACEMENT lpwndpl);
|
||||||
|
|
||||||
[DllImport("kernel32", SetLastError = true)]
|
[DllImport("kernel32", SetLastError = true)]
|
||||||
[ReliabilityContract(Consistency.WillNotCorruptState, Cer.MayFail)]
|
|
||||||
internal static extern bool CloseHandle(IntPtr handle);
|
internal static extern bool CloseHandle(IntPtr handle);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|||||||
@@ -49,6 +49,8 @@ namespace mRemoteNG.App
|
|||||||
|
|
||||||
public static ICredentialRepositoryList CredentialProviderCatalog { get; } = new CredentialRepositoryList();
|
public static ICredentialRepositoryList CredentialProviderCatalog { get; } = new CredentialRepositoryList();
|
||||||
|
|
||||||
|
public static ConnectionInitiator ConnectionInitiator { get; set; } = new ConnectionInitiator();
|
||||||
|
|
||||||
public static ConnectionsService ConnectionsService { get; } =
|
public static ConnectionsService ConnectionsService { get; } =
|
||||||
new ConnectionsService(PuttySessionsManager.Instance);
|
new ConnectionsService(PuttySessionsManager.Instance);
|
||||||
|
|
||||||
@@ -102,6 +104,10 @@ namespace mRemoteNG.App
|
|||||||
if (Settings.Default.UseSQLServer)
|
if (Settings.Default.UseSQLServer)
|
||||||
{
|
{
|
||||||
ConnectionsService.LastSqlUpdate = DateTime.Now;
|
ConnectionsService.LastSqlUpdate = DateTime.Now;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ConnectionsService.LastFileUpdate = System.IO.File.GetLastWriteTime(connectionFileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
// re-enable sql update checking after updates are loaded
|
// re-enable sql update checking after updates are loaded
|
||||||
|
|||||||
@@ -2,11 +2,12 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
using mRemoteNG.Config.Connections;
|
||||||
using mRemoteNG.Config.Putty;
|
using mRemoteNG.Config.Putty;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.UI.Controls;
|
using mRemoteNG.UI.Controls;
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
// ReSharper disable ArrangeAccessorOwnerBody
|
// ReSharper disable ArrangeAccessorOwnerBody
|
||||||
|
|
||||||
@@ -60,8 +61,34 @@ namespace mRemoteNG.App
|
|||||||
|
|
||||||
private static void SaveConnections()
|
private static void SaveConnections()
|
||||||
{
|
{
|
||||||
if (Settings.Default.SaveConsOnExit)
|
DateTime lastUpdate;
|
||||||
|
DateTime updateDate;
|
||||||
|
DateTime currentDate = DateTime.Now;
|
||||||
|
|
||||||
|
//OBSOLETE: Settings.Default.SaveConsOnExit is obsolete and should be removed in a future release
|
||||||
|
if (Settings.Default.SaveConsOnExit || (Settings.Default.SaveConnectionsFrequency == (int)ConnectionsBackupFrequencyEnum.OnExit))
|
||||||
|
{
|
||||||
Runtime.ConnectionsService.SaveConnections();
|
Runtime.ConnectionsService.SaveConnections();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
lastUpdate = Runtime.ConnectionsService.UsingDatabase ? Runtime.ConnectionsService.LastSqlUpdate : Runtime.ConnectionsService.LastFileUpdate;
|
||||||
|
|
||||||
|
switch (Settings.Default.SaveConnectionsFrequency)
|
||||||
|
{
|
||||||
|
case (int)ConnectionsBackupFrequencyEnum.Daily:
|
||||||
|
updateDate = lastUpdate.AddDays(1);
|
||||||
|
break;
|
||||||
|
case (int)ConnectionsBackupFrequencyEnum.Weekly:
|
||||||
|
updateDate = lastUpdate.AddDays(7);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentDate >= updateDate)
|
||||||
|
{
|
||||||
|
Runtime.ConnectionsService.SaveConnections();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void SaveSettings(Control quickConnectToolStrip,
|
private static void SaveSettings(Control quickConnectToolStrip,
|
||||||
@@ -93,7 +120,7 @@ namespace mRemoteNG.App
|
|||||||
private static void RunUpdateFile()
|
private static void RunUpdateFile()
|
||||||
{
|
{
|
||||||
if (UpdatePending)
|
if (UpdatePending)
|
||||||
Process.Start(_updateFilePath);
|
Process.Start(new ProcessStartInfo(_updateFilePath) { UseShellExecute = true });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
|
using System.Threading.Tasks;
|
||||||
using mRemoteNG.App.Info;
|
using mRemoteNG.App.Info;
|
||||||
using mRemoteNG.App.Initialization;
|
using mRemoteNG.App.Initialization;
|
||||||
using mRemoteNG.App.Update;
|
using mRemoteNG.App.Update;
|
||||||
@@ -65,7 +66,7 @@ namespace mRemoteNG.App
|
|||||||
Runtime.ConnectionsService.RemoteConnectionsSyncronizer.Enable();
|
Runtime.ConnectionsService.RemoteConnectionsSyncronizer.Enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void CheckForUpdate()
|
public async Task CheckForUpdate()
|
||||||
{
|
{
|
||||||
if (_appUpdate == null)
|
if (_appUpdate == null)
|
||||||
{
|
{
|
||||||
@@ -87,32 +88,9 @@ namespace mRemoteNG.App
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
_appUpdate.GetUpdateInfoCompletedEvent += GetUpdateInfoCompleted;
|
|
||||||
_appUpdate.GetUpdateInfoAsync();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void GetUpdateInfoCompleted(object sender, AsyncCompletedEventArgs e)
|
|
||||||
{
|
|
||||||
if (_frmMain.InvokeRequired)
|
|
||||||
{
|
|
||||||
_frmMain.Invoke(new AsyncCompletedEventHandler(GetUpdateInfoCompleted), sender, e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_appUpdate.GetUpdateInfoCompletedEvent -= GetUpdateInfoCompleted;
|
await _appUpdate.GetUpdateInfoAsync();
|
||||||
|
|
||||||
if (e.Cancelled)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (e.Error != null)
|
|
||||||
{
|
|
||||||
throw e.Error;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_appUpdate.IsUpdateAvailable())
|
if (_appUpdate.IsUpdateAvailable())
|
||||||
{
|
{
|
||||||
Windows.Show(WindowType.Update);
|
Windows.Show(WindowType.Update);
|
||||||
@@ -120,7 +98,7 @@ namespace mRemoteNG.App
|
|||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
Runtime.MessageCollector.AddExceptionMessage("GetUpdateInfoCompleted() failed.", ex);
|
Runtime.MessageCollector.AddExceptionMessage("CheckForUpdate() failed.", ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.ComponentModel;
|
using System.Net.Http;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Reflection;
|
|
||||||
using mRemoteNG.App.Info;
|
using mRemoteNG.App.Info;
|
||||||
using mRemoteNG.Security.SymmetricEncryption;
|
using mRemoteNG.Security.SymmetricEncryption;
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
|
using System.Threading.Tasks;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
#if !PORTABLE
|
#if !PORTABLE
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
@@ -21,29 +21,30 @@ namespace mRemoteNG.App.Update
|
|||||||
{
|
{
|
||||||
public class AppUpdater
|
public class AppUpdater
|
||||||
{
|
{
|
||||||
|
private const int _bufferLength = 8192;
|
||||||
private WebProxy _webProxy;
|
private WebProxy _webProxy;
|
||||||
private Thread _getUpdateInfoThread;
|
private HttpClient _httpClient;
|
||||||
private Thread _getChangeLogThread;
|
private CancellationTokenSource _changeLogCancelToken;
|
||||||
|
private CancellationTokenSource _getUpdateInfoCancelToken;
|
||||||
|
|
||||||
#region Public Properties
|
#region Public Properties
|
||||||
|
|
||||||
public UpdateInfo CurrentUpdateInfo { get; private set; }
|
public UpdateInfo CurrentUpdateInfo { get; private set; }
|
||||||
|
|
||||||
public string ChangeLog { get; private set; }
|
|
||||||
|
|
||||||
public bool IsGetUpdateInfoRunning
|
public bool IsGetUpdateInfoRunning
|
||||||
{
|
{
|
||||||
get { return _getUpdateInfoThread != null && _getUpdateInfoThread.IsAlive; }
|
get
|
||||||
|
{
|
||||||
|
return _getUpdateInfoCancelToken != null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool IsGetChangeLogRunning
|
private bool IsGetChangeLogRunning
|
||||||
{
|
{
|
||||||
get { return _getChangeLogThread != null && _getChangeLogThread.IsAlive; }
|
get
|
||||||
}
|
{
|
||||||
|
return _changeLogCancelToken != null;
|
||||||
public bool IsDownloadUpdateRunning
|
}
|
||||||
{
|
|
||||||
get { return _downloadUpdateWebClient != null; }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
@@ -52,10 +53,10 @@ namespace mRemoteNG.App.Update
|
|||||||
|
|
||||||
public AppUpdater()
|
public AppUpdater()
|
||||||
{
|
{
|
||||||
SetProxySettings();
|
SetDefaultProxySettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetProxySettings()
|
private void SetDefaultProxySettings()
|
||||||
{
|
{
|
||||||
var shouldWeUseProxy = Settings.Default.UpdateUseProxy;
|
var shouldWeUseProxy = Settings.Default.UpdateUseProxy;
|
||||||
var proxyAddress = Settings.Default.UpdateProxyAddress;
|
var proxyAddress = Settings.Default.UpdateProxyAddress;
|
||||||
@@ -78,13 +79,14 @@ namespace mRemoteNG.App.Update
|
|||||||
if (useProxy && !string.IsNullOrEmpty(address))
|
if (useProxy && !string.IsNullOrEmpty(address))
|
||||||
{
|
{
|
||||||
_webProxy = port != 0 ? new WebProxy(address, port) : new WebProxy(address);
|
_webProxy = port != 0 ? new WebProxy(address, port) : new WebProxy(address);
|
||||||
|
|
||||||
_webProxy.Credentials = useAuthentication ? new NetworkCredential(username, password) : null;
|
_webProxy.Credentials = useAuthentication ? new NetworkCredential(username, password) : null;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_webProxy = null;
|
_webProxy = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
UpdateHttpClient();
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool IsUpdateAvailable()
|
public bool IsUpdateAvailable()
|
||||||
@@ -96,54 +98,24 @@ namespace mRemoteNG.App.Update
|
|||||||
|
|
||||||
return CurrentUpdateInfo.Version > GeneralAppInfo.GetApplicationVersion();
|
return CurrentUpdateInfo.Version > GeneralAppInfo.GetApplicationVersion();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void GetUpdateInfoAsync()
|
public async Task DownloadUpdateAsync(IProgress<int> progress)
|
||||||
{
|
{
|
||||||
if (IsGetUpdateInfoRunning)
|
if (IsGetUpdateInfoRunning)
|
||||||
{
|
{
|
||||||
_getUpdateInfoThread.Abort();
|
_getUpdateInfoCancelToken.Cancel();
|
||||||
}
|
_getUpdateInfoCancelToken.Dispose();
|
||||||
|
_getUpdateInfoCancelToken = null;
|
||||||
|
|
||||||
_getUpdateInfoThread = new Thread(GetUpdateInfo);
|
|
||||||
_getUpdateInfoThread.SetApartmentState(ApartmentState.STA);
|
|
||||||
_getUpdateInfoThread.IsBackground = true;
|
|
||||||
_getUpdateInfoThread.Start();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void GetChangeLogAsync()
|
|
||||||
{
|
|
||||||
if (CurrentUpdateInfo == null || !CurrentUpdateInfo.IsValid)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException(
|
|
||||||
"CurrentUpdateInfo is not valid. GetUpdateInfoAsync() must be called before calling GetChangeLogAsync().");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (IsGetChangeLogRunning)
|
|
||||||
{
|
|
||||||
_getChangeLogThread.Abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
_getChangeLogThread = new Thread(GetChangeLog);
|
|
||||||
_getChangeLogThread.SetApartmentState(ApartmentState.STA);
|
|
||||||
_getChangeLogThread.IsBackground = true;
|
|
||||||
_getChangeLogThread.Start();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void DownloadUpdateAsync()
|
|
||||||
{
|
|
||||||
if (_downloadUpdateWebClient != null)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException("A previous call to DownloadUpdateAsync() is still in progress.");
|
throw new InvalidOperationException("A previous call to DownloadUpdateAsync() is still in progress.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (CurrentUpdateInfo == null || !CurrentUpdateInfo.IsValid)
|
if (CurrentUpdateInfo == null || !CurrentUpdateInfo.IsValid)
|
||||||
{
|
{
|
||||||
throw new InvalidOperationException(
|
throw new InvalidOperationException("CurrentUpdateInfo is not valid. GetUpdateInfoAsync() must be called before calling DownloadUpdateAsync().");
|
||||||
"CurrentUpdateInfo is not valid. GetUpdateInfoAsync() must be called before calling DownloadUpdateAsync().");
|
|
||||||
}
|
}
|
||||||
#if !PORTABLE
|
#if !PORTABLE
|
||||||
CurrentUpdateInfo.UpdateFilePath =
|
CurrentUpdateInfo.UpdateFilePath = Path.Combine(Path.GetTempPath(), Path.ChangeExtension(Path.GetRandomFileName(), "msi"));
|
||||||
Path.Combine(Path.GetTempPath(), Path.ChangeExtension(Path.GetRandomFileName(), "msi"));
|
|
||||||
#else
|
#else
|
||||||
var sfd = new SaveFileDialog
|
var sfd = new SaveFileDialog
|
||||||
{
|
{
|
||||||
@@ -160,135 +132,38 @@ namespace mRemoteNG.App.Update
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
DownloadUpdateWebClient.DownloadFileAsync(CurrentUpdateInfo.DownloadAddress,
|
|
||||||
CurrentUpdateInfo.UpdateFilePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private Properties
|
|
||||||
|
|
||||||
private WebClient _downloadUpdateWebClient;
|
|
||||||
|
|
||||||
private WebClient DownloadUpdateWebClient
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
if (_downloadUpdateWebClient != null)
|
|
||||||
{
|
|
||||||
return _downloadUpdateWebClient;
|
|
||||||
}
|
|
||||||
|
|
||||||
_downloadUpdateWebClient = CreateWebClient();
|
|
||||||
|
|
||||||
_downloadUpdateWebClient.DownloadProgressChanged += DownloadUpdateProgressChanged;
|
|
||||||
_downloadUpdateWebClient.DownloadFileCompleted += DownloadUpdateCompleted;
|
|
||||||
|
|
||||||
return _downloadUpdateWebClient;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private Methods
|
|
||||||
|
|
||||||
private WebClient CreateWebClient()
|
|
||||||
{
|
|
||||||
var webClient = new WebClient();
|
|
||||||
webClient.Headers.Add("user-agent", GeneralAppInfo.UserAgent);
|
|
||||||
webClient.Proxy = _webProxy;
|
|
||||||
return webClient;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static DownloadStringCompletedEventArgs NewDownloadStringCompletedEventArgs(string result,
|
|
||||||
Exception exception,
|
|
||||||
bool cancelled,
|
|
||||||
object userToken)
|
|
||||||
{
|
|
||||||
var type = typeof(DownloadStringCompletedEventArgs);
|
|
||||||
const BindingFlags bindingFlags = BindingFlags.NonPublic | BindingFlags.Instance;
|
|
||||||
Type[] argumentTypes = {typeof(string), typeof(Exception), typeof(bool), typeof(object)};
|
|
||||||
var constructor = type.GetConstructor(bindingFlags, null, argumentTypes, null);
|
|
||||||
object[] arguments = {result, exception, cancelled, userToken};
|
|
||||||
|
|
||||||
if (constructor == null)
|
|
||||||
return null;
|
|
||||||
return (DownloadStringCompletedEventArgs)constructor.Invoke(arguments);
|
|
||||||
}
|
|
||||||
|
|
||||||
private DownloadStringCompletedEventArgs DownloadString(Uri address)
|
|
||||||
{
|
|
||||||
var webClient = CreateWebClient();
|
|
||||||
var result = string.Empty;
|
|
||||||
Exception exception = null;
|
|
||||||
var cancelled = false;
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
result = webClient.DownloadString(address);
|
_getUpdateInfoCancelToken = new CancellationTokenSource();
|
||||||
}
|
using var response = await _httpClient.GetAsync(CurrentUpdateInfo.DownloadAddress, HttpCompletionOption.ResponseHeadersRead, _getUpdateInfoCancelToken.Token);
|
||||||
catch (ThreadAbortException)
|
var buffer = new byte[_bufferLength];
|
||||||
{
|
var totalBytes = response.Content.Headers.ContentLength ?? 0;
|
||||||
cancelled = true;
|
var readBytes = 0L;
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
exception = ex;
|
|
||||||
}
|
|
||||||
|
|
||||||
return NewDownloadStringCompletedEventArgs(result, exception, cancelled, null);
|
await using (var httpStream = await response.Content.ReadAsStreamAsync(_getUpdateInfoCancelToken.Token))
|
||||||
}
|
|
||||||
|
|
||||||
private void GetUpdateInfo()
|
|
||||||
{
|
|
||||||
var e = DownloadString(UpdateChannelInfo.GetUpdateChannelInfo());
|
|
||||||
|
|
||||||
if (!e.Cancelled && e.Error == null)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
{
|
||||||
CurrentUpdateInfo = UpdateInfo.FromString(e.Result);
|
await using var fileStream = new FileStream(CurrentUpdateInfo.UpdateFilePath, FileMode.Create,
|
||||||
|
FileAccess.Write, FileShare.None, _bufferLength, true);
|
||||||
|
|
||||||
Settings.Default.CheckForUpdatesLastCheck = DateTime.UtcNow;
|
while (readBytes <= totalBytes || !_getUpdateInfoCancelToken.IsCancellationRequested)
|
||||||
if (!Settings.Default.UpdatePending)
|
|
||||||
{
|
{
|
||||||
Settings.Default.UpdatePending = IsUpdateAvailable();
|
var bytesRead =
|
||||||
|
await httpStream.ReadAsync(buffer, 0, _bufferLength, _getUpdateInfoCancelToken.Token);
|
||||||
|
if (bytesRead == 0)
|
||||||
|
{
|
||||||
|
progress.Report(100);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
await fileStream.WriteAsync(buffer, 0, bytesRead, _getUpdateInfoCancelToken.Token);
|
||||||
|
|
||||||
|
readBytes += bytesRead;
|
||||||
|
|
||||||
|
var percentComplete = (int)(readBytes * 100 / totalBytes);
|
||||||
|
progress.Report(percentComplete);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
e = NewDownloadStringCompletedEventArgs(e.Result, ex, e.Cancelled, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
GetUpdateInfoCompletedEventEvent?.Invoke(this, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void GetChangeLog()
|
|
||||||
{
|
|
||||||
var e = DownloadString(CurrentUpdateInfo.ChangeLogAddress);
|
|
||||||
|
|
||||||
if (!e.Cancelled && e.Error == null)
|
|
||||||
{
|
|
||||||
ChangeLog = e.Result;
|
|
||||||
}
|
|
||||||
|
|
||||||
GetChangeLogCompletedEventEvent?.Invoke(this, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void DownloadUpdateProgressChanged(object sender, DownloadProgressChangedEventArgs e)
|
|
||||||
{
|
|
||||||
DownloadUpdateProgressChangedEventEvent?.Invoke(sender, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void DownloadUpdateCompleted(object sender, AsyncCompletedEventArgs e)
|
|
||||||
{
|
|
||||||
var raiseEventArgs = e;
|
|
||||||
|
|
||||||
if (!e.Cancelled && e.Error == null)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
#if !PORTABLE
|
#if !PORTABLE
|
||||||
var updateAuthenticode = new Authenticode(CurrentUpdateInfo.UpdateFilePath)
|
var updateAuthenticode = new Authenticode(CurrentUpdateInfo.UpdateFilePath)
|
||||||
{
|
{
|
||||||
@@ -307,101 +182,85 @@ namespace mRemoteNG.App.Update
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using (var cksum = SHA512.Create())
|
using var checksum = SHA512.Create();
|
||||||
{
|
await using var stream = File.OpenRead(CurrentUpdateInfo.UpdateFilePath);
|
||||||
using (var stream = File.OpenRead(CurrentUpdateInfo.UpdateFilePath))
|
var hash = await checksum.ComputeHashAsync(stream);
|
||||||
{
|
var hashString = BitConverter.ToString(hash).Replace("-", "").ToUpperInvariant();
|
||||||
var hash = cksum.ComputeHash(stream);
|
if (!hashString.Equals(CurrentUpdateInfo.Checksum))
|
||||||
var hashString = BitConverter.ToString(hash).Replace("-", "").ToUpperInvariant();
|
throw new Exception("SHA512 Hashes didn't match!");
|
||||||
if (!hashString.Equals(CurrentUpdateInfo.Checksum))
|
} finally{
|
||||||
throw new Exception("SHA512 Hashes didn't match!");
|
_getUpdateInfoCancelToken?.Dispose();
|
||||||
}
|
_getUpdateInfoCancelToken = null;
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
raiseEventArgs = new AsyncCompletedEventArgs(ex, false, null);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (raiseEventArgs.Cancelled || raiseEventArgs.Error != null)
|
|
||||||
{
|
|
||||||
File.Delete(CurrentUpdateInfo.UpdateFilePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
DownloadUpdateCompletedEventEvent?.Invoke(this, raiseEventArgs);
|
|
||||||
|
|
||||||
_downloadUpdateWebClient.Dispose();
|
|
||||||
_downloadUpdateWebClient = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Events
|
#region Private Methods
|
||||||
|
|
||||||
private AsyncCompletedEventHandler GetUpdateInfoCompletedEventEvent;
|
private void UpdateHttpClient()
|
||||||
|
|
||||||
public event AsyncCompletedEventHandler GetUpdateInfoCompletedEvent
|
|
||||||
{
|
{
|
||||||
add
|
if (_httpClient != null)
|
||||||
{
|
{
|
||||||
GetUpdateInfoCompletedEventEvent =
|
_httpClient.Dispose();
|
||||||
(AsyncCompletedEventHandler)Delegate.Combine(GetUpdateInfoCompletedEventEvent, value);
|
|
||||||
}
|
}
|
||||||
remove
|
|
||||||
|
var httpClientHandler = new HttpClientHandler();
|
||||||
|
if (_webProxy != null)
|
||||||
{
|
{
|
||||||
GetUpdateInfoCompletedEventEvent =
|
httpClientHandler.UseProxy = true;
|
||||||
(AsyncCompletedEventHandler)Delegate.Remove(GetUpdateInfoCompletedEventEvent, value);
|
httpClientHandler.Proxy = _webProxy;
|
||||||
|
}
|
||||||
|
_httpClient = new HttpClient(httpClientHandler);
|
||||||
|
_httpClient.DefaultRequestHeaders.UserAgent.ParseAdd(GeneralAppInfo.UserAgent);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task GetUpdateInfoAsync()
|
||||||
|
{
|
||||||
|
if (IsGetUpdateInfoRunning)
|
||||||
|
{
|
||||||
|
_getUpdateInfoCancelToken.Cancel();
|
||||||
|
_getUpdateInfoCancelToken.Dispose();
|
||||||
|
_getUpdateInfoCancelToken = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_getUpdateInfoCancelToken = new CancellationTokenSource();
|
||||||
|
var updateInfo = await _httpClient.GetStringAsync(UpdateChannelInfo.GetUpdateChannelInfo(), _getUpdateInfoCancelToken.Token);
|
||||||
|
CurrentUpdateInfo = UpdateInfo.FromString(updateInfo);
|
||||||
|
Settings.Default.CheckForUpdatesLastCheck = DateTime.UtcNow;
|
||||||
|
|
||||||
|
if (!Settings.Default.UpdatePending)
|
||||||
|
{
|
||||||
|
Settings.Default.UpdatePending = IsUpdateAvailable();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
_getUpdateInfoCancelToken?.Dispose();
|
||||||
|
_getUpdateInfoCancelToken = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private AsyncCompletedEventHandler GetChangeLogCompletedEventEvent;
|
public async Task<string> GetChangeLogAsync()
|
||||||
|
|
||||||
public event AsyncCompletedEventHandler GetChangeLogCompletedEvent
|
|
||||||
{
|
{
|
||||||
add
|
if (IsGetChangeLogRunning)
|
||||||
{
|
{
|
||||||
GetChangeLogCompletedEventEvent =
|
_changeLogCancelToken.Cancel();
|
||||||
(AsyncCompletedEventHandler)Delegate.Combine(GetChangeLogCompletedEventEvent, value);
|
_changeLogCancelToken.Dispose();
|
||||||
|
_changeLogCancelToken = null;
|
||||||
}
|
}
|
||||||
remove
|
|
||||||
{
|
|
||||||
GetChangeLogCompletedEventEvent =
|
|
||||||
(AsyncCompletedEventHandler)Delegate.Remove(GetChangeLogCompletedEventEvent, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private DownloadProgressChangedEventHandler DownloadUpdateProgressChangedEventEvent;
|
try
|
||||||
|
|
||||||
public event DownloadProgressChangedEventHandler DownloadUpdateProgressChangedEvent
|
|
||||||
{
|
|
||||||
add
|
|
||||||
{
|
{
|
||||||
DownloadUpdateProgressChangedEventEvent =
|
_changeLogCancelToken = new CancellationTokenSource();
|
||||||
(DownloadProgressChangedEventHandler)Delegate.Combine(DownloadUpdateProgressChangedEventEvent,
|
return await _httpClient.GetStringAsync(CurrentUpdateInfo.ChangeLogAddress, _changeLogCancelToken.Token);
|
||||||
value);
|
|
||||||
}
|
}
|
||||||
remove
|
finally
|
||||||
{
|
{
|
||||||
DownloadUpdateProgressChangedEventEvent =
|
_changeLogCancelToken?.Dispose();
|
||||||
(DownloadProgressChangedEventHandler)Delegate.Remove(DownloadUpdateProgressChangedEventEvent,
|
_changeLogCancelToken = null;
|
||||||
value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private AsyncCompletedEventHandler DownloadUpdateCompletedEventEvent;
|
|
||||||
|
|
||||||
public event AsyncCompletedEventHandler DownloadUpdateCompletedEvent
|
|
||||||
{
|
|
||||||
add
|
|
||||||
{
|
|
||||||
DownloadUpdateCompletedEventEvent =
|
|
||||||
(AsyncCompletedEventHandler)Delegate.Combine(DownloadUpdateCompletedEventEvent, value);
|
|
||||||
}
|
|
||||||
remove
|
|
||||||
{
|
|
||||||
DownloadUpdateCompletedEventEvent =
|
|
||||||
(AsyncCompletedEventHandler)Delegate.Remove(DownloadUpdateCompletedEventEvent, value);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,10 +8,8 @@ namespace mRemoteNG.App
|
|||||||
public static class Windows
|
public static class Windows
|
||||||
{
|
{
|
||||||
private static ActiveDirectoryImportWindow _adimportForm;
|
private static ActiveDirectoryImportWindow _adimportForm;
|
||||||
private static HelpWindow _helpForm;
|
|
||||||
private static ExternalToolsWindow _externalappsForm;
|
private static ExternalToolsWindow _externalappsForm;
|
||||||
private static PortScanWindow _portscanForm;
|
private static PortScanWindow _portscanForm;
|
||||||
private static ScreenshotManagerWindow _screenshotmanagerForm;
|
|
||||||
private static UltraVNCWindow _ultravncscForm;
|
private static UltraVNCWindow _ultravncscForm;
|
||||||
private static ConnectionTreeWindow _treeForm;
|
private static ConnectionTreeWindow _treeForm;
|
||||||
|
|
||||||
@@ -23,7 +21,6 @@ namespace mRemoteNG.App
|
|||||||
|
|
||||||
internal static ConfigWindow ConfigForm { get; set; } = new ConfigWindow();
|
internal static ConfigWindow ConfigForm { get; set; } = new ConfigWindow();
|
||||||
internal static ErrorAndInfoWindow ErrorsForm { get; set; } = new ErrorAndInfoWindow();
|
internal static ErrorAndInfoWindow ErrorsForm { get; set; } = new ErrorAndInfoWindow();
|
||||||
internal static ScreenshotManagerWindow ScreenshotForm { get; set; } = new ScreenshotManagerWindow();
|
|
||||||
private static UpdateWindow UpdateForm { get; set; } = new UpdateWindow();
|
private static UpdateWindow UpdateForm { get; set; } = new UpdateWindow();
|
||||||
internal static SSHTransferWindow SshtransferForm { get; private set; } = new SSHTransferWindow();
|
internal static SSHTransferWindow SshtransferForm { get; private set; } = new SSHTransferWindow();
|
||||||
|
|
||||||
@@ -58,11 +55,6 @@ namespace mRemoteNG.App
|
|||||||
UpdateForm = new UpdateWindow();
|
UpdateForm = new UpdateWindow();
|
||||||
UpdateForm.Show(dockPanel);
|
UpdateForm.Show(dockPanel);
|
||||||
break;
|
break;
|
||||||
case WindowType.Help:
|
|
||||||
if (_helpForm == null || _helpForm.IsDisposed)
|
|
||||||
_helpForm = new HelpWindow();
|
|
||||||
_helpForm.Show(dockPanel);
|
|
||||||
break;
|
|
||||||
case WindowType.ExternalApps:
|
case WindowType.ExternalApps:
|
||||||
if (_externalappsForm == null || _externalappsForm.IsDisposed)
|
if (_externalappsForm == null || _externalappsForm.IsDisposed)
|
||||||
_externalappsForm = new ExternalToolsWindow();
|
_externalappsForm = new ExternalToolsWindow();
|
||||||
@@ -72,10 +64,6 @@ namespace mRemoteNG.App
|
|||||||
_portscanForm = new PortScanWindow();
|
_portscanForm = new PortScanWindow();
|
||||||
_portscanForm.Show(dockPanel);
|
_portscanForm.Show(dockPanel);
|
||||||
break;
|
break;
|
||||||
case WindowType.ScreenshotManager:
|
|
||||||
_screenshotmanagerForm = new ScreenshotManagerWindow();
|
|
||||||
_screenshotmanagerForm.Show(dockPanel);
|
|
||||||
break;
|
|
||||||
case WindowType.UltraVNCSC:
|
case WindowType.UltraVNCSC:
|
||||||
if (_ultravncscForm == null || _ultravncscForm.IsDisposed)
|
if (_ultravncscForm == null || _ultravncscForm.IsDisposed)
|
||||||
_ultravncscForm = new UltraVNCWindow();
|
_ultravncscForm = new UltraVNCWindow();
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
namespace mRemoteNG.Config.Connections
|
||||||
|
{
|
||||||
|
public enum ConnectionsBackupFrequencyEnum
|
||||||
|
{
|
||||||
|
Unassigned = 0,
|
||||||
|
Never = 1,
|
||||||
|
OnEdit = 2,
|
||||||
|
OnExit = 3,
|
||||||
|
Daily = 4,
|
||||||
|
Weekly = 5,
|
||||||
|
Custom = 6
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,7 +8,7 @@ namespace mRemoteNG.Config.Connections.Multiuser
|
|||||||
{
|
{
|
||||||
public class RemoteConnectionsSyncronizer : IConnectionsUpdateChecker
|
public class RemoteConnectionsSyncronizer : IConnectionsUpdateChecker
|
||||||
{
|
{
|
||||||
private readonly Timer _updateTimer;
|
private readonly System.Timers.Timer _updateTimer;
|
||||||
private readonly IConnectionsUpdateChecker _updateChecker;
|
private readonly IConnectionsUpdateChecker _updateChecker;
|
||||||
|
|
||||||
public double TimerIntervalInMilliseconds
|
public double TimerIntervalInMilliseconds
|
||||||
@@ -19,7 +19,7 @@ namespace mRemoteNG.Config.Connections.Multiuser
|
|||||||
public RemoteConnectionsSyncronizer(IConnectionsUpdateChecker updateChecker)
|
public RemoteConnectionsSyncronizer(IConnectionsUpdateChecker updateChecker)
|
||||||
{
|
{
|
||||||
_updateChecker = updateChecker;
|
_updateChecker = updateChecker;
|
||||||
_updateTimer = new Timer(3000);
|
_updateTimer = new System.Timers.Timer(3000);
|
||||||
SetEventListeners();
|
SetEventListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ using System.Collections.Specialized;
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
|
using mRemoteNG.Properties;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Connections
|
namespace mRemoteNG.Config.Connections
|
||||||
{
|
{
|
||||||
@@ -48,12 +49,14 @@ namespace mRemoteNG.Config.Connections
|
|||||||
|
|
||||||
private void SaveConnectionOnEdit(string propertyName = "")
|
private void SaveConnectionOnEdit(string propertyName = "")
|
||||||
{
|
{
|
||||||
if (!Properties.Settings.Default.SaveConnectionsAfterEveryEdit)
|
//OBSOLETE: mRemoteNG.Settings.Default.SaveConnectionsAfterEveryEdit is obsolete and should be removed in a future release
|
||||||
return;
|
if (mRemoteNG.Properties.Settings.Default.SaveConnectionsAfterEveryEdit || (mRemoteNG.Properties.Settings.Default.SaveConnectionsFrequency == (int)ConnectionsBackupFrequencyEnum.OnEdit))
|
||||||
if (FrmMain.Default.IsClosing)
|
{
|
||||||
return;
|
if (FrmMain.Default.IsClosing)
|
||||||
|
return;
|
||||||
|
|
||||||
_connectionsService.SaveConnectionsAsync(propertyName);
|
_connectionsService.SaveConnectionsAsync(propertyName);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -12,12 +12,12 @@ using mRemoteNG.Config.Serializers.Versioning;
|
|||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Security;
|
using mRemoteNG.Security;
|
||||||
using mRemoteNG.Security.SymmetricEncryption;
|
using mRemoteNG.Security.SymmetricEncryption;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Connections
|
namespace mRemoteNG.Config.Connections
|
||||||
{
|
{
|
||||||
@@ -140,9 +140,9 @@ namespace mRemoteNG.Config.Connections
|
|||||||
{
|
{
|
||||||
dbQuery =
|
dbQuery =
|
||||||
databaseConnector.DbCommand(
|
databaseConnector.DbCommand(
|
||||||
"INSERT INTO tblRoot (Name, Export, Protected, ConfVersion) VALUES(\'" +
|
"INSERT INTO tblRoot (Name, Export, Protected, ConfVersion) VALUES('" +
|
||||||
MiscTools.PrepareValueForDB(rootTreeNode.Name) + "\', 0, \'" + strProtected + "\'," +
|
MiscTools.PrepareValueForDB(rootTreeNode.Name) + "', 0, '" + strProtected + "','" +
|
||||||
ConnectionsFileInfo.ConnectionFileVersion.ToString(CultureInfo.InvariantCulture) + ")");
|
ConnectionsFileInfo.ConnectionFileVersion.ToString() + "')");
|
||||||
dbQuery.ExecuteNonQuery();
|
dbQuery.ExecuteNonQuery();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -172,7 +172,7 @@ namespace mRemoteNG.Config.Connections
|
|||||||
{
|
{
|
||||||
var dbQuery = databaseConnector.DbCommand("DELETE FROM tblUpdate");
|
var dbQuery = databaseConnector.DbCommand("DELETE FROM tblUpdate");
|
||||||
dbQuery.ExecuteNonQuery();
|
dbQuery.ExecuteNonQuery();
|
||||||
dbQuery = databaseConnector.DbCommand("INSERT INTO tblUpdate (LastUpdate) VALUES(\'" + MiscTools.DBDate(DateTime.Now) + "\')");
|
dbQuery = databaseConnector.DbCommand("INSERT INTO tblUpdate (LastUpdate) VALUES('" + MiscTools.DBDate(DateTime.Now) + "')");
|
||||||
dbQuery.ExecuteNonQuery();
|
dbQuery.ExecuteNonQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -53,12 +53,26 @@ namespace mRemoteNG.Config.DatabaseConnectors
|
|||||||
|
|
||||||
private void BuildDbConnectionStringWithCustomCredentials()
|
private void BuildDbConnectionStringWithCustomCredentials()
|
||||||
{
|
{
|
||||||
_dbConnectionString = $"Data Source={_dbHost};Initial Catalog={_dbCatalog};User Id={_dbUsername};Password={_dbPassword}";
|
string[] hostParts = _dbHost.Split(new char[] { ':' }, 2);
|
||||||
|
var _dbPort = (hostParts.Length == 2) ? hostParts[1] : "1433";
|
||||||
|
|
||||||
|
_dbConnectionString = new SqlConnectionStringBuilder
|
||||||
|
{
|
||||||
|
DataSource = $"{hostParts[0]},{_dbPort}",
|
||||||
|
InitialCatalog = _dbCatalog,
|
||||||
|
UserID = _dbUsername,
|
||||||
|
Password = _dbPassword,
|
||||||
|
}.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void BuildDbConnectionStringWithDefaultCredentials()
|
private void BuildDbConnectionStringWithDefaultCredentials()
|
||||||
{
|
{
|
||||||
_dbConnectionString = $"Data Source={_dbHost};Initial Catalog={_dbCatalog};Integrated Security=True";
|
_dbConnectionString = new SqlConnectionStringBuilder
|
||||||
|
{
|
||||||
|
DataSource = _dbHost,
|
||||||
|
InitialCatalog = _dbCatalog,
|
||||||
|
IntegratedSecurity = true
|
||||||
|
}.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Connect()
|
public void Connect()
|
||||||
|
|||||||
@@ -101,6 +101,10 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
? connectionCsv[headers.IndexOf("Panel")]
|
? connectionCsv[headers.IndexOf("Panel")]
|
||||||
: "";
|
: "";
|
||||||
|
|
||||||
|
connectionRecord.Username = headers.Contains("UserViaAPI")
|
||||||
|
? connectionCsv[headers.IndexOf("UserViaAPI")]
|
||||||
|
: "";
|
||||||
|
|
||||||
connectionRecord.Username = headers.Contains("Username")
|
connectionRecord.Username = headers.Contains("Username")
|
||||||
? connectionCsv[headers.IndexOf("Username")]
|
? connectionCsv[headers.IndexOf("Username")]
|
||||||
: "";
|
: "";
|
||||||
@@ -136,6 +140,10 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
? connectionCsv[headers.IndexOf("LoadBalanceInfo")]
|
? connectionCsv[headers.IndexOf("LoadBalanceInfo")]
|
||||||
: "";
|
: "";
|
||||||
|
|
||||||
|
connectionRecord.OpeningCommand = headers.Contains("OpeningCommand")
|
||||||
|
? connectionCsv[headers.IndexOf("OpeningCommand")]
|
||||||
|
: "";
|
||||||
|
|
||||||
connectionRecord.PreExtApp = headers.Contains("PreExtApp")
|
connectionRecord.PreExtApp = headers.Contains("PreExtApp")
|
||||||
? connectionCsv[headers.IndexOf("PreExtApp")]
|
? connectionCsv[headers.IndexOf("PreExtApp")]
|
||||||
: "";
|
: "";
|
||||||
@@ -186,6 +194,14 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
? connectionCsv[headers.IndexOf("RDGatewayHostname")]
|
? connectionCsv[headers.IndexOf("RDGatewayHostname")]
|
||||||
: "";
|
: "";
|
||||||
|
|
||||||
|
connectionRecord.RDPStartProgram = headers.Contains("RDPStartProgram")
|
||||||
|
? connectionCsv[headers.IndexOf("RDPStartProgram")]
|
||||||
|
: "";
|
||||||
|
|
||||||
|
connectionRecord.RDPStartProgramWorkDir = headers.Contains("RDPStartProgramWorkDir")
|
||||||
|
? connectionCsv[headers.IndexOf("RDPStartProgramWorkDir")]
|
||||||
|
: "";
|
||||||
|
|
||||||
if (headers.Contains("Protocol"))
|
if (headers.Contains("Protocol"))
|
||||||
{
|
{
|
||||||
if (Enum.TryParse(connectionCsv[headers.IndexOf("Protocol")], out ProtocolType protocolType))
|
if (Enum.TryParse(connectionCsv[headers.IndexOf("Protocol")], out ProtocolType protocolType))
|
||||||
@@ -536,6 +552,12 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
connectionRecord.Inheritance.SSHTunnelConnectionName = value;
|
connectionRecord.Inheritance.SSHTunnelConnectionName = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (headers.Contains("InheritOpeningCommand"))
|
||||||
|
{
|
||||||
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritOpeningCommand")], out bool value))
|
||||||
|
connectionRecord.Inheritance.OpeningCommand = value;
|
||||||
|
}
|
||||||
|
|
||||||
if (headers.Contains("InheritSSHOptions"))
|
if (headers.Contains("InheritSSHOptions"))
|
||||||
{
|
{
|
||||||
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritSSHOptions")], out bool value))
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritSSHOptions")], out bool value))
|
||||||
@@ -632,6 +654,12 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
connectionRecord.Inheritance.RenderingEngine = value;
|
connectionRecord.Inheritance.RenderingEngine = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (headers.Contains("InheritUserViaAPI"))
|
||||||
|
{
|
||||||
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritUserViaAPI")], out bool value))
|
||||||
|
connectionRecord.Inheritance.UserViaAPI = value;
|
||||||
|
}
|
||||||
|
|
||||||
if (headers.Contains("InheritUsername"))
|
if (headers.Contains("InheritUsername"))
|
||||||
{
|
{
|
||||||
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritUsername")], out bool value))
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritUsername")], out bool value))
|
||||||
@@ -656,6 +684,12 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
|||||||
connectionRecord.Inheritance.LoadBalanceInfo = value;
|
connectionRecord.Inheritance.LoadBalanceInfo = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (headers.Contains("InheritOpeningCommand"))
|
||||||
|
{
|
||||||
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritOpeningCommand")], out bool value))
|
||||||
|
connectionRecord.Inheritance.OpeningCommand = value;
|
||||||
|
}
|
||||||
|
|
||||||
if (headers.Contains("InheritPreExtApp"))
|
if (headers.Contains("InheritPreExtApp"))
|
||||||
{
|
{
|
||||||
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritPreExtApp")], out bool value))
|
if (bool.TryParse(connectionCsv[headers.IndexOf("InheritPreExtApp")], out bool value))
|
||||||
|
|||||||
@@ -1,255 +1,263 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Credential;
|
using mRemoteNG.Credential;
|
||||||
using mRemoteNG.Security;
|
using mRemoteNG.Security;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Csv
|
||||||
{
|
{
|
||||||
public class CsvConnectionsSerializerMremotengFormat : ISerializer<ConnectionInfo, string>
|
public class CsvConnectionsSerializerMremotengFormat : ISerializer<ConnectionInfo, string>
|
||||||
{
|
{
|
||||||
private readonly SaveFilter _saveFilter;
|
private readonly SaveFilter _saveFilter;
|
||||||
private readonly ICredentialRepositoryList _credentialRepositoryList;
|
private readonly ICredentialRepositoryList _credentialRepositoryList;
|
||||||
|
|
||||||
public Version Version { get; } = new Version(2, 7);
|
public Version Version { get; } = new Version(2, 7);
|
||||||
|
|
||||||
public CsvConnectionsSerializerMremotengFormat(SaveFilter saveFilter,
|
public CsvConnectionsSerializerMremotengFormat(SaveFilter saveFilter,
|
||||||
ICredentialRepositoryList credentialRepositoryList)
|
ICredentialRepositoryList credentialRepositoryList)
|
||||||
{
|
{
|
||||||
saveFilter.ThrowIfNull(nameof(saveFilter));
|
saveFilter.ThrowIfNull(nameof(saveFilter));
|
||||||
credentialRepositoryList.ThrowIfNull(nameof(credentialRepositoryList));
|
credentialRepositoryList.ThrowIfNull(nameof(credentialRepositoryList));
|
||||||
|
|
||||||
_saveFilter = saveFilter;
|
_saveFilter = saveFilter;
|
||||||
_credentialRepositoryList = credentialRepositoryList;
|
_credentialRepositoryList = credentialRepositoryList;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Serialize(ConnectionTreeModel connectionTreeModel)
|
public string Serialize(ConnectionTreeModel connectionTreeModel)
|
||||||
{
|
{
|
||||||
connectionTreeModel.ThrowIfNull(nameof(connectionTreeModel));
|
connectionTreeModel.ThrowIfNull(nameof(connectionTreeModel));
|
||||||
|
|
||||||
var rootNode = connectionTreeModel.RootNodes.First(node => node is RootNodeInfo);
|
var rootNode = connectionTreeModel.RootNodes.First(node => node is RootNodeInfo);
|
||||||
return Serialize(rootNode);
|
return Serialize(rootNode);
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Serialize(ConnectionInfo serializationTarget)
|
public string Serialize(ConnectionInfo serializationTarget)
|
||||||
{
|
{
|
||||||
serializationTarget.ThrowIfNull(nameof(serializationTarget));
|
serializationTarget.ThrowIfNull(nameof(serializationTarget));
|
||||||
var sb = new StringBuilder();
|
var sb = new StringBuilder();
|
||||||
|
|
||||||
WriteCsvHeader(sb);
|
WriteCsvHeader(sb);
|
||||||
SerializeNodesRecursive(serializationTarget, sb);
|
SerializeNodesRecursive(serializationTarget, sb);
|
||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WriteCsvHeader(StringBuilder sb)
|
private void WriteCsvHeader(StringBuilder sb)
|
||||||
{
|
{
|
||||||
sb.Append("Name;Id;Parent;NodeType;Description;Icon;Panel;");
|
sb.Append("Name;Id;Parent;NodeType;Description;Icon;Panel;");
|
||||||
if (_saveFilter.SaveUsername)
|
if (_saveFilter.SaveUsername)
|
||||||
sb.Append("Username;");
|
sb.Append("Username;");
|
||||||
if (_saveFilter.SavePassword)
|
if (_saveFilter.SavePassword)
|
||||||
sb.Append("Password;");
|
sb.Append("Password;");
|
||||||
if (_saveFilter.SaveDomain)
|
if (_saveFilter.SaveDomain)
|
||||||
sb.Append("Domain;");
|
sb.Append("Domain;");
|
||||||
|
|
||||||
sb.Append("Hostname;Port;VmId;Protocol;SSHTunnelConnectionName;SSHOptions;PuttySession;ConnectToConsole;UseCredSsp;UseVmId;UseEnhancedMode;RenderingEngine;RDPAuthenticationLevel;" +
|
sb.Append("Hostname;Port;VmId;Protocol;SSHTunnelConnectionName;OpeningCommand;SSHOptions;PuttySession;ConnectToConsole;UseCredSsp;UseVmId;UseEnhancedMode;RenderingEngine;RDPAuthenticationLevel;" +
|
||||||
"LoadBalanceInfo;Colors;Resolution;AutomaticResize;DisplayWallpaper;DisplayThemes;EnableFontSmoothing;EnableDesktopComposition;DisableFullWindowDrag;DisableMenuAnimations;DisableCursorShadow;DisableCursorBlinking;" +
|
"LoadBalanceInfo;Colors;Resolution;AutomaticResize;DisplayWallpaper;DisplayThemes;EnableFontSmoothing;EnableDesktopComposition;DisableFullWindowDrag;DisableMenuAnimations;DisableCursorShadow;DisableCursorBlinking;" +
|
||||||
"CacheBitmaps;RedirectDiskDrives;RedirectPorts;RedirectPrinters;RedirectClipboard;RedirectSmartCards;RedirectSound;RedirectKeys;" +
|
"CacheBitmaps;RedirectDiskDrives;RedirectPorts;RedirectPrinters;RedirectClipboard;RedirectSmartCards;RedirectSound;RedirectKeys;" +
|
||||||
"PreExtApp;PostExtApp;MacAddress;UserField;ExtApp;Favorite;VNCCompression;VNCEncoding;VNCAuthMode;VNCProxyType;VNCProxyIP;" +
|
"PreExtApp;PostExtApp;MacAddress;UserField;ExtApp;Favorite;VNCCompression;VNCEncoding;VNCAuthMode;VNCProxyType;VNCProxyIP;" +
|
||||||
"VNCProxyPort;VNCProxyUsername;VNCProxyPassword;VNCColors;VNCSmartSizeMode;VNCViewOnly;RDGatewayUsageMethod;RDGatewayHostname;" +
|
"VNCProxyPort;VNCProxyUsername;VNCProxyPassword;VNCColors;VNCSmartSizeMode;VNCViewOnly;RDGatewayUsageMethod;RDGatewayHostname;" +
|
||||||
"RDGatewayUseConnectionCredentials;RDGatewayUsername;RDGatewayPassword;RDGatewayDomain;RedirectAudioCapture;RdpVersion;");
|
"RDGatewayUseConnectionCredentials;RDGatewayUsername;RDGatewayPassword;RDGatewayDomain;RedirectAudioCapture;RdpVersion;RDPStartProgram;RDPStartProgramWorkDir;UserViaAPI;EC2InstanceId;EC2Region;");
|
||||||
|
|
||||||
if (_saveFilter.SaveInheritance)
|
if (_saveFilter.SaveInheritance)
|
||||||
sb.Append("InheritCacheBitmaps;InheritColors;InheritDescription;InheritDisplayThemes;InheritDisplayWallpaper;" +
|
sb.Append("InheritCacheBitmaps;InheritColors;InheritDescription;InheritDisplayThemes;InheritDisplayWallpaper;" +
|
||||||
"InheritEnableFontSmoothing;InheritEnableDesktopComposition;InheritDisableFullWindowDrag;InheritDisableMenuAnimations;InheritDisableCursorShadow;InheritDisableCursorBlinking;InheritDomain;InheritIcon;InheritPanel;InheritPassword;InheritPort;" +
|
"InheritEnableFontSmoothing;InheritEnableDesktopComposition;InheritDisableFullWindowDrag;InheritDisableMenuAnimations;InheritDisableCursorShadow;InheritDisableCursorBlinking;InheritDomain;InheritIcon;InheritPanel;InheritPassword;InheritPort;" +
|
||||||
"InheritProtocol;InheritSSHTunnelConnectionName;InheritSSHOptions;InheritPuttySession;InheritRedirectDiskDrives;InheritRedirectKeys;InheritRedirectPorts;InheritRedirectPrinters;" +
|
"InheritProtocol;InheritSSHTunnelConnectionName;InheritOpeningCommand;InheritSSHOptions;InheritPuttySession;InheritRedirectDiskDrives;InheritRedirectKeys;InheritRedirectPorts;InheritRedirectPrinters;" +
|
||||||
"InheritRedirectClipboard;InheritRedirectSmartCards;InheritRedirectSound;InheritResolution;InheritAutomaticResize;" +
|
"InheritRedirectClipboard;InheritRedirectSmartCards;InheritRedirectSound;InheritResolution;InheritAutomaticResize;" +
|
||||||
"InheritUseConsoleSession;InheritUseCredSsp;InheritUseVmId;InheritUseEnhancedMode;InheritVmId;InheritRenderingEngine;InheritUsername;" +
|
"InheritUseConsoleSession;InheritUseCredSsp;InheritUseVmId;InheritUseEnhancedMode;InheritVmId;InheritRenderingEngine;InheritUsername;" +
|
||||||
"InheritRDPAuthenticationLevel;InheritLoadBalanceInfo;InheritPreExtApp;InheritPostExtApp;InheritMacAddress;InheritUserField;" +
|
"InheritRDPAuthenticationLevel;InheritLoadBalanceInfo;InheritPreExtApp;InheritPostExtApp;InheritMacAddress;InheritUserField;" +
|
||||||
"InheritFavorite;InheritExtApp;InheritVNCCompression;InheritVNCEncoding;InheritVNCAuthMode;InheritVNCProxyType;InheritVNCProxyIP;" +
|
"InheritFavorite;InheritExtApp;InheritVNCCompression;InheritVNCEncoding;InheritVNCAuthMode;InheritVNCProxyType;InheritVNCProxyIP;" +
|
||||||
"InheritVNCProxyPort;InheritVNCProxyUsername;InheritVNCProxyPassword;InheritVNCColors;InheritVNCSmartSizeMode;InheritVNCViewOnly;" +
|
"InheritVNCProxyPort;InheritVNCProxyUsername;InheritVNCProxyPassword;InheritVNCColors;InheritVNCSmartSizeMode;InheritVNCViewOnly;" +
|
||||||
"InheritRDGatewayUsageMethod;InheritRDGatewayHostname;InheritRDGatewayUseConnectionCredentials;InheritRDGatewayUsername;" +
|
"InheritRDGatewayUsageMethod;InheritRDGatewayHostname;InheritRDGatewayUseConnectionCredentials;InheritRDGatewayUsername;" +
|
||||||
"InheritRDGatewayPassword;InheritRDGatewayDomain;InheritRDPAlertIdleTimeout;InheritRDPMinutesToIdleTimeout;InheritSoundQuality;" +
|
"InheritRDGatewayPassword;InheritRDGatewayDomain;InheritRDPAlertIdleTimeout;InheritRDPMinutesToIdleTimeout;InheritSoundQuality;InheritUserViaAPI;" +
|
||||||
"InheritRedirectAudioCapture;InheritRdpVersion");
|
"InheritRedirectAudioCapture;InheritRdpVersion");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SerializeNodesRecursive(ConnectionInfo node, StringBuilder sb)
|
private void SerializeNodesRecursive(ConnectionInfo node, StringBuilder sb)
|
||||||
{
|
{
|
||||||
var nodeAsContainer = node as ContainerInfo;
|
var nodeAsContainer = node as ContainerInfo;
|
||||||
if (nodeAsContainer != null)
|
if (nodeAsContainer != null)
|
||||||
{
|
{
|
||||||
foreach (var child in nodeAsContainer.Children)
|
foreach (var child in nodeAsContainer.Children)
|
||||||
{
|
{
|
||||||
SerializeNodesRecursive(child, sb);
|
SerializeNodesRecursive(child, sb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// dont serialize the root node
|
// dont serialize the root node
|
||||||
if (node is RootNodeInfo)
|
if (node is RootNodeInfo)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
SerializeConnectionInfo(node, sb);
|
SerializeConnectionInfo(node, sb);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SerializeConnectionInfo(ConnectionInfo con, StringBuilder sb)
|
private void SerializeConnectionInfo(ConnectionInfo con, StringBuilder sb)
|
||||||
{
|
{
|
||||||
sb.AppendLine();
|
sb.AppendLine();
|
||||||
sb.Append(FormatForCsv(con.Name))
|
sb.Append(FormatForCsv(con.Name))
|
||||||
.Append(FormatForCsv(con.ConstantID))
|
.Append(FormatForCsv(con.ConstantID))
|
||||||
.Append(FormatForCsv(con.Parent?.ConstantID ?? ""))
|
.Append(FormatForCsv(con.Parent?.ConstantID ?? ""))
|
||||||
.Append(FormatForCsv(con.GetTreeNodeType()))
|
.Append(FormatForCsv(con.GetTreeNodeType()))
|
||||||
.Append(FormatForCsv(con.Description))
|
.Append(FormatForCsv(con.Description))
|
||||||
.Append(FormatForCsv(con.Icon))
|
.Append(FormatForCsv(con.Icon))
|
||||||
.Append(FormatForCsv(con.Panel));
|
.Append(FormatForCsv(con.Panel));
|
||||||
|
|
||||||
if (_saveFilter.SaveUsername)
|
if (_saveFilter.SaveUsername)
|
||||||
sb.Append(FormatForCsv(con.Username));
|
sb.Append(FormatForCsv(con.Username));
|
||||||
|
|
||||||
if (_saveFilter.SavePassword)
|
if (_saveFilter.SavePassword)
|
||||||
sb.Append(FormatForCsv(con.Password));
|
sb.Append(FormatForCsv(con.Password));
|
||||||
|
|
||||||
if (_saveFilter.SaveDomain)
|
if (_saveFilter.SaveDomain)
|
||||||
sb.Append(FormatForCsv(con.Domain));
|
sb.Append(FormatForCsv(con.Domain));
|
||||||
|
|
||||||
sb.Append(FormatForCsv(con.Hostname))
|
sb.Append(FormatForCsv(con.Hostname))
|
||||||
.Append(FormatForCsv(con.Port))
|
.Append(FormatForCsv(con.Port))
|
||||||
.Append(FormatForCsv(con.VmId))
|
.Append(FormatForCsv(con.VmId))
|
||||||
.Append(FormatForCsv(con.Protocol))
|
.Append(FormatForCsv(con.Protocol))
|
||||||
.Append(FormatForCsv(con.SSHTunnelConnectionName))
|
.Append(FormatForCsv(con.SSHTunnelConnectionName))
|
||||||
.Append(FormatForCsv(con.SSHOptions))
|
.Append(FormatForCsv(con.OpeningCommand))
|
||||||
.Append(FormatForCsv(con.PuttySession))
|
.Append(FormatForCsv(con.SSHOptions))
|
||||||
.Append(FormatForCsv(con.UseConsoleSession))
|
.Append(FormatForCsv(con.PuttySession))
|
||||||
.Append(FormatForCsv(con.UseCredSsp))
|
.Append(FormatForCsv(con.UseConsoleSession))
|
||||||
.Append(FormatForCsv(con.UseVmId))
|
.Append(FormatForCsv(con.UseCredSsp))
|
||||||
.Append(FormatForCsv(con.UseEnhancedMode))
|
.Append(FormatForCsv(con.UseVmId))
|
||||||
.Append(FormatForCsv(con.RenderingEngine))
|
.Append(FormatForCsv(con.UseEnhancedMode))
|
||||||
.Append(FormatForCsv(con.RDPAuthenticationLevel))
|
.Append(FormatForCsv(con.RenderingEngine))
|
||||||
.Append(FormatForCsv(con.LoadBalanceInfo))
|
.Append(FormatForCsv(con.RDPAuthenticationLevel))
|
||||||
.Append(FormatForCsv(con.Colors))
|
.Append(FormatForCsv(con.LoadBalanceInfo))
|
||||||
.Append(FormatForCsv(con.Resolution))
|
.Append(FormatForCsv(con.Colors))
|
||||||
.Append(FormatForCsv(con.AutomaticResize))
|
.Append(FormatForCsv(con.Resolution))
|
||||||
.Append(FormatForCsv(con.DisplayWallpaper))
|
.Append(FormatForCsv(con.AutomaticResize))
|
||||||
.Append(FormatForCsv(con.DisplayThemes))
|
.Append(FormatForCsv(con.DisplayWallpaper))
|
||||||
.Append(FormatForCsv(con.EnableFontSmoothing))
|
.Append(FormatForCsv(con.DisplayThemes))
|
||||||
.Append(FormatForCsv(con.EnableDesktopComposition))
|
.Append(FormatForCsv(con.EnableFontSmoothing))
|
||||||
.Append(FormatForCsv(con.DisableFullWindowDrag))
|
.Append(FormatForCsv(con.EnableDesktopComposition))
|
||||||
.Append(FormatForCsv(con.DisableMenuAnimations))
|
.Append(FormatForCsv(con.DisableFullWindowDrag))
|
||||||
.Append(FormatForCsv(con.DisableCursorShadow))
|
.Append(FormatForCsv(con.DisableMenuAnimations))
|
||||||
.Append(FormatForCsv(con.DisableCursorBlinking))
|
.Append(FormatForCsv(con.DisableCursorShadow))
|
||||||
.Append(FormatForCsv(con.CacheBitmaps))
|
.Append(FormatForCsv(con.DisableCursorBlinking))
|
||||||
.Append(FormatForCsv(con.RedirectDiskDrives))
|
.Append(FormatForCsv(con.CacheBitmaps))
|
||||||
.Append(FormatForCsv(con.RedirectPorts))
|
.Append(FormatForCsv(con.RedirectDiskDrives))
|
||||||
.Append(FormatForCsv(con.RedirectPrinters))
|
.Append(FormatForCsv(con.RedirectPorts))
|
||||||
.Append(FormatForCsv(con.RedirectClipboard))
|
.Append(FormatForCsv(con.RedirectPrinters))
|
||||||
.Append(FormatForCsv(con.RedirectSmartCards))
|
.Append(FormatForCsv(con.RedirectClipboard))
|
||||||
.Append(FormatForCsv(con.RedirectSound))
|
.Append(FormatForCsv(con.RedirectSmartCards))
|
||||||
.Append(FormatForCsv(con.RedirectKeys))
|
.Append(FormatForCsv(con.RedirectSound))
|
||||||
.Append(FormatForCsv(con.PreExtApp))
|
.Append(FormatForCsv(con.RedirectKeys))
|
||||||
.Append(FormatForCsv(con.PostExtApp))
|
.Append(FormatForCsv(con.PreExtApp))
|
||||||
.Append(FormatForCsv(con.MacAddress))
|
.Append(FormatForCsv(con.PostExtApp))
|
||||||
.Append(FormatForCsv(con.UserField))
|
.Append(FormatForCsv(con.MacAddress))
|
||||||
.Append(FormatForCsv(con.ExtApp))
|
.Append(FormatForCsv(con.UserField))
|
||||||
.Append(FormatForCsv(con.Favorite))
|
.Append(FormatForCsv(con.ExtApp))
|
||||||
.Append(FormatForCsv(con.VNCCompression))
|
.Append(FormatForCsv(con.Favorite))
|
||||||
.Append(FormatForCsv(con.VNCEncoding))
|
.Append(FormatForCsv(con.VNCCompression))
|
||||||
.Append(FormatForCsv(con.VNCAuthMode))
|
.Append(FormatForCsv(con.VNCEncoding))
|
||||||
.Append(FormatForCsv(con.VNCProxyType))
|
.Append(FormatForCsv(con.VNCAuthMode))
|
||||||
.Append(FormatForCsv(con.VNCProxyIP))
|
.Append(FormatForCsv(con.VNCProxyType))
|
||||||
.Append(FormatForCsv(con.VNCProxyPort))
|
.Append(FormatForCsv(con.VNCProxyIP))
|
||||||
.Append(FormatForCsv(con.VNCProxyUsername))
|
.Append(FormatForCsv(con.VNCProxyPort))
|
||||||
.Append(FormatForCsv(con.VNCProxyPassword))
|
.Append(FormatForCsv(con.VNCProxyUsername))
|
||||||
.Append(FormatForCsv(con.VNCColors))
|
.Append(FormatForCsv(con.VNCProxyPassword))
|
||||||
.Append(FormatForCsv(con.VNCSmartSizeMode))
|
.Append(FormatForCsv(con.VNCColors))
|
||||||
.Append(FormatForCsv(con.VNCViewOnly))
|
.Append(FormatForCsv(con.VNCSmartSizeMode))
|
||||||
.Append(FormatForCsv(con.RDGatewayUsageMethod))
|
.Append(FormatForCsv(con.VNCViewOnly))
|
||||||
.Append(FormatForCsv(con.RDGatewayHostname))
|
.Append(FormatForCsv(con.RDGatewayUsageMethod))
|
||||||
.Append(FormatForCsv(con.RDGatewayUseConnectionCredentials))
|
.Append(FormatForCsv(con.RDGatewayHostname))
|
||||||
.Append(FormatForCsv(con.RDGatewayUsername))
|
.Append(FormatForCsv(con.RDGatewayUseConnectionCredentials))
|
||||||
.Append(FormatForCsv(con.RDGatewayPassword))
|
.Append(FormatForCsv(con.RDGatewayUsername))
|
||||||
.Append(FormatForCsv(con.RDGatewayDomain))
|
.Append(FormatForCsv(con.RDGatewayPassword))
|
||||||
.Append(FormatForCsv(con.RedirectAudioCapture))
|
.Append(FormatForCsv(con.RDGatewayDomain))
|
||||||
.Append(FormatForCsv(con.RdpVersion));
|
.Append(FormatForCsv(con.RedirectAudioCapture))
|
||||||
|
.Append(FormatForCsv(con.RdpVersion))
|
||||||
|
.Append(FormatForCsv(con.RDPStartProgram))
|
||||||
if (!_saveFilter.SaveInheritance)
|
.Append(FormatForCsv(con.RDPStartProgramWorkDir))
|
||||||
return;
|
.Append(FormatForCsv(con.UserViaAPI))
|
||||||
|
.Append(FormatForCsv(con.EC2InstanceId))
|
||||||
sb.Append(FormatForCsv(con.Inheritance.CacheBitmaps))
|
.Append(FormatForCsv(con.EC2Region));
|
||||||
.Append(FormatForCsv(con.Inheritance.Colors))
|
|
||||||
.Append(FormatForCsv(con.Inheritance.Description))
|
|
||||||
.Append(FormatForCsv(con.Inheritance.DisplayThemes))
|
if (!_saveFilter.SaveInheritance)
|
||||||
.Append(FormatForCsv(con.Inheritance.DisplayWallpaper))
|
return;
|
||||||
.Append(FormatForCsv(con.Inheritance.EnableFontSmoothing))
|
|
||||||
.Append(FormatForCsv(con.Inheritance.EnableDesktopComposition))
|
sb.Append(FormatForCsv(con.Inheritance.CacheBitmaps))
|
||||||
.Append(FormatForCsv(con.Inheritance.DisableFullWindowDrag))
|
.Append(FormatForCsv(con.Inheritance.Colors))
|
||||||
.Append(FormatForCsv(con.Inheritance.DisableMenuAnimations))
|
.Append(FormatForCsv(con.Inheritance.Description))
|
||||||
.Append(FormatForCsv(con.Inheritance.DisableCursorShadow))
|
.Append(FormatForCsv(con.Inheritance.DisplayThemes))
|
||||||
.Append(FormatForCsv(con.Inheritance.DisableCursorBlinking))
|
.Append(FormatForCsv(con.Inheritance.DisplayWallpaper))
|
||||||
.Append(FormatForCsv(con.Inheritance.Domain))
|
.Append(FormatForCsv(con.Inheritance.EnableFontSmoothing))
|
||||||
.Append(FormatForCsv(con.Inheritance.Icon))
|
.Append(FormatForCsv(con.Inheritance.EnableDesktopComposition))
|
||||||
.Append(FormatForCsv(con.Inheritance.Panel))
|
.Append(FormatForCsv(con.Inheritance.DisableFullWindowDrag))
|
||||||
.Append(FormatForCsv(con.Inheritance.Password))
|
.Append(FormatForCsv(con.Inheritance.DisableMenuAnimations))
|
||||||
.Append(FormatForCsv(con.Inheritance.Port))
|
.Append(FormatForCsv(con.Inheritance.DisableCursorShadow))
|
||||||
.Append(FormatForCsv(con.Inheritance.Protocol))
|
.Append(FormatForCsv(con.Inheritance.DisableCursorBlinking))
|
||||||
.Append(FormatForCsv(con.Inheritance.SSHTunnelConnectionName))
|
.Append(FormatForCsv(con.Inheritance.Domain))
|
||||||
.Append(FormatForCsv(con.Inheritance.SSHOptions))
|
.Append(FormatForCsv(con.Inheritance.Icon))
|
||||||
.Append(FormatForCsv(con.Inheritance.PuttySession))
|
.Append(FormatForCsv(con.Inheritance.Panel))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectDiskDrives))
|
.Append(FormatForCsv(con.Inheritance.Password))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectKeys))
|
.Append(FormatForCsv(con.Inheritance.Port))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectPorts))
|
.Append(FormatForCsv(con.Inheritance.Protocol))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectPrinters))
|
.Append(FormatForCsv(con.Inheritance.SSHTunnelConnectionName))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectClipboard))
|
.Append(FormatForCsv(con.Inheritance.OpeningCommand))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectSmartCards))
|
.Append(FormatForCsv(con.Inheritance.SSHOptions))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectSound))
|
.Append(FormatForCsv(con.Inheritance.PuttySession))
|
||||||
.Append(FormatForCsv(con.Inheritance.Resolution))
|
.Append(FormatForCsv(con.Inheritance.RedirectDiskDrives))
|
||||||
.Append(FormatForCsv(con.Inheritance.AutomaticResize))
|
.Append(FormatForCsv(con.Inheritance.RedirectKeys))
|
||||||
.Append(FormatForCsv(con.Inheritance.UseConsoleSession))
|
.Append(FormatForCsv(con.Inheritance.RedirectPorts))
|
||||||
.Append(FormatForCsv(con.Inheritance.UseCredSsp))
|
.Append(FormatForCsv(con.Inheritance.RedirectPrinters))
|
||||||
.Append(FormatForCsv(con.Inheritance.UseVmId))
|
.Append(FormatForCsv(con.Inheritance.RedirectClipboard))
|
||||||
.Append(FormatForCsv(con.Inheritance.UseEnhancedMode))
|
.Append(FormatForCsv(con.Inheritance.RedirectSmartCards))
|
||||||
.Append(FormatForCsv(con.Inheritance.VmId))
|
.Append(FormatForCsv(con.Inheritance.RedirectSound))
|
||||||
.Append(FormatForCsv(con.Inheritance.RenderingEngine))
|
.Append(FormatForCsv(con.Inheritance.Resolution))
|
||||||
.Append(FormatForCsv(con.Inheritance.Username))
|
.Append(FormatForCsv(con.Inheritance.AutomaticResize))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDPAuthenticationLevel))
|
.Append(FormatForCsv(con.Inheritance.UseConsoleSession))
|
||||||
.Append(FormatForCsv(con.Inheritance.LoadBalanceInfo))
|
.Append(FormatForCsv(con.Inheritance.UseCredSsp))
|
||||||
.Append(FormatForCsv(con.Inheritance.PreExtApp))
|
.Append(FormatForCsv(con.Inheritance.UseVmId))
|
||||||
.Append(FormatForCsv(con.Inheritance.PostExtApp))
|
.Append(FormatForCsv(con.Inheritance.UseEnhancedMode))
|
||||||
.Append(FormatForCsv(con.Inheritance.MacAddress))
|
.Append(FormatForCsv(con.Inheritance.VmId))
|
||||||
.Append(FormatForCsv(con.Inheritance.UserField))
|
.Append(FormatForCsv(con.Inheritance.RenderingEngine))
|
||||||
.Append(FormatForCsv(con.Inheritance.Favorite))
|
.Append(FormatForCsv(con.Inheritance.Username))
|
||||||
.Append(FormatForCsv(con.Inheritance.ExtApp))
|
.Append(FormatForCsv(con.Inheritance.RDPAuthenticationLevel))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCCompression))
|
.Append(FormatForCsv(con.Inheritance.LoadBalanceInfo))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCEncoding))
|
.Append(FormatForCsv(con.Inheritance.PreExtApp))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCAuthMode))
|
.Append(FormatForCsv(con.Inheritance.PostExtApp))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCProxyType))
|
.Append(FormatForCsv(con.Inheritance.MacAddress))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCProxyIP))
|
.Append(FormatForCsv(con.Inheritance.UserField))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCProxyPort))
|
.Append(FormatForCsv(con.Inheritance.Favorite))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCProxyUsername))
|
.Append(FormatForCsv(con.Inheritance.ExtApp))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCProxyPassword))
|
.Append(FormatForCsv(con.Inheritance.VNCCompression))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCColors))
|
.Append(FormatForCsv(con.Inheritance.VNCEncoding))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCSmartSizeMode))
|
.Append(FormatForCsv(con.Inheritance.VNCAuthMode))
|
||||||
.Append(FormatForCsv(con.Inheritance.VNCViewOnly))
|
.Append(FormatForCsv(con.Inheritance.VNCProxyType))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayUsageMethod))
|
.Append(FormatForCsv(con.Inheritance.VNCProxyIP))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayHostname))
|
.Append(FormatForCsv(con.Inheritance.VNCProxyPort))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayUseConnectionCredentials))
|
.Append(FormatForCsv(con.Inheritance.VNCProxyUsername))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayUsername))
|
.Append(FormatForCsv(con.Inheritance.VNCProxyPassword))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayPassword))
|
.Append(FormatForCsv(con.Inheritance.VNCColors))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDGatewayDomain))
|
.Append(FormatForCsv(con.Inheritance.VNCSmartSizeMode))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDPAlertIdleTimeout))
|
.Append(FormatForCsv(con.Inheritance.VNCViewOnly))
|
||||||
.Append(FormatForCsv(con.Inheritance.RDPMinutesToIdleTimeout))
|
.Append(FormatForCsv(con.Inheritance.RDGatewayUsageMethod))
|
||||||
.Append(FormatForCsv(con.Inheritance.SoundQuality))
|
.Append(FormatForCsv(con.Inheritance.RDGatewayHostname))
|
||||||
.Append(FormatForCsv(con.Inheritance.RedirectAudioCapture))
|
.Append(FormatForCsv(con.Inheritance.RDGatewayUseConnectionCredentials))
|
||||||
.Append(FormatForCsv(con.Inheritance.RdpVersion));
|
.Append(FormatForCsv(con.Inheritance.RDGatewayUsername))
|
||||||
}
|
.Append(FormatForCsv(con.Inheritance.RDGatewayPassword))
|
||||||
|
.Append(FormatForCsv(con.Inheritance.RDGatewayDomain))
|
||||||
private string FormatForCsv(object value)
|
.Append(FormatForCsv(con.Inheritance.RDPAlertIdleTimeout))
|
||||||
{
|
.Append(FormatForCsv(con.Inheritance.RDPMinutesToIdleTimeout))
|
||||||
var cleanedString = value.ToString().Replace(";", "");
|
.Append(FormatForCsv(con.Inheritance.SoundQuality))
|
||||||
return cleanedString + ";";
|
.Append(FormatForCsv(con.Inheritance.RedirectAudioCapture))
|
||||||
}
|
.Append(FormatForCsv(con.Inheritance.RdpVersion))
|
||||||
}
|
.Append(FormatForCsv(con.Inheritance.UserViaAPI));
|
||||||
|
}
|
||||||
|
|
||||||
|
private string FormatForCsv(object value)
|
||||||
|
{
|
||||||
|
var cleanedString = value.ToString().Replace(";", "");
|
||||||
|
return cleanedString + ";";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,278 +1,263 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Data;
|
using System.Data;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Security;
|
using System.Security;
|
||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Connection.Protocol.Http;
|
using mRemoteNG.Connection.Protocol.Http;
|
||||||
using mRemoteNG.Connection.Protocol.RDP;
|
using mRemoteNG.Connection.Protocol.RDP;
|
||||||
using mRemoteNG.Connection.Protocol.VNC;
|
using mRemoteNG.Connection.Protocol.VNC;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Security;
|
using mRemoteNG.Security;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Serializers.ConnectionSerializers.MsSql
|
namespace mRemoteNG.Config.Serializers.ConnectionSerializers.MsSql
|
||||||
{
|
{
|
||||||
public class DataTableDeserializer : IDeserializer<DataTable, ConnectionTreeModel>
|
public class DataTableDeserializer : IDeserializer<DataTable, ConnectionTreeModel>
|
||||||
{
|
{
|
||||||
private readonly ICryptographyProvider _cryptographyProvider;
|
private readonly ICryptographyProvider _cryptographyProvider;
|
||||||
private readonly SecureString _decryptionKey;
|
private readonly SecureString _decryptionKey;
|
||||||
|
|
||||||
public DataTableDeserializer(ICryptographyProvider cryptographyProvider, SecureString decryptionKey)
|
public DataTableDeserializer(ICryptographyProvider cryptographyProvider, SecureString decryptionKey)
|
||||||
{
|
{
|
||||||
_cryptographyProvider = cryptographyProvider.ThrowIfNull(nameof(cryptographyProvider));
|
_cryptographyProvider = cryptographyProvider.ThrowIfNull(nameof(cryptographyProvider));
|
||||||
_decryptionKey = decryptionKey.ThrowIfNull(nameof(decryptionKey));
|
_decryptionKey = decryptionKey.ThrowIfNull(nameof(decryptionKey));
|
||||||
}
|
}
|
||||||
|
|
||||||
public ConnectionTreeModel Deserialize(DataTable table)
|
public ConnectionTreeModel Deserialize(DataTable table)
|
||||||
{
|
{
|
||||||
var connectionList = CreateNodesFromTable(table);
|
var connectionList = CreateNodesFromTable(table);
|
||||||
var connectionTreeModel = CreateNodeHierarchy(connectionList, table);
|
var connectionTreeModel = CreateNodeHierarchy(connectionList, table);
|
||||||
Runtime.ConnectionsService.IsConnectionsFileLoaded = true;
|
Runtime.ConnectionsService.IsConnectionsFileLoaded = true;
|
||||||
return connectionTreeModel;
|
return connectionTreeModel;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ConnectionInfo> CreateNodesFromTable(DataTable table)
|
private List<ConnectionInfo> CreateNodesFromTable(DataTable table)
|
||||||
{
|
{
|
||||||
var nodeList = new List<ConnectionInfo>();
|
var nodeList = new List<ConnectionInfo>();
|
||||||
foreach (DataRow row in table.Rows)
|
foreach (DataRow row in table.Rows)
|
||||||
{
|
{
|
||||||
// ReSharper disable once SwitchStatementMissingSomeCases
|
// ReSharper disable once SwitchStatementMissingSomeCases
|
||||||
switch ((string)row["Type"])
|
switch ((string)row["Type"])
|
||||||
{
|
{
|
||||||
case "Connection":
|
case "Connection":
|
||||||
nodeList.Add(DeserializeConnectionInfo(row));
|
nodeList.Add(DeserializeConnectionInfo(row));
|
||||||
break;
|
break;
|
||||||
case "Container":
|
case "Container":
|
||||||
nodeList.Add(DeserializeContainerInfo(row));
|
nodeList.Add(DeserializeContainerInfo(row));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nodeList;
|
return nodeList;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ConnectionInfo DeserializeConnectionInfo(DataRow row)
|
private ConnectionInfo DeserializeConnectionInfo(DataRow row)
|
||||||
{
|
{
|
||||||
var connectionId = row["ConstantID"] as string ?? Guid.NewGuid().ToString();
|
var connectionId = row["ConstantID"] as string ?? Guid.NewGuid().ToString();
|
||||||
var connectionInfo = new ConnectionInfo(connectionId);
|
var connectionInfo = new ConnectionInfo(connectionId);
|
||||||
PopulateConnectionInfoFromDatarow(row, connectionInfo);
|
PopulateConnectionInfoFromDatarow(row, connectionInfo);
|
||||||
return connectionInfo;
|
return connectionInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ContainerInfo DeserializeContainerInfo(DataRow row)
|
private ContainerInfo DeserializeContainerInfo(DataRow row)
|
||||||
{
|
{
|
||||||
var containerId = row["ConstantID"] as string ?? Guid.NewGuid().ToString();
|
var containerId = row["ConstantID"] as string ?? Guid.NewGuid().ToString();
|
||||||
var containerInfo = new ContainerInfo(containerId);
|
var containerInfo = new ContainerInfo(containerId);
|
||||||
PopulateConnectionInfoFromDatarow(row, containerInfo);
|
PopulateConnectionInfoFromDatarow(row, containerInfo);
|
||||||
return containerInfo;
|
return containerInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void PopulateConnectionInfoFromDatarow(DataRow dataRow, ConnectionInfo connectionInfo)
|
private void PopulateConnectionInfoFromDatarow(DataRow dataRow, ConnectionInfo connectionInfo)
|
||||||
{
|
{
|
||||||
connectionInfo.Name = (string)dataRow["Name"];
|
connectionInfo.Name = (string)dataRow["Name"];
|
||||||
|
|
||||||
// This throws a NPE - Parent is a connectionInfo object which will be null at this point.
|
// This throws a NPE - Parent is a connectionInfo object which will be null at this point.
|
||||||
// The Parent object is linked properly later in CreateNodeHierarchy()
|
// The Parent object is linked properly later in CreateNodeHierarchy()
|
||||||
//connectionInfo.Parent.ConstantID = (string)dataRow["ParentID"];
|
//connectionInfo.Parent.ConstantID = (string)dataRow["ParentID"];
|
||||||
|
|
||||||
connectionInfo.Description = (string)dataRow["Description"];
|
connectionInfo.Description = (string)dataRow["Description"];
|
||||||
connectionInfo.Icon = (string)dataRow["Icon"];
|
connectionInfo.Icon = (string)dataRow["Icon"];
|
||||||
connectionInfo.Panel = (string)dataRow["Panel"];
|
connectionInfo.Panel = (string)dataRow["Panel"];
|
||||||
connectionInfo.Username = (string)dataRow["Username"];
|
connectionInfo.Username = (string)dataRow["Username"];
|
||||||
connectionInfo.Domain = (string)dataRow["Domain"];
|
connectionInfo.Domain = (string)dataRow["Domain"];
|
||||||
connectionInfo.Password = DecryptValue((string)dataRow["Password"]);
|
connectionInfo.Password = DecryptValue((string)dataRow["Password"]);
|
||||||
connectionInfo.Hostname = (string)dataRow["Hostname"];
|
connectionInfo.Hostname = (string)dataRow["Hostname"];
|
||||||
connectionInfo.VmId = (string)dataRow["VmId"];
|
connectionInfo.VmId = (string)dataRow["VmId"];
|
||||||
connectionInfo.UseEnhancedMode = (bool)dataRow["UseEnhancedMode"];
|
connectionInfo.UseEnhancedMode = (bool)dataRow["UseEnhancedMode"];
|
||||||
connectionInfo.Protocol = (ProtocolType)Enum.Parse(typeof(ProtocolType), (string)dataRow["Protocol"]);
|
connectionInfo.Protocol = (ProtocolType)Enum.Parse(typeof(ProtocolType), (string)dataRow["Protocol"]);
|
||||||
connectionInfo.SSHTunnelConnectionName = (string)dataRow["SSHTunnelConnectionName"];
|
connectionInfo.SSHTunnelConnectionName = (string)dataRow["SSHTunnelConnectionName"];
|
||||||
connectionInfo.SSHOptions = (string)dataRow["SSHOptions"];
|
connectionInfo.OpeningCommand = (string)dataRow["OpeningCommand"];
|
||||||
connectionInfo.PuttySession = (string)dataRow["PuttySession"];
|
connectionInfo.SSHOptions = (string)dataRow["SSHOptions"];
|
||||||
connectionInfo.Port = (int)dataRow["Port"];
|
connectionInfo.PuttySession = (string)dataRow["PuttySession"];
|
||||||
connectionInfo.UseConsoleSession = (bool)dataRow["ConnectToConsole"];
|
connectionInfo.Port = (int)dataRow["Port"];
|
||||||
connectionInfo.UseCredSsp = (bool)dataRow["UseCredSsp"];
|
connectionInfo.UseConsoleSession = (bool)dataRow["ConnectToConsole"];
|
||||||
connectionInfo.UseVmId = (bool)dataRow["UseVmId"];
|
connectionInfo.UseCredSsp = (bool)dataRow["UseCredSsp"];
|
||||||
connectionInfo.RenderingEngine = (HTTPBase.RenderingEngine)Enum.Parse(typeof(HTTPBase.RenderingEngine),
|
connectionInfo.UseVmId = (bool)dataRow["UseVmId"];
|
||||||
(string)dataRow["RenderingEngine"]);
|
connectionInfo.RenderingEngine = (HTTPBase.RenderingEngine)Enum.Parse(typeof(HTTPBase.RenderingEngine), (string)dataRow["RenderingEngine"]);
|
||||||
connectionInfo.RDPAuthenticationLevel =
|
connectionInfo.RDPAuthenticationLevel = (AuthenticationLevel)Enum.Parse(typeof(AuthenticationLevel), (string)dataRow["RDPAuthenticationLevel"]);
|
||||||
(AuthenticationLevel)Enum.Parse(typeof(AuthenticationLevel),
|
connectionInfo.RDPMinutesToIdleTimeout = (int)dataRow["RDPMinutesToIdleTimeout"];
|
||||||
(string)dataRow["RDPAuthenticationLevel"]);
|
connectionInfo.RDPAlertIdleTimeout = (bool)dataRow["RDPAlertIdleTimeout"];
|
||||||
connectionInfo.RDPMinutesToIdleTimeout = (int)dataRow["RDPMinutesToIdleTimeout"];
|
connectionInfo.LoadBalanceInfo = (string)dataRow["LoadBalanceInfo"];
|
||||||
connectionInfo.RDPAlertIdleTimeout = (bool)dataRow["RDPAlertIdleTimeout"];
|
connectionInfo.Colors = (RDPColors)Enum.Parse(typeof(RDPColors), (string)dataRow["Colors"]);
|
||||||
connectionInfo.LoadBalanceInfo = (string)dataRow["LoadBalanceInfo"];
|
connectionInfo.Resolution = (RDPResolutions)Enum.Parse(typeof(RDPResolutions), (string)dataRow["Resolution"]);
|
||||||
connectionInfo.Colors =
|
connectionInfo.AutomaticResize = (bool)dataRow["AutomaticResize"];
|
||||||
(RDPColors)Enum.Parse(typeof(RDPColors), (string)dataRow["Colors"]);
|
connectionInfo.DisplayWallpaper = (bool)dataRow["DisplayWallpaper"];
|
||||||
connectionInfo.Resolution =
|
connectionInfo.DisplayThemes = (bool)dataRow["DisplayThemes"];
|
||||||
(RDPResolutions)Enum.Parse(typeof(RDPResolutions),
|
connectionInfo.EnableFontSmoothing = (bool)dataRow["EnableFontSmoothing"];
|
||||||
(string)dataRow["Resolution"]);
|
connectionInfo.EnableDesktopComposition = (bool)dataRow["EnableDesktopComposition"];
|
||||||
connectionInfo.AutomaticResize = (bool)dataRow["AutomaticResize"];
|
connectionInfo.DisableFullWindowDrag = (bool)dataRow["DisableFullWindowDrag"];
|
||||||
connectionInfo.DisplayWallpaper = (bool)dataRow["DisplayWallpaper"];
|
connectionInfo.DisableMenuAnimations = (bool)dataRow["DisableMenuAnimations"];
|
||||||
connectionInfo.DisplayThemes = (bool)dataRow["DisplayThemes"];
|
connectionInfo.DisableCursorShadow = (bool)dataRow["DisableCursorShadow"];
|
||||||
connectionInfo.EnableFontSmoothing = (bool)dataRow["EnableFontSmoothing"];
|
connectionInfo.DisableCursorBlinking = (bool)dataRow["DisableCursorBlinking"];
|
||||||
connectionInfo.EnableDesktopComposition = (bool)dataRow["EnableDesktopComposition"];
|
connectionInfo.CacheBitmaps = (bool)dataRow["CacheBitmaps"];
|
||||||
connectionInfo.DisableFullWindowDrag = (bool)dataRow["DisableFullWindowDrag"];
|
connectionInfo.RedirectDiskDrives = (bool)dataRow["RedirectDiskDrives"];
|
||||||
connectionInfo.DisableMenuAnimations = (bool)dataRow["DisableMenuAnimations"];
|
connectionInfo.RedirectPorts = (bool)dataRow["RedirectPorts"];
|
||||||
connectionInfo.DisableCursorShadow = (bool)dataRow["DisableCursorShadow"];
|
connectionInfo.RedirectPrinters = (bool)dataRow["RedirectPrinters"];
|
||||||
connectionInfo.DisableCursorBlinking = (bool)dataRow["DisableCursorBlinking"];
|
connectionInfo.RedirectClipboard = (bool)dataRow["RedirectClipboard"];
|
||||||
connectionInfo.CacheBitmaps = (bool)dataRow["CacheBitmaps"];
|
connectionInfo.RedirectSmartCards = (bool)dataRow["RedirectSmartCards"];
|
||||||
connectionInfo.RedirectDiskDrives = (bool)dataRow["RedirectDiskDrives"];
|
connectionInfo.RedirectSound = (RDPSounds)Enum.Parse(typeof(RDPSounds), (string)dataRow["RedirectSound"]);
|
||||||
connectionInfo.RedirectPorts = (bool)dataRow["RedirectPorts"];
|
connectionInfo.SoundQuality = (RDPSoundQuality)Enum.Parse(typeof(RDPSoundQuality), (string)dataRow["SoundQuality"]);
|
||||||
connectionInfo.RedirectPrinters = (bool)dataRow["RedirectPrinters"];
|
connectionInfo.RedirectAudioCapture = (bool)dataRow["RedirectAudioCapture"];
|
||||||
connectionInfo.RedirectClipboard = (bool)dataRow["RedirectClipboard"];
|
connectionInfo.RDPStartProgram = (string)dataRow["StartProgram"];
|
||||||
connectionInfo.RedirectSmartCards = (bool)dataRow["RedirectSmartCards"];
|
connectionInfo.RDPStartProgramWorkDir = (string)dataRow["StartProgramWorkDir"];
|
||||||
connectionInfo.RedirectSound =
|
connectionInfo.RedirectKeys = (bool)dataRow["RedirectKeys"];
|
||||||
(RDPSounds)Enum.Parse(typeof(RDPSounds), (string)dataRow["RedirectSound"]);
|
connectionInfo.OpeningCommand = (string)dataRow["OpeningCommand"];
|
||||||
connectionInfo.SoundQuality = (RDPSoundQuality)Enum.Parse(typeof(RDPSoundQuality),
|
connectionInfo.PreExtApp = (string)dataRow["PreExtApp"];
|
||||||
(string)dataRow["SoundQuality"]);
|
connectionInfo.PostExtApp = (string)dataRow["PostExtApp"];
|
||||||
connectionInfo.RedirectAudioCapture = (bool)dataRow["RedirectAudioCapture"];
|
connectionInfo.MacAddress = (string)dataRow["MacAddress"];
|
||||||
|
connectionInfo.UserField = (string)dataRow["UserField"];
|
||||||
connectionInfo.RedirectKeys = (bool)dataRow["RedirectKeys"];
|
connectionInfo.ExtApp = (string)dataRow["ExtApp"];
|
||||||
connectionInfo.PreExtApp = (string)dataRow["PreExtApp"];
|
connectionInfo.VNCCompression = (ProtocolVNC.Compression)Enum.Parse(typeof(ProtocolVNC.Compression), (string)dataRow["VNCCompression"]);
|
||||||
connectionInfo.PostExtApp = (string)dataRow["PostExtApp"];
|
connectionInfo.VNCEncoding = (ProtocolVNC.Encoding)Enum.Parse(typeof(ProtocolVNC.Encoding), (string)dataRow["VNCEncoding"]);
|
||||||
connectionInfo.MacAddress = (string)dataRow["MacAddress"];
|
connectionInfo.VNCAuthMode = (ProtocolVNC.AuthMode)Enum.Parse(typeof(ProtocolVNC.AuthMode), (string)dataRow["VNCAuthMode"]);
|
||||||
connectionInfo.UserField = (string)dataRow["UserField"];
|
connectionInfo.VNCProxyType = (ProtocolVNC.ProxyType)Enum.Parse(typeof(ProtocolVNC.ProxyType), (string)dataRow["VNCProxyType"]);
|
||||||
connectionInfo.ExtApp = (string)dataRow["ExtApp"];
|
connectionInfo.VNCProxyIP = (string)dataRow["VNCProxyIP"];
|
||||||
connectionInfo.VNCCompression = (ProtocolVNC.Compression)Enum.Parse(typeof(ProtocolVNC.Compression),
|
connectionInfo.VNCProxyPort = (int)dataRow["VNCProxyPort"];
|
||||||
(string)dataRow["VNCCompression"]);
|
connectionInfo.VNCProxyUsername = (string)dataRow["VNCProxyUsername"];
|
||||||
connectionInfo.VNCEncoding =
|
connectionInfo.VNCProxyPassword = DecryptValue((string)dataRow["VNCProxyPassword"]);
|
||||||
(ProtocolVNC.Encoding)Enum.Parse(typeof(ProtocolVNC.Encoding), (string)dataRow["VNCEncoding"]);
|
connectionInfo.VNCColors = (ProtocolVNC.Colors)Enum.Parse(typeof(ProtocolVNC.Colors), (string)dataRow["VNCColors"]);
|
||||||
connectionInfo.VNCAuthMode =
|
connectionInfo.VNCSmartSizeMode = (ProtocolVNC.SmartSizeMode)Enum.Parse(typeof(ProtocolVNC.SmartSizeMode), (string)dataRow["VNCSmartSizeMode"]);
|
||||||
(ProtocolVNC.AuthMode)Enum.Parse(typeof(ProtocolVNC.AuthMode), (string)dataRow["VNCAuthMode"]);
|
connectionInfo.VNCViewOnly = (bool)dataRow["VNCViewOnly"];
|
||||||
connectionInfo.VNCProxyType =
|
connectionInfo.RDGatewayUsageMethod = (RDGatewayUsageMethod)Enum.Parse(typeof(RDGatewayUsageMethod), (string)dataRow["RDGatewayUsageMethod"]);
|
||||||
(ProtocolVNC.ProxyType)Enum.Parse(typeof(ProtocolVNC.ProxyType), (string)dataRow["VNCProxyType"]);
|
connectionInfo.RDGatewayHostname = (string)dataRow["RDGatewayHostname"];
|
||||||
connectionInfo.VNCProxyIP = (string)dataRow["VNCProxyIP"];
|
connectionInfo.RDGatewayUseConnectionCredentials = (RDGatewayUseConnectionCredentials)Enum.Parse(typeof(RDGatewayUseConnectionCredentials), (string)dataRow["RDGatewayUseConnectionCredentials"]);
|
||||||
connectionInfo.VNCProxyPort = (int)dataRow["VNCProxyPort"];
|
connectionInfo.RDGatewayUsername = (string)dataRow["RDGatewayUsername"];
|
||||||
connectionInfo.VNCProxyUsername = (string)dataRow["VNCProxyUsername"];
|
connectionInfo.RDGatewayPassword = DecryptValue((string)dataRow["RDGatewayPassword"]);
|
||||||
connectionInfo.VNCProxyPassword = DecryptValue((string)dataRow["VNCProxyPassword"]);
|
connectionInfo.RDGatewayDomain = (string)dataRow["RDGatewayDomain"];
|
||||||
connectionInfo.VNCColors =
|
|
||||||
(ProtocolVNC.Colors)Enum.Parse(typeof(ProtocolVNC.Colors), (string)dataRow["VNCColors"]);
|
if (!dataRow.IsNull("RdpVersion")) // table allows null values which must be handled
|
||||||
connectionInfo.VNCSmartSizeMode = (ProtocolVNC.SmartSizeMode)Enum.Parse(typeof(ProtocolVNC.SmartSizeMode),
|
if (Enum.TryParse((string)dataRow["RdpVersion"], true, out RdpVersion rdpVersion))
|
||||||
(string)dataRow
|
connectionInfo.RdpVersion = rdpVersion;
|
||||||
["VNCSmartSizeMode"]);
|
|
||||||
connectionInfo.VNCViewOnly = (bool)dataRow["VNCViewOnly"];
|
connectionInfo.Inheritance.CacheBitmaps = (bool)dataRow["InheritCacheBitmaps"];
|
||||||
connectionInfo.RDGatewayUsageMethod =
|
connectionInfo.Inheritance.Colors = (bool)dataRow["InheritColors"];
|
||||||
(RDGatewayUsageMethod)Enum.Parse(typeof(RDGatewayUsageMethod),
|
connectionInfo.Inheritance.Description = (bool)dataRow["InheritDescription"];
|
||||||
(string)dataRow["RDGatewayUsageMethod"]);
|
connectionInfo.Inheritance.DisplayThemes = (bool)dataRow["InheritDisplayThemes"];
|
||||||
connectionInfo.RDGatewayHostname = (string)dataRow["RDGatewayHostname"];
|
connectionInfo.Inheritance.DisplayWallpaper = (bool)dataRow["InheritDisplayWallpaper"];
|
||||||
connectionInfo.RDGatewayUseConnectionCredentials =
|
connectionInfo.Inheritance.EnableFontSmoothing = (bool)dataRow["InheritEnableFontSmoothing"];
|
||||||
(RDGatewayUseConnectionCredentials)Enum.Parse(typeof(RDGatewayUseConnectionCredentials),
|
connectionInfo.Inheritance.EnableDesktopComposition = (bool)dataRow["InheritEnableDesktopComposition"];
|
||||||
(string)dataRow["RDGatewayUseConnectionCredentials"]);
|
connectionInfo.Inheritance.DisableFullWindowDrag = (bool)dataRow["InheritDisableFullWindowDrag"];
|
||||||
connectionInfo.RDGatewayUsername = (string)dataRow["RDGatewayUsername"];
|
connectionInfo.Inheritance.DisableMenuAnimations = (bool)dataRow["InheritDisableMenuAnimations"];
|
||||||
connectionInfo.RDGatewayPassword = DecryptValue((string)dataRow["RDGatewayPassword"]);
|
connectionInfo.Inheritance.DisableCursorShadow = (bool)dataRow["InheritDisableCursorShadow"];
|
||||||
connectionInfo.RDGatewayDomain = (string)dataRow["RDGatewayDomain"];
|
connectionInfo.Inheritance.DisableCursorBlinking = (bool)dataRow["InheritDisableCursorBlinking"];
|
||||||
|
connectionInfo.Inheritance.Domain = (bool)dataRow["InheritDomain"];
|
||||||
if (!dataRow.IsNull("RdpVersion")) // table allows null values which must be handled
|
connectionInfo.Inheritance.Icon = (bool)dataRow["InheritIcon"];
|
||||||
if (Enum.TryParse((string)dataRow["RdpVersion"], true, out RdpVersion rdpVersion))
|
connectionInfo.Inheritance.Panel = (bool)dataRow["InheritPanel"];
|
||||||
connectionInfo.RdpVersion = rdpVersion;
|
connectionInfo.Inheritance.Password = (bool)dataRow["InheritPassword"];
|
||||||
|
connectionInfo.Inheritance.Port = (bool)dataRow["InheritPort"];
|
||||||
connectionInfo.Inheritance.CacheBitmaps = (bool)dataRow["InheritCacheBitmaps"];
|
connectionInfo.Inheritance.Protocol = (bool)dataRow["InheritProtocol"];
|
||||||
connectionInfo.Inheritance.Colors = (bool)dataRow["InheritColors"];
|
connectionInfo.Inheritance.SSHTunnelConnectionName = (bool)dataRow["InheritSSHTunnelConnectionName"];
|
||||||
connectionInfo.Inheritance.Description = (bool)dataRow["InheritDescription"];
|
connectionInfo.Inheritance.OpeningCommand = (bool)dataRow["InheritOpeningCommand"];
|
||||||
connectionInfo.Inheritance.DisplayThemes = (bool)dataRow["InheritDisplayThemes"];
|
connectionInfo.Inheritance.SSHOptions = (bool)dataRow["InheritSSHOptions"];
|
||||||
connectionInfo.Inheritance.DisplayWallpaper = (bool)dataRow["InheritDisplayWallpaper"];
|
connectionInfo.Inheritance.PuttySession = (bool)dataRow["InheritPuttySession"];
|
||||||
connectionInfo.Inheritance.EnableFontSmoothing = (bool)dataRow["InheritEnableFontSmoothing"];
|
connectionInfo.Inheritance.RedirectDiskDrives = (bool)dataRow["InheritRedirectDiskDrives"];
|
||||||
connectionInfo.Inheritance.EnableDesktopComposition = (bool)dataRow["InheritEnableDesktopComposition"];
|
connectionInfo.Inheritance.RedirectKeys = (bool)dataRow["InheritRedirectKeys"];
|
||||||
connectionInfo.Inheritance.DisableFullWindowDrag = (bool)dataRow["InheritDisableFullWindowDrag"];
|
connectionInfo.Inheritance.RedirectPorts = (bool)dataRow["InheritRedirectPorts"];
|
||||||
connectionInfo.Inheritance.DisableMenuAnimations = (bool)dataRow["InheritDisableMenuAnimations"];
|
connectionInfo.Inheritance.RedirectPrinters = (bool)dataRow["InheritRedirectPrinters"];
|
||||||
connectionInfo.Inheritance.DisableCursorShadow = (bool)dataRow["InheritDisableCursorShadow"];
|
connectionInfo.Inheritance.RedirectClipboard = (bool)dataRow["InheritRedirectClipboard"];
|
||||||
connectionInfo.Inheritance.DisableCursorBlinking = (bool)dataRow["InheritDisableCursorBlinking"];
|
connectionInfo.Inheritance.RedirectSmartCards = (bool)dataRow["InheritRedirectSmartCards"];
|
||||||
connectionInfo.Inheritance.Domain = (bool)dataRow["InheritDomain"];
|
connectionInfo.Inheritance.RedirectSound = (bool)dataRow["InheritRedirectSound"];
|
||||||
connectionInfo.Inheritance.Icon = (bool)dataRow["InheritIcon"];
|
connectionInfo.Inheritance.SoundQuality = (bool)dataRow["InheritSoundQuality"];
|
||||||
connectionInfo.Inheritance.Panel = (bool)dataRow["InheritPanel"];
|
connectionInfo.Inheritance.RedirectAudioCapture = (bool)dataRow["InheritRedirectAudioCapture"];
|
||||||
connectionInfo.Inheritance.Password = (bool)dataRow["InheritPassword"];
|
connectionInfo.Inheritance.Resolution = (bool)dataRow["InheritResolution"];
|
||||||
connectionInfo.Inheritance.Port = (bool)dataRow["InheritPort"];
|
connectionInfo.Inheritance.AutomaticResize = (bool)dataRow["InheritAutomaticResize"];
|
||||||
connectionInfo.Inheritance.Protocol = (bool)dataRow["InheritProtocol"];
|
connectionInfo.Inheritance.UseConsoleSession = (bool)dataRow["InheritUseConsoleSession"];
|
||||||
connectionInfo.Inheritance.SSHTunnelConnectionName = (bool)dataRow["InheritSSHTunnelConnectionName"];
|
connectionInfo.Inheritance.UseCredSsp = (bool)dataRow["InheritUseCredSsp"];
|
||||||
connectionInfo.Inheritance.SSHOptions = (bool)dataRow["InheritSSHOptions"];
|
connectionInfo.Inheritance.UseVmId = (bool)dataRow["InheritUseVmId"];
|
||||||
connectionInfo.Inheritance.PuttySession = (bool)dataRow["InheritPuttySession"];
|
connectionInfo.Inheritance.UseEnhancedMode = (bool)dataRow["InheritUseEnhancedMode"];
|
||||||
connectionInfo.Inheritance.RedirectDiskDrives = (bool)dataRow["InheritRedirectDiskDrives"];
|
connectionInfo.Inheritance.VmId = (bool)dataRow["InheritVmId"];
|
||||||
connectionInfo.Inheritance.RedirectKeys = (bool)dataRow["InheritRedirectKeys"];
|
connectionInfo.Inheritance.RenderingEngine = (bool)dataRow["InheritRenderingEngine"];
|
||||||
connectionInfo.Inheritance.RedirectPorts = (bool)dataRow["InheritRedirectPorts"];
|
connectionInfo.Inheritance.Username = (bool)dataRow["InheritUsername"];
|
||||||
connectionInfo.Inheritance.RedirectPrinters = (bool)dataRow["InheritRedirectPrinters"];
|
connectionInfo.Inheritance.RDPAuthenticationLevel = (bool)dataRow["InheritRDPAuthenticationLevel"];
|
||||||
connectionInfo.Inheritance.RedirectClipboard = (bool)dataRow["InheritRedirectClipboard"];
|
connectionInfo.Inheritance.RDPAlertIdleTimeout = (bool)dataRow["InheritRDPAlertIdleTimeout"];
|
||||||
connectionInfo.Inheritance.RedirectSmartCards = (bool)dataRow["InheritRedirectSmartCards"];
|
connectionInfo.Inheritance.RDPMinutesToIdleTimeout = (bool)dataRow["InheritRDPMinutesToIdleTimeout"];
|
||||||
connectionInfo.Inheritance.RedirectSound = (bool)dataRow["InheritRedirectSound"];
|
connectionInfo.Inheritance.LoadBalanceInfo = (bool)dataRow["InheritLoadBalanceInfo"];
|
||||||
connectionInfo.Inheritance.SoundQuality = (bool)dataRow["InheritSoundQuality"];
|
connectionInfo.Inheritance.OpeningCommand = (bool)dataRow["InheritOpeningCommand"];
|
||||||
connectionInfo.Inheritance.RedirectAudioCapture = (bool)dataRow["InheritRedirectAudioCapture"];
|
connectionInfo.Inheritance.PreExtApp = (bool)dataRow["InheritPreExtApp"];
|
||||||
connectionInfo.Inheritance.Resolution = (bool)dataRow["InheritResolution"];
|
connectionInfo.Inheritance.PostExtApp = (bool)dataRow["InheritPostExtApp"];
|
||||||
connectionInfo.Inheritance.AutomaticResize = (bool)dataRow["InheritAutomaticResize"];
|
connectionInfo.Inheritance.MacAddress = (bool)dataRow["InheritMacAddress"];
|
||||||
connectionInfo.Inheritance.UseConsoleSession = (bool)dataRow["InheritUseConsoleSession"];
|
connectionInfo.Inheritance.UserField = (bool)dataRow["InheritUserField"];
|
||||||
connectionInfo.Inheritance.UseCredSsp = (bool)dataRow["InheritUseCredSsp"];
|
connectionInfo.Inheritance.ExtApp = (bool)dataRow["InheritExtApp"];
|
||||||
connectionInfo.Inheritance.UseVmId = (bool)dataRow["InheritUseVmId"];
|
connectionInfo.Inheritance.VNCCompression = (bool)dataRow["InheritVNCCompression"];
|
||||||
connectionInfo.Inheritance.UseEnhancedMode = (bool)dataRow["InheritUseEnhancedMode"];
|
connectionInfo.Inheritance.VNCEncoding = (bool)dataRow["InheritVNCEncoding"];
|
||||||
connectionInfo.Inheritance.VmId = (bool)dataRow["InheritVmId"];
|
connectionInfo.Inheritance.VNCAuthMode = (bool)dataRow["InheritVNCAuthMode"];
|
||||||
connectionInfo.Inheritance.RenderingEngine = (bool)dataRow["InheritRenderingEngine"];
|
connectionInfo.Inheritance.VNCProxyType = (bool)dataRow["InheritVNCProxyType"];
|
||||||
connectionInfo.Inheritance.Username = (bool)dataRow["InheritUsername"];
|
connectionInfo.Inheritance.VNCProxyIP = (bool)dataRow["InheritVNCProxyIP"];
|
||||||
connectionInfo.Inheritance.RDPAuthenticationLevel = (bool)dataRow["InheritRDPAuthenticationLevel"];
|
connectionInfo.Inheritance.VNCProxyPort = (bool)dataRow["InheritVNCProxyPort"];
|
||||||
connectionInfo.Inheritance.RDPAlertIdleTimeout = (bool)dataRow["InheritRDPAlertIdleTimeout"];
|
connectionInfo.Inheritance.VNCProxyUsername = (bool)dataRow["InheritVNCProxyUsername"];
|
||||||
connectionInfo.Inheritance.RDPMinutesToIdleTimeout = (bool)dataRow["InheritRDPMinutesToIdleTimeout"];
|
connectionInfo.Inheritance.VNCProxyPassword = (bool)dataRow["InheritVNCProxyPassword"];
|
||||||
connectionInfo.Inheritance.LoadBalanceInfo = (bool)dataRow["InheritLoadBalanceInfo"];
|
connectionInfo.Inheritance.VNCColors = (bool)dataRow["InheritVNCColors"];
|
||||||
connectionInfo.Inheritance.PreExtApp = (bool)dataRow["InheritPreExtApp"];
|
connectionInfo.Inheritance.VNCSmartSizeMode = (bool)dataRow["InheritVNCSmartSizeMode"];
|
||||||
connectionInfo.Inheritance.PostExtApp = (bool)dataRow["InheritPostExtApp"];
|
connectionInfo.Inheritance.VNCViewOnly = (bool)dataRow["InheritVNCViewOnly"];
|
||||||
connectionInfo.Inheritance.MacAddress = (bool)dataRow["InheritMacAddress"];
|
connectionInfo.Inheritance.RDGatewayUsageMethod = (bool)dataRow["InheritRDGatewayUsageMethod"];
|
||||||
connectionInfo.Inheritance.UserField = (bool)dataRow["InheritUserField"];
|
connectionInfo.Inheritance.RDGatewayHostname = (bool)dataRow["InheritRDGatewayHostname"];
|
||||||
connectionInfo.Inheritance.ExtApp = (bool)dataRow["InheritExtApp"];
|
connectionInfo.Inheritance.RDGatewayUseConnectionCredentials = (bool)dataRow["InheritRDGatewayUseConnectionCredentials"];
|
||||||
connectionInfo.Inheritance.VNCCompression = (bool)dataRow["InheritVNCCompression"];
|
connectionInfo.Inheritance.RDGatewayUsername = (bool)dataRow["InheritRDGatewayUsername"];
|
||||||
connectionInfo.Inheritance.VNCEncoding = (bool)dataRow["InheritVNCEncoding"];
|
connectionInfo.Inheritance.RDGatewayPassword = (bool)dataRow["InheritRDGatewayPassword"];
|
||||||
connectionInfo.Inheritance.VNCAuthMode = (bool)dataRow["InheritVNCAuthMode"];
|
connectionInfo.Inheritance.RDGatewayDomain = (bool)dataRow["InheritRDGatewayDomain"];
|
||||||
connectionInfo.Inheritance.VNCProxyType = (bool)dataRow["InheritVNCProxyType"];
|
connectionInfo.Inheritance.RdpVersion = (bool)dataRow["InheritRdpVersion"];
|
||||||
connectionInfo.Inheritance.VNCProxyIP = (bool)dataRow["InheritVNCProxyIP"];
|
}
|
||||||
connectionInfo.Inheritance.VNCProxyPort = (bool)dataRow["InheritVNCProxyPort"];
|
|
||||||
connectionInfo.Inheritance.VNCProxyUsername = (bool)dataRow["InheritVNCProxyUsername"];
|
private string DecryptValue(string cipherText)
|
||||||
connectionInfo.Inheritance.VNCProxyPassword = (bool)dataRow["InheritVNCProxyPassword"];
|
{
|
||||||
connectionInfo.Inheritance.VNCColors = (bool)dataRow["InheritVNCColors"];
|
try
|
||||||
connectionInfo.Inheritance.VNCSmartSizeMode = (bool)dataRow["InheritVNCSmartSizeMode"];
|
{
|
||||||
connectionInfo.Inheritance.VNCViewOnly = (bool)dataRow["InheritVNCViewOnly"];
|
return _cryptographyProvider.Decrypt(cipherText, _decryptionKey);
|
||||||
connectionInfo.Inheritance.RDGatewayUsageMethod = (bool)dataRow["InheritRDGatewayUsageMethod"];
|
}
|
||||||
connectionInfo.Inheritance.RDGatewayHostname = (bool)dataRow["InheritRDGatewayHostname"];
|
catch (EncryptionException)
|
||||||
connectionInfo.Inheritance.RDGatewayUseConnectionCredentials =
|
{
|
||||||
(bool)dataRow["InheritRDGatewayUseConnectionCredentials"];
|
// value may not be encrypted
|
||||||
connectionInfo.Inheritance.RDGatewayUsername = (bool)dataRow["InheritRDGatewayUsername"];
|
return cipherText;
|
||||||
connectionInfo.Inheritance.RDGatewayPassword = (bool)dataRow["InheritRDGatewayPassword"];
|
}
|
||||||
connectionInfo.Inheritance.RDGatewayDomain = (bool)dataRow["InheritRDGatewayDomain"];
|
}
|
||||||
connectionInfo.Inheritance.RdpVersion = (bool)dataRow["InheritRdpVersion"];
|
|
||||||
}
|
private ConnectionTreeModel CreateNodeHierarchy(List<ConnectionInfo> connectionList, DataTable dataTable)
|
||||||
|
{
|
||||||
private string DecryptValue(string cipherText)
|
var connectionTreeModel = new ConnectionTreeModel();
|
||||||
{
|
var rootNode = new RootNodeInfo(RootNodeType.Connection, "0")
|
||||||
try
|
{
|
||||||
{
|
PasswordString = _decryptionKey.ConvertToUnsecureString()
|
||||||
return _cryptographyProvider.Decrypt(cipherText, _decryptionKey);
|
};
|
||||||
}
|
connectionTreeModel.AddRootNode(rootNode);
|
||||||
catch (EncryptionException)
|
|
||||||
{
|
foreach (DataRow row in dataTable.Rows)
|
||||||
// value may not be encrypted
|
{
|
||||||
return cipherText;
|
var id = (string)row["ConstantID"];
|
||||||
}
|
var connectionInfo = connectionList.First(node => node.ConstantID == id);
|
||||||
}
|
var parentId = (string)row["ParentID"];
|
||||||
|
if (parentId == "0" || connectionList.All(node => node.ConstantID != parentId))
|
||||||
private ConnectionTreeModel CreateNodeHierarchy(List<ConnectionInfo> connectionList, DataTable dataTable)
|
rootNode.AddChild(connectionInfo);
|
||||||
{
|
else
|
||||||
var connectionTreeModel = new ConnectionTreeModel();
|
(connectionList.First(node => node.ConstantID == parentId) as ContainerInfo)?.AddChild(
|
||||||
var rootNode = new RootNodeInfo(RootNodeType.Connection, "0")
|
connectionInfo);
|
||||||
{
|
}
|
||||||
PasswordString = _decryptionKey.ConvertToUnsecureString()
|
|
||||||
};
|
return connectionTreeModel;
|
||||||
connectionTreeModel.AddRootNode(rootNode);
|
}
|
||||||
|
}
|
||||||
foreach (DataRow row in dataTable.Rows)
|
|
||||||
{
|
|
||||||
var id = (string)row["ConstantID"];
|
|
||||||
var connectionInfo = connectionList.First(node => node.ConstantID == id);
|
|
||||||
var parentId = (string)row["ParentID"];
|
|
||||||
if (parentId == "0" || connectionList.All(node => node.ConstantID != parentId))
|
|
||||||
rootNode.AddChild(connectionInfo);
|
|
||||||
else
|
|
||||||
(connectionList.First(node => node.ConstantID == parentId) as ContainerInfo)?.AddChild(
|
|
||||||
connectionInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
return connectionTreeModel;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -80,9 +80,9 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.MsSql
|
|||||||
if (rootTreeNode != null)
|
if (rootTreeNode != null)
|
||||||
{
|
{
|
||||||
cmd = databaseConnector.DbCommand(
|
cmd = databaseConnector.DbCommand(
|
||||||
"INSERT INTO tblRoot (Name, Export, Protected, ConfVersion) VALUES(\'" +
|
"INSERT INTO tblRoot (Name, Export, Protected, ConfVersion) VALUES('" +
|
||||||
MiscTools.PrepareValueForDB(rootTreeNode.Name) + "\', 0, \'" + strProtected + "\'," +
|
MiscTools.PrepareValueForDB(rootTreeNode.Name) + "', 0, '" + strProtected + "','" +
|
||||||
ConnectionsFileInfo.ConnectionFileVersion.ToString(CultureInfo.InvariantCulture) + ")");
|
ConnectionsFileInfo.ConnectionFileVersion.ToString() + "')");
|
||||||
cmd.ExecuteNonQuery();
|
cmd.ExecuteNonQuery();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Security;
|
using System.Security;
|
||||||
using System.Xml.Linq;
|
using System.Xml.Linq;
|
||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
@@ -66,6 +66,7 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("Hostname", connectionInfo.Hostname));
|
element.Add(new XAttribute("Hostname", connectionInfo.Hostname));
|
||||||
element.Add(new XAttribute("Protocol", connectionInfo.Protocol));
|
element.Add(new XAttribute("Protocol", connectionInfo.Protocol));
|
||||||
element.Add(new XAttribute("SSHTunnelConnectionName", connectionInfo.SSHTunnelConnectionName));
|
element.Add(new XAttribute("SSHTunnelConnectionName", connectionInfo.SSHTunnelConnectionName));
|
||||||
|
element.Add(new XAttribute("OpeningCommand", connectionInfo.OpeningCommand));
|
||||||
element.Add(new XAttribute("SSHOptions", connectionInfo.SSHOptions));
|
element.Add(new XAttribute("SSHOptions", connectionInfo.SSHOptions));
|
||||||
element.Add(new XAttribute("PuttySession", connectionInfo.PuttySession));
|
element.Add(new XAttribute("PuttySession", connectionInfo.PuttySession));
|
||||||
element.Add(new XAttribute("Port", connectionInfo.Port));
|
element.Add(new XAttribute("Port", connectionInfo.Port));
|
||||||
@@ -98,7 +99,7 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("MacAddress", connectionInfo.MacAddress));
|
element.Add(new XAttribute("MacAddress", connectionInfo.MacAddress));
|
||||||
element.Add(new XAttribute("UserField", connectionInfo.UserField));
|
element.Add(new XAttribute("UserField", connectionInfo.UserField));
|
||||||
element.Add(new XAttribute("ExtApp", connectionInfo.ExtApp));
|
element.Add(new XAttribute("ExtApp", connectionInfo.ExtApp));
|
||||||
element.Add(new XAttribute("StartProgram", connectionInfo.StartProgram));
|
element.Add(new XAttribute("StartProgram", connectionInfo.RDPStartProgram));
|
||||||
element.Add(new XAttribute("VNCCompression", connectionInfo.VNCCompression));
|
element.Add(new XAttribute("VNCCompression", connectionInfo.VNCCompression));
|
||||||
element.Add(new XAttribute("VNCEncoding", connectionInfo.VNCEncoding));
|
element.Add(new XAttribute("VNCEncoding", connectionInfo.VNCEncoding));
|
||||||
element.Add(new XAttribute("VNCAuthMode", connectionInfo.VNCAuthMode));
|
element.Add(new XAttribute("VNCAuthMode", connectionInfo.VNCAuthMode));
|
||||||
@@ -168,6 +169,8 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("InheritProtocol", inheritance.Protocol.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritProtocol", inheritance.Protocol.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.SSHTunnelConnectionName)
|
if (inheritance.SSHTunnelConnectionName)
|
||||||
element.Add(new XAttribute("InheritSSHTunnelConnectionName", inheritance.SSHTunnelConnectionName.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritSSHTunnelConnectionName", inheritance.SSHTunnelConnectionName.ToString().ToLowerInvariant()));
|
||||||
|
if (inheritance.OpeningCommand)
|
||||||
|
element.Add(new XAttribute("InheritOpeningCommand", inheritance.OpeningCommand.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.SSHOptions)
|
if (inheritance.SSHOptions)
|
||||||
element.Add(new XAttribute("InheritSSHOptions", inheritance.SSHOptions.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritSSHOptions", inheritance.SSHOptions.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.PuttySession)
|
if (inheritance.PuttySession)
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Security;
|
using System.Security;
|
||||||
using System.Xml.Linq;
|
using System.Xml.Linq;
|
||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
@@ -76,6 +76,7 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("Protocol", connectionInfo.Protocol));
|
element.Add(new XAttribute("Protocol", connectionInfo.Protocol));
|
||||||
element.Add(new XAttribute("RdpVersion", connectionInfo.RdpVersion.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("RdpVersion", connectionInfo.RdpVersion.ToString().ToLowerInvariant()));
|
||||||
element.Add(new XAttribute("SSHTunnelConnectionName", connectionInfo.SSHTunnelConnectionName));
|
element.Add(new XAttribute("SSHTunnelConnectionName", connectionInfo.SSHTunnelConnectionName));
|
||||||
|
element.Add(new XAttribute("OpeningCommand", connectionInfo.OpeningCommand));
|
||||||
element.Add(new XAttribute("SSHOptions", connectionInfo.SSHOptions));
|
element.Add(new XAttribute("SSHOptions", connectionInfo.SSHOptions));
|
||||||
element.Add(new XAttribute("PuttySession", connectionInfo.PuttySession));
|
element.Add(new XAttribute("PuttySession", connectionInfo.PuttySession));
|
||||||
element.Add(new XAttribute("Port", connectionInfo.Port));
|
element.Add(new XAttribute("Port", connectionInfo.Port));
|
||||||
@@ -114,7 +115,8 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("UserField", connectionInfo.UserField));
|
element.Add(new XAttribute("UserField", connectionInfo.UserField));
|
||||||
element.Add(new XAttribute("Favorite", connectionInfo.Favorite));
|
element.Add(new XAttribute("Favorite", connectionInfo.Favorite));
|
||||||
element.Add(new XAttribute("ExtApp", connectionInfo.ExtApp));
|
element.Add(new XAttribute("ExtApp", connectionInfo.ExtApp));
|
||||||
element.Add(new XAttribute("StartProgram", connectionInfo.StartProgram));
|
element.Add(new XAttribute("StartProgram", connectionInfo.RDPStartProgram));
|
||||||
|
element.Add(new XAttribute("StartProgramWorkDir", connectionInfo.RDPStartProgramWorkDir));
|
||||||
element.Add(new XAttribute("VNCCompression", connectionInfo.VNCCompression));
|
element.Add(new XAttribute("VNCCompression", connectionInfo.VNCCompression));
|
||||||
element.Add(new XAttribute("VNCEncoding", connectionInfo.VNCEncoding));
|
element.Add(new XAttribute("VNCEncoding", connectionInfo.VNCEncoding));
|
||||||
element.Add(new XAttribute("VNCAuthMode", connectionInfo.VNCAuthMode));
|
element.Add(new XAttribute("VNCAuthMode", connectionInfo.VNCAuthMode));
|
||||||
@@ -148,6 +150,10 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(_saveFilter.SaveDomain
|
element.Add(_saveFilter.SaveDomain
|
||||||
? new XAttribute("RDGatewayDomain", connectionInfo.RDGatewayDomain)
|
? new XAttribute("RDGatewayDomain", connectionInfo.RDGatewayDomain)
|
||||||
: new XAttribute("RDGatewayDomain", ""));
|
: new XAttribute("RDGatewayDomain", ""));
|
||||||
|
|
||||||
|
element.Add(new XAttribute("UserViaAPI", connectionInfo.UserViaAPI));
|
||||||
|
element.Add(new XAttribute("EC2InstanceId", connectionInfo.EC2InstanceId));
|
||||||
|
element.Add(new XAttribute("EC2Region", connectionInfo.EC2Region));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetInheritanceAttributes(XContainer element, IInheritable connectionInfo)
|
private void SetInheritanceAttributes(XContainer element, IInheritable connectionInfo)
|
||||||
@@ -194,6 +200,8 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("InheritRdpVersion", inheritance.RdpVersion.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritRdpVersion", inheritance.RdpVersion.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.SSHTunnelConnectionName)
|
if (inheritance.SSHTunnelConnectionName)
|
||||||
element.Add(new XAttribute("InheritSSHTunnelConnectionName", inheritance.SSHTunnelConnectionName.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritSSHTunnelConnectionName", inheritance.SSHTunnelConnectionName.ToString().ToLowerInvariant()));
|
||||||
|
if (inheritance.OpeningCommand)
|
||||||
|
element.Add(new XAttribute("InheritOpeningCommand", inheritance.OpeningCommand.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.SSHOptions)
|
if (inheritance.SSHOptions)
|
||||||
element.Add(new XAttribute("InheritSSHOptions", inheritance.SSHOptions.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritSSHOptions", inheritance.SSHOptions.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.PuttySession)
|
if (inheritance.PuttySession)
|
||||||
@@ -288,6 +296,8 @@ namespace mRemoteNG.Config.Serializers.ConnectionSerializers.Xml
|
|||||||
element.Add(new XAttribute("InheritUseVmId", inheritance.UseVmId.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritUseVmId", inheritance.UseVmId.ToString().ToLowerInvariant()));
|
||||||
if (inheritance.UseEnhancedMode)
|
if (inheritance.UseEnhancedMode)
|
||||||
element.Add(new XAttribute("InheritUseEnhancedMode", inheritance.UseEnhancedMode.ToString().ToLowerInvariant()));
|
element.Add(new XAttribute("InheritUseEnhancedMode", inheritance.UseEnhancedMode.ToString().ToLowerInvariant()));
|
||||||
|
if (inheritance.UserViaAPI)
|
||||||
|
element.Add(new XAttribute("InheritUserViaAPI", inheritance.UserViaAPI.ToString().ToLowerInvariant()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -6,10 +6,10 @@ using mRemoteNG.Config.Import;
|
|||||||
using mRemoteNG.Connection;
|
using mRemoteNG.Connection;
|
||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Serializers.MiscSerializers
|
namespace mRemoteNG.Config.Serializers.MiscSerializers
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -152,7 +152,7 @@ namespace mRemoteNG.Config.Serializers.MiscSerializers
|
|||||||
connectionInfo.RDGatewayHostname = value;
|
connectionInfo.RDGatewayHostname = value;
|
||||||
break;
|
break;
|
||||||
case "alternate shell":
|
case "alternate shell":
|
||||||
connectionInfo.StartProgram = value;
|
connectionInfo.RDPStartProgram = value;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
@@ -7,9 +7,9 @@ using mRemoteNG.Connection;
|
|||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Connection.Protocol.RDP;
|
using mRemoteNG.Connection.Protocol.RDP;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Serializers.MiscSerializers
|
namespace mRemoteNG.Config.Serializers.MiscSerializers
|
||||||
{
|
{
|
||||||
@@ -183,8 +183,8 @@ namespace mRemoteNG.Config.Serializers.MiscSerializers
|
|||||||
{
|
{
|
||||||
if (bool.TryParse(connectionSettingsNode.SelectSingleNode("./connectToConsole")?.InnerText, out var useConsole))
|
if (bool.TryParse(connectionSettingsNode.SelectSingleNode("./connectToConsole")?.InnerText, out var useConsole))
|
||||||
connectionInfo.UseConsoleSession = useConsole;
|
connectionInfo.UseConsoleSession = useConsole;
|
||||||
connectionInfo.StartProgram = connectionSettingsNode.SelectSingleNode("./startProgram")?.InnerText;
|
connectionInfo.RDPStartProgram = connectionSettingsNode.SelectSingleNode("./startProgram")?.InnerText;
|
||||||
// ./workingDir
|
connectionInfo.RDPStartProgramWorkDir = connectionSettingsNode.SelectSingleNode("./startProgramWorkDir")?.InnerText;
|
||||||
if (int.TryParse(connectionSettingsNode.SelectSingleNode("./port")?.InnerText, out var port))
|
if (int.TryParse(connectionSettingsNode.SelectSingleNode("./port")?.InnerText, out var port))
|
||||||
connectionInfo.Port = port;
|
connectionInfo.Port = port;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,13 +2,15 @@
|
|||||||
using mRemoteNG.App.Info;
|
using mRemoteNG.App.Info;
|
||||||
using mRemoteNG.Config.DatabaseConnectors;
|
using mRemoteNG.Config.DatabaseConnectors;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using System;
|
|
||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Resources.Language;
|
||||||
|
using System;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Serializers.Versioning
|
namespace mRemoteNG.Config.Serializers.Versioning
|
||||||
{
|
{
|
||||||
public class SqlDatabaseVersionVerifier
|
public class SqlDatabaseVersionVerifier
|
||||||
{
|
{
|
||||||
|
protected readonly Version currentSupportedVersion = new Version(2, 9);
|
||||||
|
|
||||||
private readonly IDatabaseConnector _databaseConnector;
|
private readonly IDatabaseConnector _databaseConnector;
|
||||||
|
|
||||||
public SqlDatabaseVersionVerifier(IDatabaseConnector DatabaseConnector)
|
public SqlDatabaseVersionVerifier(IDatabaseConnector DatabaseConnector)
|
||||||
@@ -39,6 +41,7 @@ namespace mRemoteNG.Config.Serializers.Versioning
|
|||||||
new SqlVersion25To26Upgrader(_databaseConnector),
|
new SqlVersion25To26Upgrader(_databaseConnector),
|
||||||
new SqlVersion26To27Upgrader(_databaseConnector),
|
new SqlVersion26To27Upgrader(_databaseConnector),
|
||||||
new SqlVersion27To28Upgrader(_databaseConnector),
|
new SqlVersion27To28Upgrader(_databaseConnector),
|
||||||
|
new SqlVersion28To29Upgrader(_databaseConnector),
|
||||||
};
|
};
|
||||||
|
|
||||||
foreach (var upgrader in dbUpgraders)
|
foreach (var upgrader in dbUpgraders)
|
||||||
@@ -50,7 +53,7 @@ namespace mRemoteNG.Config.Serializers.Versioning
|
|||||||
}
|
}
|
||||||
|
|
||||||
// DB is at the highest current supported version
|
// DB is at the highest current supported version
|
||||||
if (databaseVersion.CompareTo(new Version(2, 8)) == 0)
|
if (databaseVersion.CompareTo(currentSupportedVersion) == 0)
|
||||||
isVerified = true;
|
isVerified = true;
|
||||||
|
|
||||||
if (isVerified == false)
|
if (isVerified == false)
|
||||||
|
|||||||
@@ -0,0 +1,80 @@
|
|||||||
|
using mRemoteNG.App;
|
||||||
|
using mRemoteNG.Config.DatabaseConnectors;
|
||||||
|
using mRemoteNG.Messages;
|
||||||
|
using System;
|
||||||
|
using System.Data.Common;
|
||||||
|
|
||||||
|
namespace mRemoteNG.Config.Serializers.Versioning
|
||||||
|
{
|
||||||
|
public class SqlVersion28To29Upgrader : IVersionUpgrader
|
||||||
|
{
|
||||||
|
private readonly Version version = new Version(2, 9);
|
||||||
|
private readonly IDatabaseConnector _databaseConnector;
|
||||||
|
|
||||||
|
public SqlVersion28To29Upgrader(IDatabaseConnector databaseConnector)
|
||||||
|
{
|
||||||
|
_databaseConnector = databaseConnector ?? throw new ArgumentNullException(nameof(databaseConnector));
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool CanUpgrade(Version currentVersion)
|
||||||
|
{
|
||||||
|
return currentVersion == new Version(2, 8) ||
|
||||||
|
// Support upgrading during dev revisions, 2.9.1, 2.9.2, etc...
|
||||||
|
(currentVersion <= new Version(2, 9) &&
|
||||||
|
currentVersion < version);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Version Upgrade()
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.InformationMsg,
|
||||||
|
string.Format("Upgrading database to version {0}.", version));
|
||||||
|
|
||||||
|
const string mySqlAlter = @"
|
||||||
|
ALTER TABLE tblCons ADD COLUMN StartProgram varchar(512) DEFAULT NULL;
|
||||||
|
ALTER TABLE tblCons ADD COLUMN StartProgramWorkDir varchar(512) DEFAULT NULL;
|
||||||
|
ALTER TABLE tblRoot CHANGE COLUMN ConfVersion ConfVersion VARCHAR(15) NOT NULL;";
|
||||||
|
const string mySqlUpdate = @"UPDATE tblRoot SET ConfVersion=?;";
|
||||||
|
const string msSqlAlter = @"
|
||||||
|
IF NOT EXISTS (SELECT * FROM sys.columns WHERE object_id = OBJECT_ID(N'[dbo].[tblCons]') AND name = 'StartProgram')
|
||||||
|
BEGIN
|
||||||
|
ALTER TABLE tblCons ADD StartProgram varchar(512), StartProgramWorkDir varchar(512);
|
||||||
|
END;GO;
|
||||||
|
ALTER TABLE tblRoot MODIFY COLUMN ConfVersion varchar(15);GO;";
|
||||||
|
const string msSqlUpdate = @"UPDATE tblRoot SET ConfVersion=@confVersion;";
|
||||||
|
using (var sqlTran = _databaseConnector.DbConnection().BeginTransaction(System.Data.IsolationLevel.Serializable))
|
||||||
|
{
|
||||||
|
DbCommand dbCommand;
|
||||||
|
if (_databaseConnector.GetType() == typeof(MSSqlDatabaseConnector))
|
||||||
|
{
|
||||||
|
dbCommand = _databaseConnector.DbCommand(msSqlAlter);
|
||||||
|
dbCommand.Transaction = sqlTran;
|
||||||
|
dbCommand.ExecuteNonQuery();
|
||||||
|
dbCommand = _databaseConnector.DbCommand(msSqlUpdate);
|
||||||
|
dbCommand.Transaction = sqlTran;
|
||||||
|
}
|
||||||
|
else if (_databaseConnector.GetType() == typeof(MySqlDatabaseConnector))
|
||||||
|
{
|
||||||
|
dbCommand = _databaseConnector.DbCommand(mySqlAlter);
|
||||||
|
dbCommand.Transaction = sqlTran;
|
||||||
|
dbCommand.ExecuteNonQuery();
|
||||||
|
dbCommand = _databaseConnector.DbCommand(mySqlUpdate);
|
||||||
|
dbCommand.Transaction = sqlTran;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unknown database back-end");
|
||||||
|
}
|
||||||
|
var pConfVersion = dbCommand.CreateParameter();
|
||||||
|
pConfVersion.ParameterName = "confVersion";
|
||||||
|
pConfVersion.Value = version.ToString();
|
||||||
|
pConfVersion.DbType = System.Data.DbType.String;
|
||||||
|
pConfVersion.Direction = System.Data.ParameterDirection.Input;
|
||||||
|
dbCommand.Parameters.Add(pConfVersion);
|
||||||
|
|
||||||
|
dbCommand.ExecuteNonQuery();
|
||||||
|
sqlTran.Commit();
|
||||||
|
}
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -77,9 +77,6 @@ namespace mRemoteNG.Config.Settings
|
|||||||
|
|
||||||
if (persistString == typeof(ErrorAndInfoWindow).ToString())
|
if (persistString == typeof(ErrorAndInfoWindow).ToString())
|
||||||
return Windows.ErrorsForm;
|
return Windows.ErrorsForm;
|
||||||
|
|
||||||
if (persistString == typeof(ScreenshotManagerWindow).ToString())
|
|
||||||
return Windows.ScreenshotForm;
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Drawing;
|
using System.Drawing;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using WeifenLuo.WinFormsUI.Docking;
|
using WeifenLuo.WinFormsUI.Docking;
|
||||||
@@ -11,7 +11,7 @@ using mRemoteNG.Messages;
|
|||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.UI.Controls;
|
using mRemoteNG.UI.Controls;
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
|
using mRemoteNG.Connection.Protocol.Winbox;
|
||||||
|
|
||||||
namespace mRemoteNG.Config.Settings
|
namespace mRemoteNG.Config.Settings
|
||||||
{
|
{
|
||||||
@@ -69,6 +69,7 @@ namespace mRemoteNG.Config.Settings
|
|||||||
SetKioskMode();
|
SetKioskMode();
|
||||||
|
|
||||||
SetPuttyPath();
|
SetPuttyPath();
|
||||||
|
SetWinboxPath();
|
||||||
SetShowSystemTrayIcon();
|
SetShowSystemTrayIcon();
|
||||||
SetAutoSave();
|
SetAutoSave();
|
||||||
LoadExternalAppsFromXml();
|
LoadExternalAppsFromXml();
|
||||||
@@ -169,6 +170,11 @@ namespace mRemoteNG.Config.Settings
|
|||||||
: GeneralAppInfo.PuttyPath;
|
: GeneralAppInfo.PuttyPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void SetWinboxPath()
|
||||||
|
{
|
||||||
|
ProtocolWinbox.WinboxPath = GeneralAppInfo.WinboxPath;
|
||||||
|
}
|
||||||
|
|
||||||
private void EnsureSettingsAreSavedInNewestVersion()
|
private void EnsureSettingsAreSavedInNewestVersion()
|
||||||
{
|
{
|
||||||
if (Properties.Settings.Default.DoUpgrade)
|
if (Properties.Settings.Default.DoUpgrade)
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -15,8 +15,10 @@ using mRemoteNG.Connection.Protocol.Telnet;
|
|||||||
using mRemoteNG.Connection.Protocol.VNC;
|
using mRemoteNG.Connection.Protocol.VNC;
|
||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Connection.Protocol.Winbox;
|
||||||
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
@@ -46,10 +48,10 @@ namespace mRemoteNG.Connection
|
|||||||
[Browsable(false)] public ContainerInfo Parent { get; internal set; }
|
[Browsable(false)] public ContainerInfo Parent { get; internal set; }
|
||||||
|
|
||||||
[Browsable(false)]
|
[Browsable(false)]
|
||||||
// ReSharper disable once UnusedAutoPropertyAccessor.Global
|
|
||||||
public bool IsQuickConnect { get; set; }
|
public bool IsQuickConnect { get; set; }
|
||||||
|
|
||||||
[Browsable(false)] public bool PleaseConnect { get; set; }
|
[Browsable(false)]
|
||||||
|
public bool PleaseConnect { get; set; }
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@@ -66,6 +68,7 @@ namespace mRemoteNG.Connection
|
|||||||
SetTreeDisplayDefaults();
|
SetTreeDisplayDefaults();
|
||||||
SetConnectionDefaults();
|
SetConnectionDefaults();
|
||||||
SetProtocolDefaults();
|
SetProtocolDefaults();
|
||||||
|
SetRemoteDesktopServicesDefaults();
|
||||||
SetRdGatewayDefaults();
|
SetRdGatewayDefaults();
|
||||||
SetAppearanceDefaults();
|
SetAppearanceDefaults();
|
||||||
SetRedirectDefaults();
|
SetRedirectDefaults();
|
||||||
@@ -199,7 +202,10 @@ namespace mRemoteNG.Connection
|
|||||||
|
|
||||||
private bool ShouldThisPropertyBeInherited(string propertyName)
|
private bool ShouldThisPropertyBeInherited(string propertyName)
|
||||||
{
|
{
|
||||||
return ParentIsValidInheritanceTarget() && IsInheritanceTurnedOnForThisProperty(propertyName);
|
return
|
||||||
|
Inheritance.InheritanceActive &&
|
||||||
|
ParentIsValidInheritanceTarget() &&
|
||||||
|
IsInheritanceTurnedOnForThisProperty(propertyName);
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool ParentIsValidInheritanceTarget()
|
private bool ParentIsValidInheritanceTarget()
|
||||||
@@ -269,6 +275,8 @@ namespace mRemoteNG.Connection
|
|||||||
return (int)ProtocolPowerShell.Defaults.Port;
|
return (int)ProtocolPowerShell.Defaults.Port;
|
||||||
case ProtocolType.IntApp:
|
case ProtocolType.IntApp:
|
||||||
return (int)IntegratedProgram.Defaults.Port;
|
return (int)IntegratedProgram.Defaults.Port;
|
||||||
|
case ProtocolType.Winbox:
|
||||||
|
return (int)ProtocolWinbox.Defaults.Port;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -291,6 +299,7 @@ namespace mRemoteNG.Connection
|
|||||||
private void SetConnectionDefaults()
|
private void SetConnectionDefaults()
|
||||||
{
|
{
|
||||||
Hostname = string.Empty;
|
Hostname = string.Empty;
|
||||||
|
EC2Region = Settings.Default.ConDefaultEC2Region;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetProtocolDefaults()
|
private void SetProtocolDefaults()
|
||||||
@@ -310,6 +319,12 @@ namespace mRemoteNG.Connection
|
|||||||
UseEnhancedMode = Settings.Default.ConDefaultUseEnhancedMode;
|
UseEnhancedMode = Settings.Default.ConDefaultUseEnhancedMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SetRemoteDesktopServicesDefaults()
|
||||||
|
{
|
||||||
|
RDPStartProgram = string.Empty;
|
||||||
|
RDPStartProgramWorkDir = string.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
private void SetRdGatewayDefaults()
|
private void SetRdGatewayDefaults()
|
||||||
{
|
{
|
||||||
RDGatewayUsageMethod = (RDGatewayUsageMethod)Enum.Parse(typeof(RDGatewayUsageMethod), Settings.Default.ConDefaultRDGatewayUsageMethod);
|
RDGatewayUsageMethod = (RDGatewayUsageMethod)Enum.Parse(typeof(RDGatewayUsageMethod), Settings.Default.ConDefaultRDGatewayUsageMethod);
|
||||||
@@ -356,7 +371,9 @@ namespace mRemoteNG.Connection
|
|||||||
MacAddress = Settings.Default.ConDefaultMacAddress;
|
MacAddress = Settings.Default.ConDefaultMacAddress;
|
||||||
UserField = Settings.Default.ConDefaultUserField;
|
UserField = Settings.Default.ConDefaultUserField;
|
||||||
Favorite = Settings.Default.ConDefaultFavorite;
|
Favorite = Settings.Default.ConDefaultFavorite;
|
||||||
StartProgram = Settings.Default.ConDefaultStartProgram;
|
RDPStartProgram = Settings.Default.ConDefaultRDPStartProgram;
|
||||||
|
RDPStartProgramWorkDir = Settings.Default.ConDefaultRDPStartProgramWorkDir;
|
||||||
|
OpeningCommand = Settings.Default.OpeningCommand;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetVncDefaults()
|
private void SetVncDefaults()
|
||||||
|
|||||||
@@ -2,8 +2,9 @@
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
{
|
{
|
||||||
@@ -50,6 +51,12 @@ namespace mRemoteNG.Connection
|
|||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Connection
|
#region Connection
|
||||||
|
[LocalizedAttributes.LocalizedCategory(nameof(Language.Connection), 3),
|
||||||
|
LocalizedAttributes.LocalizedDisplayNameInherit(nameof(Language.UserViaAPI)),
|
||||||
|
LocalizedAttributes.LocalizedDescriptionInherit(nameof(Language.PropertyDescriptionUserViaAPI)),
|
||||||
|
TypeConverter(typeof(MiscTools.YesNoTypeConverter))]
|
||||||
|
[Browsable(true)]
|
||||||
|
public bool UserViaAPI { get; set; }
|
||||||
|
|
||||||
[LocalizedAttributes.LocalizedCategory(nameof(Language.Connection), 3),
|
[LocalizedAttributes.LocalizedCategory(nameof(Language.Connection), 3),
|
||||||
LocalizedAttributes.LocalizedDisplayNameInherit(nameof(Language.Username)),
|
LocalizedAttributes.LocalizedDisplayNameInherit(nameof(Language.Username)),
|
||||||
@@ -92,6 +99,15 @@ namespace mRemoteNG.Connection
|
|||||||
[Browsable(true)]
|
[Browsable(true)]
|
||||||
public bool SSHTunnelConnectionName { get; set; }
|
public bool SSHTunnelConnectionName { get; set; }
|
||||||
|
|
||||||
|
[LocalizedAttributes.LocalizedCategory(nameof(Language.Connection), 3),
|
||||||
|
LocalizedAttributes.LocalizedDisplayNameInheritAttribute(nameof(Language.OpeningCommand)),
|
||||||
|
LocalizedAttributes.LocalizedDescriptionInheritAttribute(nameof(Language.PropertyDescriptionOpeningCommand)),
|
||||||
|
TypeConverter(typeof(MiscTools.YesNoTypeConverter))]
|
||||||
|
[Browsable(true)]
|
||||||
|
public bool OpeningCommand { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Protocol
|
#region Protocol
|
||||||
@@ -446,7 +462,16 @@ namespace mRemoteNG.Connection
|
|||||||
TypeConverter(typeof(MiscTools.YesNoTypeConverter))]public bool VNCViewOnly {get; set;}
|
TypeConverter(typeof(MiscTools.YesNoTypeConverter))]public bool VNCViewOnly {get; set;}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
[Browsable(false)] public ConnectionInfo Parent { get; private set; }
|
[Browsable(false)]
|
||||||
|
public ConnectionInfo Parent { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Indicates whether this inheritance object is enabled.
|
||||||
|
/// When false, users of this object should not respect inheritance
|
||||||
|
/// settings for individual properties.
|
||||||
|
/// </summary>
|
||||||
|
[Browsable(false)]
|
||||||
|
public bool InheritanceActive => !(Parent is RootNodeInfo || Parent?.Parent is RootNodeInfo);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@@ -463,7 +488,6 @@ namespace mRemoteNG.Connection
|
|||||||
{
|
{
|
||||||
var newInheritance = (ConnectionInfoInheritance)MemberwiseClone();
|
var newInheritance = (ConnectionInfoInheritance)MemberwiseClone();
|
||||||
newInheritance.Parent = parent;
|
newInheritance.Parent = parent;
|
||||||
newInheritance._tempInheritanceStorage = null;
|
|
||||||
return newInheritance;
|
return newInheritance;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -521,15 +545,22 @@ namespace mRemoteNG.Connection
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public IEnumerable<string> GetEnabledInheritanceProperties()
|
public IEnumerable<string> GetEnabledInheritanceProperties()
|
||||||
{
|
{
|
||||||
return GetProperties()
|
return InheritanceActive
|
||||||
.Where(property => (bool)property.GetValue(this))
|
? GetProperties()
|
||||||
.Select(property => property.Name)
|
.Where(property => (bool)property.GetValue(this))
|
||||||
.ToList();
|
.Select(property => property.Name)
|
||||||
|
.ToList()
|
||||||
|
: Enumerable.Empty<string>();
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool FilterProperty(PropertyInfo propertyInfo)
|
private bool FilterProperty(PropertyInfo propertyInfo)
|
||||||
{
|
{
|
||||||
var exclusions = new[] {"EverythingInherited", "Parent"};
|
var exclusions = new[]
|
||||||
|
{
|
||||||
|
nameof(EverythingInherited),
|
||||||
|
nameof(Parent),
|
||||||
|
nameof(InheritanceActive)
|
||||||
|
};
|
||||||
var valueShouldNotBeFiltered = !exclusions.Contains(propertyInfo.Name);
|
var valueShouldNotBeFiltered = !exclusions.Contains(propertyInfo.Name);
|
||||||
return valueShouldNotBeFiltered;
|
return valueShouldNotBeFiltered;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,12 +6,12 @@ using mRemoteNG.Connection.Protocol;
|
|||||||
using mRemoteNG.Container;
|
using mRemoteNG.Container;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
using mRemoteNG.UI.Panels;
|
using mRemoteNG.UI.Panels;
|
||||||
using mRemoteNG.UI.Tabs;
|
using mRemoteNG.UI.Tabs;
|
||||||
using mRemoteNG.UI.Window;
|
using mRemoteNG.UI.Window;
|
||||||
using WeifenLuo.WinFormsUI.Docking;
|
using WeifenLuo.WinFormsUI.Docking;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
@@ -62,6 +62,19 @@ namespace mRemoteNG.Connection
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
if (!string.IsNullOrEmpty(connectionInfo.EC2InstanceId))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
string host = await ExternalConnectors.AWS.EC2FetchDataService.GetEC2InstanceDataAsync("AWSAPI:" + connectionInfo.EC2InstanceId, connectionInfo.EC2Region);
|
||||||
|
if (!string.IsNullOrEmpty(host))
|
||||||
|
connectionInfo.Hostname = host;
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (connectionInfo.Hostname == "" && connectionInfo.Protocol != ProtocolType.IntApp)
|
if (connectionInfo.Hostname == "" && connectionInfo.Protocol != ProtocolType.IntApp)
|
||||||
{
|
{
|
||||||
Runtime.MessageCollector.AddMessage(MessageClass.WarningMsg,
|
Runtime.MessageCollector.AddMessage(MessageClass.WarningMsg,
|
||||||
|
|||||||
@@ -13,12 +13,12 @@ using mRemoteNG.Config.Serializers.ConnectionSerializers.MsSql;
|
|||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Security;
|
using mRemoteNG.Security;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
using mRemoteNG.UI;
|
using mRemoteNG.UI;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
{
|
{
|
||||||
@@ -37,6 +37,7 @@ namespace mRemoteNG.Connection
|
|||||||
public string ConnectionFileName { get; private set; }
|
public string ConnectionFileName { get; private set; }
|
||||||
public RemoteConnectionsSyncronizer RemoteConnectionsSyncronizer { get; set; }
|
public RemoteConnectionsSyncronizer RemoteConnectionsSyncronizer { get; set; }
|
||||||
public DateTime LastSqlUpdate { get; set; }
|
public DateTime LastSqlUpdate { get; set; }
|
||||||
|
public DateTime LastFileUpdate { get; set; }
|
||||||
|
|
||||||
public ConnectionTreeModel ConnectionTreeModel { get; private set; }
|
public ConnectionTreeModel ConnectionTreeModel { get; private set; }
|
||||||
|
|
||||||
@@ -77,13 +78,19 @@ namespace mRemoteNG.Connection
|
|||||||
|
|
||||||
if (connectionString.Contains("@"))
|
if (connectionString.Contains("@"))
|
||||||
{
|
{
|
||||||
string[] x = connectionString.Split('@');
|
var x = connectionString.Split('@');
|
||||||
uriBuilder.UserName = x[0];
|
uriBuilder.UserName = x[0];
|
||||||
uriBuilder.Host = x[1];
|
connectionString = x[1];
|
||||||
}
|
}
|
||||||
else
|
if (connectionString.Contains(":"))
|
||||||
uriBuilder.Host = connectionString;
|
{
|
||||||
|
var x = connectionString.Split(':');
|
||||||
|
connectionString = x[0];
|
||||||
|
uriBuilder.Port = Convert.ToInt32(x[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
uriBuilder.Host = connectionString;
|
||||||
|
|
||||||
var newConnectionInfo = new ConnectionInfo();
|
var newConnectionInfo = new ConnectionInfo();
|
||||||
newConnectionInfo.CopyFrom(DefaultConnectionInfo.Instance);
|
newConnectionInfo.CopyFrom(DefaultConnectionInfo.Instance);
|
||||||
|
|
||||||
@@ -94,6 +101,7 @@ namespace mRemoteNG.Connection
|
|||||||
newConnectionInfo.Protocol = protocol;
|
newConnectionInfo.Protocol = protocol;
|
||||||
newConnectionInfo.Hostname = uriBuilder.Host;
|
newConnectionInfo.Hostname = uriBuilder.Host;
|
||||||
newConnectionInfo.Username = uriBuilder.UserName;
|
newConnectionInfo.Username = uriBuilder.UserName;
|
||||||
|
|
||||||
if (uriBuilder.Port == -1)
|
if (uriBuilder.Port == -1)
|
||||||
{
|
{
|
||||||
newConnectionInfo.SetDefaultPort();
|
newConnectionInfo.SetDefaultPort();
|
||||||
|
|||||||
@@ -1,34 +0,0 @@
|
|||||||
// Copyright © 2013 The CefSharp Authors. All rights reserved.
|
|
||||||
//
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
|
|
||||||
|
|
||||||
using CefSharp;
|
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.Http
|
|
||||||
{
|
|
||||||
public class DownloadHandler : IDownloadHandler
|
|
||||||
{
|
|
||||||
public event EventHandler<DownloadItem> OnBeforeDownloadFired;
|
|
||||||
|
|
||||||
public event EventHandler<DownloadItem> OnDownloadUpdatedFired;
|
|
||||||
|
|
||||||
public void OnBeforeDownload(IWebBrowser chromiumWebBrowser, IBrowser browser, DownloadItem downloadItem, IBeforeDownloadCallback callback)
|
|
||||||
{
|
|
||||||
OnBeforeDownloadFired?.Invoke(this, downloadItem);
|
|
||||||
|
|
||||||
if (!callback.IsDisposed)
|
|
||||||
{
|
|
||||||
using (callback)
|
|
||||||
{
|
|
||||||
callback.Continue(downloadItem.SuggestedFileName, showDialog: true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnDownloadUpdated(IWebBrowser chromiumWebBrowser, IBrowser browser, DownloadItem downloadItem, IDownloadItemCallback callback)
|
|
||||||
{
|
|
||||||
OnDownloadUpdatedFired?.Invoke(this, downloadItem);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
using CefSharp;
|
|
||||||
using System.Diagnostics;
|
|
||||||
using System.Security.Cryptography.X509Certificates;
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.Http
|
|
||||||
{
|
|
||||||
partial class RequestHandler : IRequestHandler
|
|
||||||
{
|
|
||||||
public bool GetAuthCredentials(IWebBrowser chromiumWebBrowser, IBrowser browser, string originUrl, bool isProxy, string host, int port, string realm, string scheme, IAuthCallback callback)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IResourceRequestHandler GetResourceRequestHandler(IWebBrowser chromiumWebBrowser, IBrowser browser, IFrame frame, IRequest request, bool isNavigation, bool isDownload, string requestInitiator, ref bool disableDefaultHandling)
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool OnBeforeBrowse(IWebBrowser chromiumWebBrowser, IBrowser browser, IFrame frame, IRequest request, bool userGesture, bool isRedirect)
|
|
||||||
{
|
|
||||||
if (request.Url.StartsWith(Cef.CefCommitHash))
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Process.Start(request.Url);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnDocumentAvailableInMainFrame(IWebBrowser chromiumWebBrowser, IBrowser browser)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool OnCertificateError(IWebBrowser chromiumWebBrowser, IBrowser browser, CefErrorCode errorCode, string requestUrl, ISslInfo sslInfo, IRequestCallback callback)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool OnOpenUrlFromTab(IWebBrowser chromiumWebBrowser, IBrowser browser, IFrame frame, string targetUrl, WindowOpenDisposition targetDisposition, bool userGesture)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnPluginCrashed(IWebBrowser chromiumWebBrowser, IBrowser browser, string pluginPath)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool OnQuotaRequest(IWebBrowser chromiumWebBrowser, IBrowser browser, string originUrl, long newSize, IRequestCallback callback)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnRenderProcessTerminated(IWebBrowser chromiumWebBrowser, IBrowser browser, CefTerminationStatus status)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnRenderViewReady(IWebBrowser chromiumWebBrowser, IBrowser browser)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool OnSelectClientCertificate(IWebBrowser chromiumWebBrowser, IBrowser browser, bool isProxy, string host, int port, X509Certificate2Collection certificates, ISelectClientCertificateCallback callback)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,11 +1,10 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
using CefSharp;
|
using Microsoft.Web.WebView2.WinForms;
|
||||||
using CefSharp.WinForms;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.UI.Tabs;
|
using mRemoteNG.UI.Tabs;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.Http
|
namespace mRemoteNG.Connection.Protocol.Http
|
||||||
@@ -14,24 +13,22 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
{
|
{
|
||||||
#region Private Properties
|
#region Private Properties
|
||||||
|
|
||||||
private Control wBrowser;
|
private Control _wBrowser;
|
||||||
|
private string _tabTitle;
|
||||||
protected string httpOrS;
|
protected string httpOrS;
|
||||||
protected int defaultPort;
|
protected int defaultPort;
|
||||||
private string tabTitle;
|
|
||||||
private bool browserInitialised = false;
|
|
||||||
private bool connectCalled = false;
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Public Methods
|
#region Public Methods
|
||||||
|
|
||||||
protected HTTPBase(RenderingEngine RenderingEngine)
|
protected HTTPBase(RenderingEngine renderingEngine)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (RenderingEngine == RenderingEngine.CEF)
|
if (renderingEngine == RenderingEngine.EdgeChromium)
|
||||||
{
|
{
|
||||||
Control = new ChromiumWebBrowser("about:blank")
|
Control = new WebView2()
|
||||||
{
|
{
|
||||||
Dock = DockStyle.Fill,
|
Dock = DockStyle.Fill,
|
||||||
};
|
};
|
||||||
@@ -53,33 +50,26 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (InterfaceControl.Parent is ConnectionTab objConnectionTab) tabTitle = objConnectionTab.TabText;
|
if (InterfaceControl.Parent is ConnectionTab objConnectionTab) _tabTitle = objConnectionTab.TabText;
|
||||||
}
|
}
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
tabTitle = "";
|
_tabTitle = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
wBrowser = Control;
|
_wBrowser = Control;
|
||||||
|
|
||||||
if (InterfaceControl.Info.RenderingEngine == RenderingEngine.CEF)
|
if (InterfaceControl.Info.RenderingEngine == RenderingEngine.EdgeChromium)
|
||||||
{
|
{
|
||||||
var CEFBrowser = (ChromiumWebBrowser)wBrowser;
|
var edge = (WebView2)_wBrowser;
|
||||||
if (CEFBrowser != null)
|
|
||||||
{
|
edge.CoreWebView2InitializationCompleted += Edge_CoreWebView2InitializationCompleted;
|
||||||
CEFBrowser.LoadingStateChanged += CefBrowser_LoadingStateChanged;
|
|
||||||
CEFBrowser.TitleChanged += WBrowser_DocumentTitleChanged;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw new Exception("Failed to initialize CEF Rendering Engine.");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
var objWebBrowser = (WebBrowser)wBrowser;
|
var objWebBrowser = (WebBrowser)_wBrowser;
|
||||||
objWebBrowser.ScrollBarsEnabled = true;
|
objWebBrowser.ScrollBarsEnabled = true;
|
||||||
|
|
||||||
// http://stackoverflow.com/questions/4655662/how-to-ignore-script-errors-in-webbrowser
|
// http://stackoverflow.com/questions/4655662/how-to-ignore-script-errors-in-webbrowser
|
||||||
@@ -87,7 +77,6 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
|
|
||||||
objWebBrowser.Navigated += WBrowser_Navigated;
|
objWebBrowser.Navigated += WBrowser_Navigated;
|
||||||
objWebBrowser.DocumentTitleChanged += WBrowser_DocumentTitleChanged;
|
objWebBrowser.DocumentTitleChanged += WBrowser_DocumentTitleChanged;
|
||||||
browserInitialised = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@@ -103,20 +92,16 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (InterfaceControl.Info.RenderingEngine == RenderingEngine.CEF)
|
if (InterfaceControl.Info.RenderingEngine == RenderingEngine.EdgeChromium)
|
||||||
{
|
{
|
||||||
if (browserInitialised)
|
((WebView2)_wBrowser).Source = new Uri(GetUrl());
|
||||||
{
|
|
||||||
((ChromiumWebBrowser)wBrowser).Load(GetURL());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
((WebBrowser)wBrowser).Navigate(GetURL());
|
((WebBrowser)_wBrowser).Navigate(GetUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
base.Connect();
|
base.Connect();
|
||||||
connectCalled = true;
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@@ -130,22 +115,12 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
|
|
||||||
#region Private Methods
|
#region Private Methods
|
||||||
|
|
||||||
private string GetURL()
|
private string GetUrl()
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var strHost = InterfaceControl.Info.Hostname;
|
var strHost = InterfaceControl.Info.Hostname;
|
||||||
/*
|
|
||||||
* Commenting out since this codes doesn't actually do anything at this time...
|
|
||||||
* Possibly related to MR-221 and/or MR-533 ????
|
|
||||||
*
|
|
||||||
string strAuth = "";
|
|
||||||
|
|
||||||
if (((int)Force & (int)ConnectionInfo.Force.NoCredentials) != (int)ConnectionInfo.Force.NoCredentials && !string.IsNullOrEmpty(InterfaceControl.Info.Username) && !string.IsNullOrEmpty(InterfaceControl.Info.Password))
|
|
||||||
{
|
|
||||||
strAuth = "Authorization: Basic " + Convert.ToBase64String(System.Text.Encoding.ASCII.GetBytes(InterfaceControl.Info.Username + ":" + InterfaceControl.Info.Password)) + Environment.NewLine;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
if (InterfaceControl.Info.Port != defaultPort)
|
if (InterfaceControl.Info.Port != defaultPort)
|
||||||
{
|
{
|
||||||
if (strHost.EndsWith("/"))
|
if (strHost.EndsWith("/"))
|
||||||
@@ -161,6 +136,7 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
if (strHost.Contains(httpOrS + "://") == false)
|
if (strHost.Contains(httpOrS + "://") == false)
|
||||||
strHost = httpOrS + "://" + strHost;
|
strHost = httpOrS + "://" + strHost;
|
||||||
}
|
}
|
||||||
|
|
||||||
return strHost;
|
return strHost;
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@@ -174,26 +150,17 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
|
|
||||||
#region Events
|
#region Events
|
||||||
|
|
||||||
private void CefBrowser_LoadingStateChanged(object sender, LoadingStateChangedEventArgs e)
|
private void Edge_CoreWebView2InitializationCompleted(object sender, Microsoft.Web.WebView2.Core.CoreWebView2InitializationCompletedEventArgs e)
|
||||||
{
|
{
|
||||||
browserInitialised = !e.IsLoading;
|
if (!e.IsSuccess)
|
||||||
if (browserInitialised)
|
|
||||||
{
|
{
|
||||||
// Unhook the loading state changes now, as navigation is done by the user on links in the control
|
Runtime.MessageCollector.AddExceptionStackTrace(Language.HttpFailedUrlBuild, e.InitializationException);
|
||||||
((ChromiumWebBrowser)wBrowser).LoadingStateChanged -= CefBrowser_LoadingStateChanged;
|
|
||||||
|
|
||||||
// If this Connection has already been asked to connect but the browser hadn't finished initalising
|
|
||||||
// then the connect wouldn't have been allowed to take place, so now we can call it!
|
|
||||||
if (connectCalled)
|
|
||||||
{
|
|
||||||
Connect();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void WBrowser_Navigated(object sender, WebBrowserNavigatedEventArgs e)
|
private void WBrowser_Navigated(object sender, WebBrowserNavigatedEventArgs e)
|
||||||
{
|
{
|
||||||
if (!(wBrowser is WebBrowser objWebBrowser)) return;
|
if (!(_wBrowser is WebBrowser objWebBrowser)) return;
|
||||||
|
|
||||||
// This can only be set once the WebBrowser control is shown, it will throw a COM exception otherwise.
|
// This can only be set once the WebBrowser control is shown, it will throw a COM exception otherwise.
|
||||||
objWebBrowser.AllowWebBrowserDrop = false;
|
objWebBrowser.AllowWebBrowserDrop = false;
|
||||||
@@ -207,33 +174,18 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
{
|
{
|
||||||
if (!(InterfaceControl.Parent is ConnectionTab tabP)) return;
|
if (!(InterfaceControl.Parent is ConnectionTab tabP)) return;
|
||||||
string shortTitle;
|
string shortTitle;
|
||||||
|
if (((WebBrowser)_wBrowser).DocumentTitle.Length >= 15)
|
||||||
if (InterfaceControl.Info.RenderingEngine == RenderingEngine.CEF)
|
|
||||||
{
|
{
|
||||||
if (((TitleChangedEventArgs)e).Title.Length >= 15)
|
shortTitle = ((WebBrowser)_wBrowser).DocumentTitle.Substring(0, 10) + "...";
|
||||||
{
|
|
||||||
shortTitle = ((TitleChangedEventArgs)e).Title.Substring(0, 10) + "...";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
shortTitle = ((CefSharp.TitleChangedEventArgs)e).Title;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (((WebBrowser)wBrowser).DocumentTitle.Length >= 15)
|
shortTitle = ((WebBrowser)_wBrowser).DocumentTitle;
|
||||||
{
|
|
||||||
shortTitle = ((WebBrowser)wBrowser).DocumentTitle.Substring(0, 10) + "...";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
shortTitle = ((WebBrowser)wBrowser).DocumentTitle;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(tabTitle))
|
if (!string.IsNullOrEmpty(_tabTitle))
|
||||||
{
|
{
|
||||||
tabP.TabText = tabTitle + @" - " + shortTitle;
|
tabP.TabText = _tabTitle + @" - " + shortTitle;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -246,38 +198,6 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void geckoBrowser_DocumentTitleChanged(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (!(InterfaceControl.Parent is ConnectionTab tabP)) return;
|
|
||||||
string shortTitle;
|
|
||||||
|
|
||||||
if (((WebBrowser)wBrowser).DocumentTitle.Length >= 15)
|
|
||||||
{
|
|
||||||
shortTitle = ((WebBrowser)wBrowser).DocumentTitle.Substring(0, 10) + "...";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
shortTitle = ((WebBrowser)wBrowser).DocumentTitle;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(tabTitle))
|
|
||||||
{
|
|
||||||
tabP.TabText = tabTitle + @" - " + shortTitle;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
tabP.TabText = shortTitle;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
Runtime.MessageCollector.AddExceptionStackTrace(Language.HttpDocumentTileChangeFailed, ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Enums
|
#region Enums
|
||||||
@@ -288,7 +208,7 @@ namespace mRemoteNG.Connection.Protocol.Http
|
|||||||
IE = 1,
|
IE = 1,
|
||||||
|
|
||||||
[LocalizedAttributes.LocalizedDescription(nameof(Language.HttpCEF))]
|
[LocalizedAttributes.LocalizedDescription(nameof(Language.HttpCEF))]
|
||||||
CEF = 2
|
EdgeChromium = 2
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ using System.Windows.Forms;
|
|||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol
|
namespace mRemoteNG.Connection.Protocol
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ using System;
|
|||||||
using mRemoteNG.Connection.Protocol.PowerShell;
|
using mRemoteNG.Connection.Protocol.PowerShell;
|
||||||
using mRemoteNG.Properties;
|
using mRemoteNG.Properties;
|
||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Resources.Language;
|
||||||
|
using mRemoteNG.Connection.Protocol.Winbox;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol
|
namespace mRemoteNG.Connection.Protocol
|
||||||
{
|
{
|
||||||
@@ -49,6 +50,8 @@ namespace mRemoteNG.Connection.Protocol
|
|||||||
throw (new Exception(Language.NoExtAppDefined));
|
throw (new Exception(Language.NoExtAppDefined));
|
||||||
}
|
}
|
||||||
return new IntegratedProgram();
|
return new IntegratedProgram();
|
||||||
|
case ProtocolType.Winbox:
|
||||||
|
return new ProtocolWinbox();
|
||||||
}
|
}
|
||||||
|
|
||||||
return default(ProtocolBase);
|
return default(ProtocolBase);
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol
|
namespace mRemoteNG.Connection.Protocol
|
||||||
{
|
{
|
||||||
@@ -36,6 +36,9 @@ namespace mRemoteNG.Connection.Protocol
|
|||||||
PowerShell = 10,
|
PowerShell = 10,
|
||||||
|
|
||||||
[LocalizedAttributes.LocalizedDescription(nameof(Language.ExternalTool))]
|
[LocalizedAttributes.LocalizedDescription(nameof(Language.ExternalTool))]
|
||||||
IntApp = 20
|
IntApp = 20,
|
||||||
|
|
||||||
|
[LocalizedAttributes.LocalizedDescription(nameof(Language.Winbox))]
|
||||||
|
Winbox = 11
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -82,6 +82,19 @@ namespace mRemoteNG.Connection.Protocol
|
|||||||
var username = "";
|
var username = "";
|
||||||
var password = "";
|
var password = "";
|
||||||
|
|
||||||
|
// access secret server api if necessary
|
||||||
|
if (!string.IsNullOrEmpty(InterfaceControl.Info?.UserViaAPI))
|
||||||
|
{
|
||||||
|
var domain = ""; // dummy
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ExternalConnectors.TSS.SecretServerInterface.FetchSecretFromServer("SSAPI:" + InterfaceControl.Info?.UserViaAPI, out username, out password, out domain);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Event_ErrorOccured(this, "Secret Server Interface Error: " + ex.Message, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
if (!string.IsNullOrEmpty(InterfaceControl.Info?.Username))
|
if (!string.IsNullOrEmpty(InterfaceControl.Info?.Username))
|
||||||
{
|
{
|
||||||
username = InterfaceControl.Info.Username;
|
username = InterfaceControl.Info.Username;
|
||||||
@@ -188,6 +201,13 @@ namespace mRemoteNG.Connection.Protocol
|
|||||||
string.Format(Language.PanelHandle,
|
string.Format(Language.PanelHandle,
|
||||||
InterfaceControl.Parent.Handle), true);
|
InterfaceControl.Parent.Handle), true);
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(InterfaceControl.Info?.OpeningCommand))
|
||||||
|
{
|
||||||
|
NativeMethods.SetForegroundWindow(PuttyHandle);
|
||||||
|
var finalCommand = InterfaceControl.Info.OpeningCommand.TrimEnd() + "\n";
|
||||||
|
SendKeys.SendWait(finalCommand);
|
||||||
|
}
|
||||||
|
|
||||||
Resize(this, new EventArgs());
|
Resize(this, new EventArgs());
|
||||||
base.Connect();
|
base.Connect();
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -4,8 +4,8 @@ using System.Windows.Forms;
|
|||||||
using AxMSTSCLib;
|
using AxMSTSCLib;
|
||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using MSTSCLib;
|
using MSTSCLib;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.RDP
|
namespace mRemoteNG.Connection.Protocol.RDP
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -3,36 +3,20 @@ using System.Threading;
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Net.Sockets;
|
using System.Net.Sockets;
|
||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using mRemoteNG.UI.Forms;
|
using mRemoteNG.UI.Forms;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
// ReSharper disable ArrangeAccessorOwnerBody
|
// ReSharper disable ArrangeAccessorOwnerBody
|
||||||
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.VNC
|
namespace mRemoteNG.Connection.Protocol.VNC
|
||||||
{
|
{
|
||||||
public class ProtocolVNC : ProtocolBase, ISupportsViewOnly
|
public class ProtocolVNC : ProtocolBase
|
||||||
{
|
{
|
||||||
#region Properties
|
|
||||||
|
|
||||||
public bool SmartSize
|
|
||||||
{
|
|
||||||
get => _vnc.Scaled;
|
|
||||||
set => _vnc.Scaled = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool ViewOnly
|
|
||||||
{
|
|
||||||
get => _vnc.ViewOnly;
|
|
||||||
set => _vnc.ViewOnly = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region Private Declarations
|
#region Private Declarations
|
||||||
|
|
||||||
private VncSharp.RemoteDesktop _vnc;
|
private VncSharpCore.RemoteDesktop _vnc;
|
||||||
private ConnectionInfo _info;
|
private ConnectionInfo _info;
|
||||||
private static bool _isConnectionSuccessful;
|
private static bool _isConnectionSuccessful;
|
||||||
private static Exception _socketexception;
|
private static Exception _socketexception;
|
||||||
@@ -44,7 +28,7 @@ namespace mRemoteNG.Connection.Protocol.VNC
|
|||||||
|
|
||||||
public ProtocolVNC()
|
public ProtocolVNC()
|
||||||
{
|
{
|
||||||
Control = new VncSharp.RemoteDesktop();
|
Control = new VncSharpCore.RemoteDesktop();
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Initialize()
|
public override bool Initialize()
|
||||||
@@ -53,7 +37,7 @@ namespace mRemoteNG.Connection.Protocol.VNC
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_vnc = (VncSharp.RemoteDesktop)Control;
|
_vnc = (VncSharpCore.RemoteDesktop)Control;
|
||||||
_info = InterfaceControl.Info;
|
_info = InterfaceControl.Info;
|
||||||
_vnc.VncPort = _info.Port;
|
_vnc.VncPort = _info.Port;
|
||||||
|
|
||||||
@@ -109,10 +93,10 @@ namespace mRemoteNG.Connection.Protocol.VNC
|
|||||||
switch (Keys)
|
switch (Keys)
|
||||||
{
|
{
|
||||||
case SpecialKeys.CtrlAltDel:
|
case SpecialKeys.CtrlAltDel:
|
||||||
_vnc.SendSpecialKeys(VncSharp.SpecialKeys.CtrlAltDel);
|
_vnc.SendSpecialKeys(VncSharpCore.SpecialKeys.CtrlAltDel);
|
||||||
break;
|
break;
|
||||||
case SpecialKeys.CtrlEsc:
|
case SpecialKeys.CtrlEsc:
|
||||||
_vnc.SendSpecialKeys(VncSharp.SpecialKeys.CtrlEsc);
|
_vnc.SendSpecialKeys(VncSharpCore.SpecialKeys.CtrlEsc);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -124,36 +108,6 @@ namespace mRemoteNG.Connection.Protocol.VNC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ToggleSmartSize()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
SmartSize = !SmartSize;
|
|
||||||
RefreshScreen();
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
Runtime.MessageCollector.AddMessage(Messages.MessageClass.ErrorMsg,
|
|
||||||
Language.VncToggleSmartSizeFailed + Environment.NewLine +
|
|
||||||
ex.Message, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void ToggleViewOnly()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ViewOnly = !ViewOnly;
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
Runtime.MessageCollector.AddMessage(Messages.MessageClass.ErrorMsg,
|
|
||||||
Language.VncToggleViewOnlyFailed + Environment.NewLine +
|
|
||||||
ex.Message, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void StartChat()
|
public void StartChat()
|
||||||
{
|
{
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection.Protocol.VNC
|
namespace mRemoteNG.Connection.Protocol.VNC
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -0,0 +1,243 @@
|
|||||||
|
using System;
|
||||||
|
using System.Threading;
|
||||||
|
using mRemoteNG.App;
|
||||||
|
using mRemoteNG.Messages;
|
||||||
|
using mRemoteNG.Security.SymmetricEncryption;
|
||||||
|
using mRemoteNG.Tools.Cmdline;
|
||||||
|
using mRemoteNG.UI;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
using mRemoteNG.Properties;
|
||||||
|
|
||||||
|
namespace mRemoteNG.Connection.Protocol.Winbox
|
||||||
|
{
|
||||||
|
public class ProtocolWinbox : ProtocolBase
|
||||||
|
{
|
||||||
|
public ProtocolWinbox() { }
|
||||||
|
|
||||||
|
public enum Defaults
|
||||||
|
{
|
||||||
|
Port = 8291
|
||||||
|
}
|
||||||
|
|
||||||
|
private const int IDM_RECONF = 0x50; // PuTTY Settings Menu ID
|
||||||
|
private readonly DisplayProperties _display = new DisplayProperties();
|
||||||
|
|
||||||
|
#region Public Properties
|
||||||
|
|
||||||
|
|
||||||
|
public IntPtr WinboxHandle { get; set; }
|
||||||
|
|
||||||
|
private Process WinboxProcess { get; set; }
|
||||||
|
|
||||||
|
public static string WinboxPath { get; set; }
|
||||||
|
|
||||||
|
public bool Focused
|
||||||
|
{
|
||||||
|
get { return NativeMethods.GetForegroundWindow() == WinboxHandle; }
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Private Events & Handlers
|
||||||
|
|
||||||
|
private void ProcessExited(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
Event_Closed(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Public Methods
|
||||||
|
|
||||||
|
public override bool Connect()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
|
||||||
|
WinboxProcess = new Process
|
||||||
|
{
|
||||||
|
StartInfo =
|
||||||
|
{
|
||||||
|
UseShellExecute = false,
|
||||||
|
FileName = WinboxPath,
|
||||||
|
RedirectStandardOutput = true
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var arguments = new CommandLineArguments { EscapeForShell = false };
|
||||||
|
|
||||||
|
var username = "";
|
||||||
|
var password = "";
|
||||||
|
var host = InterfaceControl.Info.Hostname;
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(InterfaceControl.Info?.Username))
|
||||||
|
{
|
||||||
|
username = InterfaceControl.Info.Username;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// ReSharper disable once SwitchStatementMissingSomeCases
|
||||||
|
switch (Settings.Default.EmptyCredentials)
|
||||||
|
{
|
||||||
|
case "windows":
|
||||||
|
username = Environment.UserName;
|
||||||
|
break;
|
||||||
|
case "custom":
|
||||||
|
username = Settings.Default.DefaultUsername;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(InterfaceControl.Info?.Password))
|
||||||
|
{
|
||||||
|
password = InterfaceControl.Info.Password;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (Settings.Default.EmptyCredentials == "custom")
|
||||||
|
{
|
||||||
|
var cryptographyProvider = new LegacyRijndaelCryptographyProvider();
|
||||||
|
password = cryptographyProvider.Decrypt(Settings.Default.DefaultPassword,
|
||||||
|
Runtime.EncryptionKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!InterfaceControl.Info.Port.Equals(Defaults.Port))
|
||||||
|
{
|
||||||
|
host += ":" + InterfaceControl.Info.Port.ToString();
|
||||||
|
}
|
||||||
|
arguments.Add(host, username, password);
|
||||||
|
|
||||||
|
WinboxProcess.StartInfo.Arguments = arguments.ToString();
|
||||||
|
|
||||||
|
WinboxProcess.EnableRaisingEvents = true;
|
||||||
|
WinboxProcess.Exited += ProcessExited;
|
||||||
|
|
||||||
|
WinboxProcess.Start();
|
||||||
|
WinboxProcess.WaitForInputIdle(Settings.Default.MaxPuttyWaitTime * 1000);
|
||||||
|
while (!WinboxProcess.StandardOutput.EndOfStream)
|
||||||
|
{
|
||||||
|
var line = WinboxProcess.StandardOutput.ReadLine();
|
||||||
|
Console.WriteLine(line);
|
||||||
|
if (line.Contains("startServices done"))
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.DebugMsg, "Winbox - Find connection done");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else if (line.Contains("disconnect"))
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.DebugMsg, "Winbox - Cannot Connect");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var startTicks = Environment.TickCount;
|
||||||
|
while (WinboxHandle.ToInt32() == 0 &
|
||||||
|
Environment.TickCount < startTicks + Settings.Default.MaxPuttyWaitTime * 1000)
|
||||||
|
{
|
||||||
|
WinboxHandle = NativeMethods.FindWindowEx(InterfaceControl.Handle, new IntPtr(0), null, null);
|
||||||
|
WinboxProcess.Refresh();
|
||||||
|
WinboxHandle = WinboxProcess.MainWindowHandle;
|
||||||
|
if (WinboxHandle.ToInt32() == 0)
|
||||||
|
{
|
||||||
|
Thread.Sleep(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
NativeMethods.SetParent(WinboxHandle, InterfaceControl.Handle);
|
||||||
|
|
||||||
|
Resize(this, new EventArgs());
|
||||||
|
base.Connect();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.ErrorMsg, Language.ConnectionFailed + Environment.NewLine + ex.Message);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Focus()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
NativeMethods.SetForegroundWindow(WinboxHandle);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.ErrorMsg, Language.PuttyFocusFailed + Environment.NewLine + ex.Message, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Resize(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (InterfaceControl.Size == Size.Empty)
|
||||||
|
return;
|
||||||
|
|
||||||
|
//NativeMethods.MoveWindow(WinboxHandle, 0, 0, InterfaceControl.Width, InterfaceControl.Height, true);
|
||||||
|
var scaledFrameBorderHeight = _display.ScaleHeight(SystemInformation.FrameBorderSize.Height);
|
||||||
|
var scaledFrameBorderWidth = _display.ScaleWidth(SystemInformation.FrameBorderSize.Width);
|
||||||
|
|
||||||
|
NativeMethods.MoveWindow(WinboxHandle, -scaledFrameBorderWidth,
|
||||||
|
-(SystemInformation.CaptionHeight + scaledFrameBorderHeight),
|
||||||
|
InterfaceControl.Width + scaledFrameBorderWidth * 2,
|
||||||
|
InterfaceControl.Height + SystemInformation.CaptionHeight +
|
||||||
|
scaledFrameBorderHeight * 2,
|
||||||
|
true);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.ErrorMsg, Language.PuttyResizeFailed + Environment.NewLine + ex.Message, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Close()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (WinboxProcess.HasExited == false)
|
||||||
|
{
|
||||||
|
WinboxProcess.Kill();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.ErrorMsg, "Winbox - Kill process failed" + Environment.NewLine + ex.Message, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
WinboxProcess.Dispose();
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Runtime.MessageCollector.AddMessage(MessageClass.ErrorMsg, Language.PuttyDisposeFailed + Environment.NewLine + ex.Message, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
base.Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ShowSettingsDialog()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Enums
|
||||||
|
|
||||||
|
protected enum Winbox_Protocol
|
||||||
|
{
|
||||||
|
winbox = 0,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
using mRemoteNG.App;
|
using mRemoteNG.App;
|
||||||
using mRemoteNG.Messages;
|
using mRemoteNG.Messages;
|
||||||
using mRemoteNG.Tools;
|
using mRemoteNG.Tools;
|
||||||
using System;
|
using System;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Resources.Language;
|
|
||||||
using mRemoteNG.Tree;
|
using mRemoteNG.Tree;
|
||||||
using mRemoteNG.Tree.Root;
|
using mRemoteNG.Tree.Root;
|
||||||
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using mRemoteNG.Connection.Protocol;
|
using mRemoteNG.App;
|
||||||
|
using mRemoteNG.Connection.Protocol;
|
||||||
using mRemoteNG.Resources.Language;
|
using mRemoteNG.Resources.Language;
|
||||||
|
|
||||||
namespace mRemoteNG.Connection
|
namespace mRemoteNG.Connection
|
||||||
@@ -17,8 +18,7 @@ namespace mRemoteNG.Connection
|
|||||||
if (string.IsNullOrEmpty(connectionInfo.Panel))
|
if (string.IsNullOrEmpty(connectionInfo.Panel))
|
||||||
connectionInfo.Panel = Language.General;
|
connectionInfo.Panel = Language.General;
|
||||||
connectionInfo.IsQuickConnect = true;
|
connectionInfo.IsQuickConnect = true;
|
||||||
var connectionInitiator = new ConnectionInitiator();
|
Runtime.ConnectionInitiator.OpenConnection(connectionInfo, ConnectionInfo.Force.DoNotJump);
|
||||||
connectionInitiator.OpenConnection(connectionInfo, ConnectionInfo.Force.DoNotJump);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user