mirror of
https://gitee.com/ThingsGateway/ThingsGateway.git
synced 2025-10-21 03:01:28 +08:00
Compare commits
995 Commits
6.0.3.31
...
10.11.84.0
Author | SHA1 | Date | |
---|---|---|---|
![]() |
42c740fa1b | ||
![]() |
556819c90c | ||
![]() |
2522333a9c | ||
![]() |
bd4ce7c09b | ||
![]() |
156ed88bd6 | ||
![]() |
2416226eb0 | ||
![]() |
976323a716 | ||
![]() |
3c9e397403 | ||
![]() |
79406ad4a0 | ||
![]() |
20c44f10ca | ||
![]() |
31d6b2a9e6 | ||
![]() |
68e5a9c546 | ||
![]() |
b2ea9f99b9 | ||
![]() |
6d7d0e468a | ||
![]() |
ff1f632de2 | ||
![]() |
fc3d7015ee | ||
![]() |
40c5acb522 | ||
![]() |
f9cc1cbb05 | ||
![]() |
cf6e8b58f0 | ||
![]() |
615e3bb24c | ||
![]() |
4a7534b210 | ||
![]() |
58e099cb93 | ||
![]() |
a94a9c953c | ||
![]() |
35e1ffa3e9 | ||
![]() |
4921642151 | ||
![]() |
d71ee29da8 | ||
![]() |
901aa2d59f | ||
![]() |
764957c014 | ||
![]() |
0e3898218b | ||
![]() |
61f13cef3c | ||
![]() |
0b663d9e01 | ||
![]() |
6c95c6209f | ||
![]() |
4d223d2622 | ||
![]() |
e8d7e91b64 | ||
![]() |
8175f541ec | ||
![]() |
0adbdb926b | ||
![]() |
42adee9980 | ||
![]() |
427a7404bc | ||
![]() |
3658199e0a | ||
![]() |
82eedee50a | ||
![]() |
6a18fc3e06 | ||
![]() |
c37e314ed6 | ||
![]() |
a937a85d90 | ||
![]() |
35dd4ae9d3 | ||
![]() |
0b829ac85c | ||
![]() |
aa247422d2 | ||
![]() |
2e00e8c135 | ||
![]() |
34dd2cf0a7 | ||
![]() |
8404e20c5e | ||
![]() |
662aa162e9 | ||
![]() |
5927738c32 | ||
![]() |
3c9f97a5c3 | ||
![]() |
179ca0aa0e | ||
![]() |
fc09a52da1 | ||
![]() |
5436b91c89 | ||
![]() |
d1c46f51a6 | ||
![]() |
4539d8d198 | ||
![]() |
9ea9529a5f | ||
![]() |
4e6be23aac | ||
![]() |
2fabbd236b | ||
![]() |
163a66530e | ||
![]() |
29073a00c4 | ||
![]() |
c6d4d1ecfa | ||
![]() |
ba16889cad | ||
![]() |
5aaed35b0f | ||
![]() |
df067c91eb | ||
![]() |
2078b4a60b | ||
![]() |
20a2e3ff8e | ||
![]() |
61a973b1b5 | ||
![]() |
cbd72e2081 | ||
![]() |
4e0377b20c | ||
![]() |
fd318d3cdc | ||
![]() |
515bdb9700 | ||
![]() |
46c1780017 | ||
![]() |
fe78a4c3ca | ||
![]() |
2d7effadf9 | ||
![]() |
346c560f8b | ||
![]() |
8e3bd89f61 | ||
![]() |
6da142d080 | ||
![]() |
ff7d029e6f | ||
![]() |
21b4695683 | ||
![]() |
02ad494a26 | ||
![]() |
280366e1b2 | ||
![]() |
6660ce3e34 | ||
![]() |
7499162c1a | ||
![]() |
40208a5cd6 | ||
![]() |
fa347f4f68 | ||
![]() |
d7df6fc605 | ||
![]() |
eb4bb2fd48 | ||
![]() |
faa9858974 | ||
![]() |
1b3d2dda49 | ||
![]() |
a8a9453611 | ||
![]() |
e84f42ce14 | ||
![]() |
6f814cf6b8 | ||
![]() |
e36432e4e9 | ||
![]() |
ebd71e807b | ||
![]() |
34000d8d7d | ||
![]() |
e785f6660c | ||
![]() |
831c611797 | ||
![]() |
453817ef86 | ||
![]() |
8ce0b981c1 | ||
![]() |
4e5c51b54c | ||
![]() |
3cc9d31f28 | ||
![]() |
10391f869b | ||
![]() |
fba0723a6d | ||
![]() |
2db3f78f0c | ||
![]() |
badf61fe01 | ||
![]() |
d74e0952dc | ||
![]() |
fb1699ce80 | ||
![]() |
44adddbcd4 | ||
![]() |
0eab889452 | ||
![]() |
e14d39a459 | ||
![]() |
7575264ede | ||
![]() |
3e1a077b96 | ||
![]() |
a921cb8400 | ||
![]() |
4de7c31ed7 | ||
![]() |
08326a2cfd | ||
![]() |
e045de5acb | ||
![]() |
d3bef31aa6 | ||
![]() |
347d4d6e5d | ||
![]() |
b006a066e1 | ||
![]() |
e331bc5d3c | ||
![]() |
2e81806231 | ||
![]() |
37b48cf221 | ||
![]() |
5997487434 | ||
![]() |
4ce843182f | ||
![]() |
a4aa000cf0 | ||
![]() |
01aa6ca066 | ||
![]() |
10a0280c4a | ||
![]() |
3b8b00c783 | ||
![]() |
232ee5d5d4 | ||
![]() |
605830edce | ||
![]() |
ca86441e05 | ||
![]() |
b30b876c5f | ||
![]() |
f95590b4cb | ||
![]() |
9921130406 | ||
![]() |
5c47589ca1 | ||
![]() |
048abfae2e | ||
![]() |
8e35c16edf | ||
![]() |
143b751213 | ||
![]() |
2cafe745b9 | ||
![]() |
210ac2c122 | ||
![]() |
4707ce6d58 | ||
![]() |
788a8b670d | ||
![]() |
5e4f0057e4 | ||
![]() |
2960c13ef1 | ||
![]() |
f11b7f7ab4 | ||
![]() |
9bb9cd7419 | ||
![]() |
ba008ef8ba | ||
![]() |
28b533decf | ||
![]() |
9ee638c2f1 | ||
![]() |
d90fdbaf35 | ||
![]() |
b55e3db736 | ||
![]() |
dbee8496cb | ||
![]() |
044e78bea9 | ||
![]() |
fe79128d90 | ||
![]() |
34120da008 | ||
![]() |
4c62bb0b21 | ||
![]() |
46b16279c7 | ||
![]() |
0779efc5dd | ||
![]() |
8acdb780e8 | ||
![]() |
2e310b919e | ||
![]() |
4155c07269 | ||
![]() |
32fa833736 | ||
![]() |
2258f08555 | ||
![]() |
d90b32f165 | ||
![]() |
1492377322 | ||
![]() |
32eefbf545 | ||
![]() |
a825ca5f6f | ||
![]() |
e270b0c4f6 | ||
![]() |
6ae44ccf58 | ||
![]() |
1aa0df6339 | ||
![]() |
62c3693dbe | ||
![]() |
e4e503c97b | ||
![]() |
5ec1ee7627 | ||
![]() |
79789388fc | ||
![]() |
2c4194ee18 | ||
![]() |
1b2be585af | ||
![]() |
83736647e7 | ||
![]() |
b06405717d | ||
![]() |
298a1f2ed4 | ||
![]() |
74a47a1983 | ||
![]() |
a48a42abe4 | ||
![]() |
feb1d0a3c5 | ||
![]() |
92bca824e6 | ||
![]() |
025c699517 | ||
![]() |
53f8fbe4b1 | ||
![]() |
77bfabc41d | ||
![]() |
6427ee6ee0 | ||
![]() |
4c95997d62 | ||
![]() |
1d82cea40d | ||
![]() |
e78799424c | ||
![]() |
1000c8d38f | ||
![]() |
b2589fc634 | ||
![]() |
c80e57a4e8 | ||
![]() |
6510c3e289 | ||
![]() |
920e407d05 | ||
![]() |
7314c8901d | ||
![]() |
4e9f02b48c | ||
![]() |
9ae7602cb4 | ||
![]() |
aa8aa36aef | ||
![]() |
0174f7c6f2 | ||
![]() |
df9e7d6ff1 | ||
![]() |
b40ca920d3 | ||
![]() |
5a4b0a0e93 | ||
![]() |
a879edd68b | ||
![]() |
62e0a6ee9d | ||
![]() |
765e5564d4 | ||
![]() |
10eecac19b | ||
![]() |
59241b8faa | ||
![]() |
52b3097f04 | ||
![]() |
d922296b70 | ||
![]() |
aec91da28b | ||
![]() |
013ff394be | ||
![]() |
081e07473d | ||
![]() |
d33d900592 | ||
![]() |
29365c4ef9 | ||
![]() |
17a6189089 | ||
![]() |
003b8a3763 | ||
![]() |
1c7f8b5cab | ||
![]() |
b7ff9ffca2 | ||
![]() |
9bba9bda76 | ||
![]() |
ec2fcc75d3 | ||
![]() |
57a4038577 | ||
![]() |
b78a76e60f | ||
![]() |
28bd751d44 | ||
![]() |
dcba7b9810 | ||
![]() |
7f1a741ce6 | ||
![]() |
ca2b17d433 | ||
![]() |
af589eac10 | ||
![]() |
573670f1f5 | ||
![]() |
f3ec85a03d | ||
![]() |
c94308454f | ||
![]() |
c9c2b2b69d | ||
![]() |
40574b776f | ||
![]() |
f426c1533d | ||
![]() |
4a3b5163f1 | ||
![]() |
3a0946d357 | ||
![]() |
9dd21c644c | ||
![]() |
6713190a23 | ||
![]() |
9f24533425 | ||
![]() |
ed1d9374eb | ||
![]() |
f14d27129e | ||
![]() |
5b04f02fbe | ||
![]() |
227080e332 | ||
![]() |
1e87482a49 | ||
![]() |
054d31c3ea | ||
![]() |
3a068a7b03 | ||
![]() |
b12e923c99 | ||
![]() |
ab33eed8d3 | ||
![]() |
d930a9a8eb | ||
![]() |
af381fce12 | ||
![]() |
b64ac0539e | ||
![]() |
541c60b363 | ||
![]() |
824e95f7cb | ||
![]() |
38f7850196 | ||
![]() |
bef9de88e2 | ||
![]() |
48cd5e7c7f | ||
![]() |
3b44fda51c | ||
![]() |
dbfc9a5bb4 | ||
![]() |
1b758aa41a | ||
![]() |
43bdc70899 | ||
![]() |
fadda000a6 | ||
![]() |
45a8c91a5a | ||
![]() |
8e938f18be | ||
![]() |
ab1b364c54 | ||
![]() |
5ec65b2fb0 | ||
![]() |
926eced724 | ||
![]() |
f7f8802272 | ||
![]() |
c6910dff02 | ||
![]() |
ad299d0dbb | ||
![]() |
8b124d1050 | ||
![]() |
ff41080dbd | ||
![]() |
0e28606e3d | ||
![]() |
6a025ceee5 | ||
![]() |
6b2e53d6dc | ||
![]() |
b989aa5561 | ||
![]() |
f5b0b7ebd2 | ||
![]() |
16881ae076 | ||
![]() |
af04112656 | ||
![]() |
a2863112dc | ||
![]() |
f531e4dfc5 | ||
![]() |
8db9b32ba7 | ||
![]() |
dd5691cbef | ||
![]() |
de48b32af3 | ||
![]() |
600b5042a1 | ||
![]() |
aac77029da | ||
![]() |
e50205f557 | ||
![]() |
e227411d1f | ||
![]() |
2de0ed793f | ||
![]() |
cb0276f273 | ||
![]() |
562b3f17c9 | ||
![]() |
0f78f81c1c | ||
![]() |
6594937d0a | ||
![]() |
64bc6084be | ||
![]() |
20434d5bd2 | ||
![]() |
9ecc9380e6 | ||
![]() |
a57c55080b | ||
![]() |
b8ca06c6be | ||
![]() |
5aff6461a1 | ||
![]() |
6cf53fefec | ||
![]() |
45132f3503 | ||
![]() |
f1e78a0e8a | ||
![]() |
0bf28ec275 | ||
![]() |
41f8412c97 | ||
![]() |
c535974362 | ||
![]() |
1860c5f215 | ||
![]() |
6d778b2d39 | ||
![]() |
f48b99c259 | ||
![]() |
3c73b93051 | ||
![]() |
98f3f2d519 | ||
![]() |
b76b4e8d68 | ||
![]() |
07285a7c61 | ||
![]() |
03c0dfef37 | ||
![]() |
6ef6929c35 | ||
![]() |
e3c0c173f0 | ||
![]() |
7d64e058d4 | ||
![]() |
e97ee9b64b | ||
![]() |
6a03e39eeb | ||
![]() |
525ec740b5 | ||
![]() |
b790cf5f4e | ||
![]() |
d1248811fd | ||
![]() |
022d016e8e | ||
![]() |
f73245e650 | ||
![]() |
484461fa05 | ||
![]() |
7e0b7aff2a | ||
![]() |
6c450dcb09 | ||
![]() |
227f44283f | ||
![]() |
74f6e79625 | ||
![]() |
cec43e2ce8 | ||
![]() |
7553b258bb | ||
![]() |
8bdbdc117e | ||
![]() |
0e206be296 | ||
![]() |
00b7353433 | ||
![]() |
44e7a83593 | ||
![]() |
dd68d555d4 | ||
![]() |
0456296103 | ||
![]() |
a1b66277ff | ||
![]() |
50758b79bc | ||
![]() |
06a1f902ad | ||
![]() |
58f8b23b7c | ||
![]() |
9e7c348b15 | ||
![]() |
5f5ff8b43b | ||
![]() |
f626b4e5fc | ||
![]() |
bc23200e66 | ||
![]() |
95ab59fd5a | ||
![]() |
0bbee003b0 | ||
![]() |
d20cb7a928 | ||
![]() |
952c134aba | ||
![]() |
5533d980e3 | ||
![]() |
aa0213818f | ||
![]() |
af88ffd57c | ||
![]() |
87447b1c2a | ||
![]() |
384a12880b | ||
![]() |
791f91f377 | ||
![]() |
4f8b405cc3 | ||
![]() |
e1b7af201a | ||
![]() |
a04b7817a9 | ||
![]() |
21bf83aec7 | ||
![]() |
d060d5179d | ||
![]() |
e73dd58e46 | ||
![]() |
a34e4a6942 | ||
![]() |
a7ee6d78b5 | ||
![]() |
0a6651ac11 | ||
![]() |
fa25053c13 | ||
![]() |
61dd4edeb5 | ||
![]() |
dbaeff302b | ||
![]() |
6cbe7ebcf2 | ||
![]() |
2826e08c8c | ||
![]() |
e30e337efa | ||
![]() |
39788e0357 | ||
![]() |
c47363df71 | ||
![]() |
4199453038 | ||
![]() |
db991081c8 | ||
![]() |
24f946a727 | ||
![]() |
772dae047a | ||
![]() |
020f440fdd | ||
![]() |
c88fc5ec09 | ||
![]() |
475849fbef | ||
![]() |
1d63228fb2 | ||
![]() |
c918c0c010 | ||
![]() |
1028179983 | ||
![]() |
686f61ff90 | ||
![]() |
ae43fadca3 | ||
![]() |
1bf05780b3 | ||
![]() |
3e30daa1d3 | ||
![]() |
54ef1233b1 | ||
![]() |
4413633de7 | ||
![]() |
c76e20d146 | ||
![]() |
36d53b7ce4 | ||
![]() |
0b0bce2761 | ||
![]() |
d47a9be03c | ||
![]() |
bc32d7ae7a | ||
![]() |
e6747a2c2c | ||
![]() |
3fb48cb64e | ||
![]() |
381db1cf53 | ||
![]() |
d3939aeb9d | ||
![]() |
5956f90557 | ||
![]() |
7f54ecfe5d | ||
![]() |
e7bda99c8b | ||
![]() |
ea7ab5a2bf | ||
![]() |
ee566d199a | ||
![]() |
56eca454b1 | ||
![]() |
d057974c3e | ||
![]() |
9514e7fdea | ||
![]() |
e546113873 | ||
![]() |
60f1139355 | ||
![]() |
1b18b59054 | ||
![]() |
afec0187e9 | ||
![]() |
d0d7e1ccf8 | ||
![]() |
d72376b4b7 | ||
![]() |
3be60cb305 | ||
![]() |
75b1f351a1 | ||
![]() |
07185f8018 | ||
![]() |
2f081b62a7 | ||
![]() |
bbce2a11e1 | ||
![]() |
96ab609157 | ||
![]() |
d961d56a35 | ||
![]() |
82a5335a92 | ||
![]() |
729a23949c | ||
![]() |
a1b0419d7a | ||
![]() |
7a23015b9d | ||
![]() |
9cbe0dbae1 | ||
![]() |
4f139b7d03 | ||
![]() |
1e925e2560 | ||
![]() |
a42e1e3af3 | ||
![]() |
799caec7ee | ||
![]() |
dd7d30498f | ||
![]() |
e9b1720e98 | ||
![]() |
5f41371bdb | ||
![]() |
5226bfae20 | ||
![]() |
d1eab168b7 | ||
![]() |
8760518c10 | ||
![]() |
6719a352c2 | ||
![]() |
8449b6c6b8 | ||
![]() |
0550eaf465 | ||
![]() |
bdc9eb44ec | ||
![]() |
37b99cb1b0 | ||
![]() |
492381e4fc | ||
![]() |
27d65dd799 | ||
![]() |
434724310c | ||
![]() |
e5ad5a8521 | ||
![]() |
3942819fed | ||
![]() |
1cc5f538aa | ||
![]() |
b0d8534ea4 | ||
![]() |
5b2bc38670 | ||
![]() |
b36aa3557c | ||
![]() |
a1a525e6e3 | ||
![]() |
14453cc437 | ||
![]() |
db760ba5d8 | ||
![]() |
4ae692008f | ||
![]() |
f37449f9ac | ||
![]() |
8b7348b3d4 | ||
![]() |
709cbb7b2e | ||
![]() |
187f1a4ce2 | ||
![]() |
0f2ebd3a54 | ||
![]() |
86b63c2792 | ||
![]() |
cec2e71b41 | ||
![]() |
9380f3e1ec | ||
![]() |
76c2934e12 | ||
![]() |
9714c35d4b | ||
![]() |
0d9beb713a | ||
![]() |
c5f8d0e0b7 | ||
![]() |
5e8f4b075d | ||
![]() |
4b53fca3db | ||
![]() |
5d9c030a09 | ||
![]() |
bacbb9a28e | ||
![]() |
7c287e0c03 | ||
![]() |
10f675137d | ||
![]() |
6bdb5328e3 | ||
![]() |
14f529ac4e | ||
![]() |
ffe96d9ef1 | ||
![]() |
335f264caa | ||
![]() |
b73e86ea9f | ||
![]() |
2bc2c4c57b | ||
![]() |
6f87c2f03a | ||
![]() |
75e677af88 | ||
![]() |
9ffe355396 | ||
![]() |
60b0fb23f8 | ||
![]() |
1c05ffc6ed | ||
![]() |
8cd4e43c68 | ||
![]() |
8486d28310 | ||
![]() |
e8aadda185 | ||
![]() |
fcfd0428ab | ||
![]() |
ddcc087800 | ||
![]() |
d574de54b4 | ||
![]() |
1682ac03ac | ||
![]() |
447dbece1c | ||
![]() |
dcca901b17 | ||
![]() |
a32c779074 | ||
![]() |
187c0f9829 | ||
![]() |
6c970c88ab | ||
![]() |
28a4520c77 | ||
![]() |
02d0dcdff7 | ||
![]() |
427d4e31c9 | ||
![]() |
c60f7aac44 | ||
![]() |
42a7758a34 | ||
![]() |
e0bade4670 | ||
![]() |
6af83152de | ||
![]() |
091a30045d | ||
![]() |
b2c8ae0c33 | ||
![]() |
8b6e0982c6 | ||
![]() |
caa3ebd600 | ||
![]() |
d248e047b3 | ||
![]() |
25a95a1de0 | ||
![]() |
d506b2c692 | ||
![]() |
24c672c2b9 | ||
![]() |
c407e0e83e | ||
![]() |
b1346698d6 | ||
![]() |
5c01129567 | ||
![]() |
cd7ce53bd0 | ||
![]() |
4c95c20061 | ||
![]() |
5339db5058 | ||
![]() |
623e932f8c | ||
![]() |
43659de4f4 | ||
![]() |
2a661eda42 | ||
![]() |
c85a93a17b | ||
![]() |
8ab36cb3e1 | ||
![]() |
72820d0708 | ||
![]() |
95b551d4ba | ||
![]() |
68af9a0695 | ||
![]() |
6953c3989b | ||
![]() |
cd4cb385d5 | ||
![]() |
f4f6d595fc | ||
![]() |
d2356f00e9 | ||
![]() |
e408136196 | ||
![]() |
c355968add | ||
![]() |
783f878947 | ||
![]() |
4faf41e482 | ||
![]() |
d8964b6ed2 | ||
![]() |
b5b999941c | ||
![]() |
deeba8c4de | ||
![]() |
9e48729eb0 | ||
![]() |
936e374c05 | ||
![]() |
0f3524b114 | ||
![]() |
d62de3d72c | ||
![]() |
957a80da4b | ||
![]() |
1dccd70f7c | ||
![]() |
006a5d4e61 | ||
![]() |
ce7cdcf54e | ||
![]() |
c1ebb4a79b | ||
![]() |
41964ae1de | ||
![]() |
66cf34adf7 | ||
![]() |
9e9e0009cf | ||
![]() |
d5cd9660fc | ||
![]() |
12a7803653 | ||
![]() |
8f7bef6a20 | ||
![]() |
a0715b830c | ||
![]() |
f87ce10dc4 | ||
![]() |
ee4936b8c9 | ||
![]() |
3cb2592660 | ||
![]() |
574c901b40 | ||
![]() |
7590ba4ad5 | ||
![]() |
39ce18f8bb | ||
![]() |
777a4f9d3f | ||
![]() |
b91a938787 | ||
![]() |
c903abdb1b | ||
![]() |
3279bc0580 | ||
![]() |
bd32c9f49e | ||
![]() |
5507088e3d | ||
![]() |
37ad48ae4a | ||
![]() |
120c6e6d87 | ||
![]() |
866e907b7e | ||
![]() |
2bd8c2cb10 | ||
![]() |
c6c9919178 | ||
![]() |
575bf9d1e0 | ||
![]() |
82a56e0285 | ||
![]() |
25d5f7c132 | ||
![]() |
a3e9ecf30f | ||
![]() |
ec5ff0a07f | ||
![]() |
be836d30c5 | ||
![]() |
42b1529a5f | ||
![]() |
47708c4807 | ||
![]() |
d2a51e004c | ||
![]() |
ab14230101 | ||
![]() |
4bcf8c1f78 | ||
![]() |
44d00e9da3 | ||
![]() |
d7e6a4493c | ||
![]() |
53e89d8c54 | ||
![]() |
4497c13634 | ||
![]() |
4a35fade46 | ||
![]() |
6cba0601fd | ||
![]() |
ed4332ea78 | ||
![]() |
aba069cec5 | ||
![]() |
8a82ac0a11 | ||
![]() |
1cd1456d75 | ||
![]() |
b791a3eb10 | ||
![]() |
3b22a8b170 | ||
![]() |
419e8214ca | ||
![]() |
b9f8571f0f | ||
![]() |
c6d9a9d7f8 | ||
![]() |
310aba6ccb | ||
![]() |
9bd89ac4f6 | ||
![]() |
ea6a51dca9 | ||
![]() |
e701bcc50c | ||
![]() |
a1abf06e75 | ||
![]() |
76ace394b0 | ||
![]() |
4dac462f8f | ||
![]() |
039672b1e7 | ||
![]() |
1b26ecbbf5 | ||
![]() |
f4a7e96943 | ||
![]() |
a45bc2954f | ||
![]() |
62f32467b7 | ||
![]() |
600a1bf201 | ||
![]() |
7e196e7aa6 | ||
![]() |
9ad3507b66 | ||
![]() |
add1bdfcf6 | ||
![]() |
7ea8a7c079 | ||
![]() |
28e31f5165 | ||
![]() |
10a6975c5d | ||
![]() |
b34ea87660 | ||
![]() |
86ed69c50b | ||
![]() |
02e824154c | ||
![]() |
dc973c8491 | ||
![]() |
0a28e3a8d3 | ||
![]() |
7a48c260e1 | ||
![]() |
c55c49a3a2 | ||
![]() |
0fc9b06d12 | ||
![]() |
d71ad5a6bf | ||
![]() |
f0b3028306 | ||
![]() |
752992c527 | ||
![]() |
43c4476396 | ||
![]() |
f8172bed56 | ||
![]() |
c1f71b4cfc | ||
![]() |
4799da15e7 | ||
![]() |
4936e47c7a | ||
![]() |
cb965373aa | ||
![]() |
654a91184a | ||
![]() |
57997f7f4b | ||
![]() |
ca2f5be3d1 | ||
![]() |
1b091073f1 | ||
![]() |
85d2d3c442 | ||
![]() |
d77dfd63cf | ||
![]() |
db2bf52fca | ||
![]() |
2c62d97440 | ||
![]() |
53b2e64214 | ||
![]() |
ccf82a3ee5 | ||
![]() |
9cb6f35e60 | ||
![]() |
da2e33a040 | ||
![]() |
f2d260bfa4 | ||
![]() |
783c7244f9 | ||
![]() |
c9287e0e63 | ||
![]() |
69b84d115c | ||
![]() |
1745b898b1 | ||
![]() |
5ba4c85249 | ||
![]() |
03c87bb46d | ||
![]() |
dff5a76e9e | ||
![]() |
50386f4ca4 | ||
![]() |
de6ba2ec80 | ||
![]() |
ce126015d9 | ||
![]() |
f2337c3d43 | ||
![]() |
41b59d322a | ||
![]() |
dfea7c111e | ||
![]() |
3d5d672297 | ||
![]() |
e4dcc6f342 | ||
![]() |
9847249611 | ||
![]() |
19742a54ec | ||
![]() |
5af9ae7a80 | ||
![]() |
78962a4a75 | ||
![]() |
9a35d826aa | ||
![]() |
c9cdc89d35 | ||
![]() |
33b75703ba | ||
![]() |
ca55aa3a24 | ||
![]() |
95307c3902 | ||
![]() |
89c8eae7e2 | ||
![]() |
91614772dc | ||
![]() |
cd497ab4dc | ||
![]() |
f81895905e | ||
![]() |
d82fafaa7a | ||
![]() |
0ea01acc46 | ||
![]() |
df55792a68 | ||
![]() |
6a19c45269 | ||
![]() |
23ee345441 | ||
![]() |
0e8ff253f3 | ||
![]() |
89bddb0bc4 | ||
![]() |
77bbca9bb3 | ||
![]() |
1acd4d8d58 | ||
![]() |
4db72a712d | ||
![]() |
da2b7ba08e | ||
![]() |
f8b49411bf | ||
![]() |
a04b0d99b0 | ||
![]() |
9e9735f617 | ||
![]() |
f906b36f01 | ||
![]() |
a9d1f4f854 | ||
![]() |
d017ae905f | ||
![]() |
bede280507 | ||
![]() |
ea130047bc | ||
![]() |
d77d8de63e | ||
![]() |
f5413d9202 | ||
![]() |
559fc8f216 | ||
![]() |
34b2df911d | ||
![]() |
3d5a8a8cbd | ||
![]() |
2b07097e14 | ||
![]() |
372e943d8b | ||
![]() |
95afcedc4f | ||
![]() |
c1dc8f017c | ||
![]() |
dbeddca263 | ||
![]() |
e65d133dec | ||
![]() |
b5e1dea1c2 | ||
![]() |
3f19469939 | ||
![]() |
87874b037a | ||
![]() |
adda6841d1 | ||
![]() |
a8092b921b | ||
![]() |
930e4d69d1 | ||
![]() |
d9219df45b | ||
![]() |
a6d4ec28db | ||
![]() |
b29e13f777 | ||
![]() |
9363b78ff6 | ||
![]() |
eba411fec7 | ||
![]() |
9afe99e134 | ||
![]() |
6678856178 | ||
![]() |
a1fea38c2c | ||
![]() |
2d3265e66d | ||
![]() |
f6d4400db9 | ||
![]() |
6d892a9266 | ||
![]() |
356fa08da5 | ||
![]() |
2225f8c890 | ||
![]() |
d1a89739f9 | ||
![]() |
6ec6896763 | ||
![]() |
9fb718d610 | ||
![]() |
c913b89a47 | ||
![]() |
58b45693b7 | ||
![]() |
29d3ece9b1 | ||
![]() |
7e5db75230 | ||
![]() |
283c0b9845 | ||
![]() |
071a0f1651 | ||
![]() |
1a116557a4 | ||
![]() |
1468297626 | ||
![]() |
87e94fdf52 | ||
![]() |
64e15c33c8 | ||
![]() |
7170f435d1 | ||
![]() |
9942be0493 | ||
![]() |
eaad36277f | ||
![]() |
37cc498568 | ||
![]() |
8a3191340a | ||
![]() |
0f4e998f0a | ||
![]() |
0c93b649ba | ||
![]() |
947d269877 | ||
![]() |
b4b9453948 | ||
![]() |
b99a4cd095 | ||
![]() |
a363d5aa46 | ||
![]() |
ae442dabb4 | ||
![]() |
1477c88397 | ||
![]() |
4172462938 | ||
![]() |
27341ba4f8 | ||
![]() |
7443076094 | ||
![]() |
a764bb4b1d | ||
![]() |
57130e1af7 | ||
![]() |
3f8a354c99 | ||
![]() |
0b10d92929 | ||
![]() |
1a1c55e661 | ||
![]() |
87768f9e8b | ||
![]() |
d079f50364 | ||
![]() |
72a89835c5 | ||
![]() |
39d686810b | ||
![]() |
d936626001 | ||
![]() |
cdce1c5ea6 | ||
![]() |
d59530a54f | ||
![]() |
fe480811fb | ||
![]() |
2e3e0d34c3 | ||
![]() |
1e2984d0d9 | ||
![]() |
3e9fe693c7 | ||
![]() |
63161838d8 | ||
![]() |
7c92951ae9 | ||
![]() |
59a25854ef | ||
![]() |
3ca5768974 | ||
![]() |
9a2dce43dd | ||
![]() |
b7fce4317b | ||
![]() |
97d9514b00 | ||
![]() |
58f88708fa | ||
![]() |
d79c874aa5 | ||
![]() |
58917c1ff8 | ||
![]() |
13b171a62d | ||
![]() |
f0a601922a | ||
![]() |
d90090b35e | ||
![]() |
094d1142e7 | ||
![]() |
eb09d1c925 | ||
![]() |
bd5d75361e | ||
![]() |
5d7c0c635b | ||
![]() |
606f538bf3 | ||
![]() |
574c0eea27 | ||
![]() |
4730cbc543 | ||
![]() |
5c63359550 | ||
![]() |
ec3607f779 | ||
![]() |
7efd0f8098 | ||
![]() |
2a7c30a21a | ||
![]() |
2639c3ee3f | ||
![]() |
547e0153cb | ||
![]() |
423664fcfa | ||
![]() |
c986c230ef | ||
![]() |
7c6001f76e | ||
![]() |
d3620946ac | ||
![]() |
479643221c | ||
![]() |
c9ef8bcf6a | ||
![]() |
d655a7c2f6 | ||
![]() |
306861d3b4 | ||
![]() |
7abab41eed | ||
![]() |
acc2691e33 | ||
![]() |
21a65956b0 | ||
![]() |
9738275ad1 | ||
![]() |
7265034703 | ||
![]() |
9bcc45591d | ||
![]() |
38d657ba0e | ||
![]() |
6a0d16c5bb | ||
![]() |
490d4abb56 | ||
![]() |
a7d0f7fc99 | ||
![]() |
0d2d3ff528 | ||
![]() |
526169f0aa | ||
![]() |
42940ff0e3 | ||
![]() |
e9b943363d | ||
![]() |
01e98ff10c | ||
![]() |
d38981a17d | ||
![]() |
7612e91691 | ||
![]() |
76b0f20033 | ||
![]() |
b78c0f8a29 | ||
![]() |
ea93c7c8fc | ||
![]() |
8ac1952974 | ||
![]() |
b4514a5bbf | ||
![]() |
568053b06d | ||
![]() |
bb180bfc39 | ||
![]() |
5ee635caed | ||
![]() |
5dfd7c8597 | ||
![]() |
fe61b75d7e | ||
![]() |
e7bf565418 | ||
![]() |
12071f6251 | ||
![]() |
72ed2e3ed0 | ||
![]() |
d7c1f134fe | ||
![]() |
5072d9f7ad | ||
![]() |
5d42a1247a | ||
![]() |
ce64be22bd | ||
![]() |
36f9386e8d | ||
![]() |
e9dc963805 | ||
![]() |
8854322997 | ||
![]() |
6018f1e8ca | ||
![]() |
68f8ebb543 | ||
![]() |
301f0218fd | ||
![]() |
a9c4a56893 | ||
![]() |
3ea3d72f11 | ||
![]() |
33da5bf4a7 | ||
![]() |
e3de01948a | ||
![]() |
3cd92aaf54 | ||
![]() |
ab4e1996dd | ||
![]() |
b9ef082abf | ||
![]() |
dac7186da3 | ||
![]() |
1fd6cc2b5e | ||
![]() |
0b7da9790a | ||
![]() |
a9e0e0ead6 | ||
![]() |
079754f1a9 | ||
![]() |
c45b5b1e86 | ||
![]() |
2115cc685c | ||
![]() |
b99e56fc19 | ||
![]() |
74c057eb84 | ||
![]() |
e8ececc0dc | ||
![]() |
ad120b7736 | ||
![]() |
61c0711e79 | ||
![]() |
81c3f6fce0 | ||
![]() |
0a4416e633 | ||
![]() |
6bb712854d | ||
![]() |
46959e2407 | ||
![]() |
debbb049b0 | ||
![]() |
375377fef9 | ||
![]() |
d5758dd6a3 | ||
![]() |
d5deffea58 | ||
![]() |
fadb43d9a1 | ||
![]() |
044b641df0 | ||
![]() |
fbbacdb2ff | ||
![]() |
4bfd7acd96 | ||
![]() |
ff03225cf4 | ||
![]() |
8e820c0e47 | ||
![]() |
d718314324 | ||
![]() |
1c653ec1b1 | ||
![]() |
fe16ddadce | ||
![]() |
7a978054cc | ||
![]() |
8ed3b5a747 | ||
![]() |
6885150800 | ||
![]() |
35d33a1c7d | ||
![]() |
93a16bbd3c | ||
![]() |
d3cf6a4985 | ||
![]() |
8ef7200c32 | ||
![]() |
e43da5ba86 | ||
![]() |
10428b4340 | ||
![]() |
43b7c05cd7 | ||
![]() |
057f64b04c | ||
![]() |
0971d783f3 | ||
![]() |
54aabad3e8 | ||
![]() |
606fbb5fec | ||
![]() |
5093c27ba5 | ||
![]() |
1d3661c946 | ||
![]() |
304f7a068d | ||
![]() |
7ea91be3fc | ||
![]() |
d15464b1ae | ||
![]() |
150435f24e | ||
![]() |
e49507cd14 | ||
![]() |
ad3cc3ebb6 | ||
![]() |
ecaf53836d | ||
![]() |
8fc36e7b24 | ||
![]() |
1dbbac2aa3 | ||
![]() |
4e5775fde4 | ||
![]() |
9d81c7c366 | ||
![]() |
2df0441f0f | ||
![]() |
4216002ce5 | ||
![]() |
1af6f4e151 | ||
![]() |
05f284bc11 | ||
![]() |
40c19b3ad4 | ||
![]() |
d1d972cca0 | ||
![]() |
2a969921d6 | ||
![]() |
4b3e1f5187 | ||
![]() |
561963aa26 | ||
![]() |
6c2c192836 | ||
![]() |
f0730f2295 | ||
![]() |
9df91d2b63 | ||
![]() |
09da1941fd | ||
![]() |
613c8e4c28 | ||
![]() |
7b407fd34d | ||
![]() |
fb7ff7a803 | ||
![]() |
0c1f0e0522 | ||
![]() |
b5d771e9aa | ||
![]() |
2f64255895 | ||
![]() |
5b629a5c40 | ||
![]() |
b749cf52c3 | ||
![]() |
b9a36a9223 | ||
![]() |
32debf6e6b | ||
![]() |
06f6ae01c9 | ||
![]() |
db4d8ad802 | ||
![]() |
9c82de9c9e | ||
![]() |
8329835528 | ||
![]() |
8e624aa31b | ||
![]() |
a2e8741517 | ||
![]() |
3b7c107e8f | ||
![]() |
558bc3f971 | ||
![]() |
90a326f380 | ||
![]() |
867dc1ae35 | ||
![]() |
3f555464f7 | ||
![]() |
c0c0782258 | ||
![]() |
377f57bcb6 | ||
![]() |
a51253f1e5 | ||
![]() |
e674e94da6 | ||
![]() |
93a415f6d3 | ||
![]() |
9364b97692 | ||
![]() |
030915c9ea | ||
![]() |
10882c309a | ||
![]() |
8232fde160 | ||
![]() |
45c3474d4d | ||
![]() |
c5a9e85343 | ||
![]() |
8c7ef59583 | ||
![]() |
36404b5c92 | ||
![]() |
9949a117be | ||
![]() |
a3896db4f5 | ||
![]() |
f668062cab | ||
![]() |
bac0721078 | ||
![]() |
e29d7244d8 | ||
![]() |
5a34b91a7a | ||
![]() |
eaac8b1428 | ||
![]() |
6c6275dc88 | ||
![]() |
bd350ae679 | ||
![]() |
cadee28c68 | ||
![]() |
3534828a99 | ||
![]() |
e1c5777e25 | ||
![]() |
63553d4dd3 | ||
![]() |
6033d779fc | ||
![]() |
97db27e61f | ||
![]() |
8ed861c05f | ||
![]() |
4d416657bf | ||
![]() |
ede0399275 | ||
![]() |
1a28ada04c | ||
![]() |
8ac771cde4 | ||
![]() |
c6afbbfc73 | ||
![]() |
5ba71e8109 | ||
![]() |
a0d2922aca | ||
![]() |
446610b9df | ||
![]() |
4905eea503 | ||
![]() |
519fc128f6 | ||
![]() |
cc10955483 | ||
![]() |
e0bd47bb87 | ||
![]() |
fb0c3c4a06 | ||
![]() |
ceef1fdaf2 | ||
![]() |
e1ac287ed1 | ||
![]() |
29cd3a5945 | ||
![]() |
cab082166b | ||
![]() |
711dfd4da9 | ||
![]() |
643948331d | ||
![]() |
119030f1a5 | ||
![]() |
3efee3dc52 | ||
![]() |
70716d5121 | ||
![]() |
a7d11ead62 | ||
![]() |
017830e433 | ||
![]() |
bceb175c75 | ||
![]() |
98277c6b71 | ||
![]() |
b227fbe523 | ||
![]() |
ac6659a293 | ||
![]() |
30a24ced1d | ||
![]() |
3d1f4ae2ed | ||
![]() |
e86aff049c | ||
![]() |
8ec0ba7c9e | ||
![]() |
c2898f0b2e |
11
.gitignore
vendored
11
.gitignore
vendored
@@ -364,12 +364,5 @@ FodyWeavers.xsd
|
||||
|
||||
/src/*Pro*/
|
||||
/src/*Pro*
|
||||
/src/*pro*
|
||||
/src/*pro*/
|
||||
/doc/.*
|
||||
/doc/build/
|
||||
/src/ThingsGateway.Server/.config/
|
||||
/src/nuget.exe
|
||||
/src/nupkgs/
|
||||
/src/nupkgs
|
||||
|
||||
/src/ThingsGateway.Server/Configuration/GiteeOAuthSettings.json
|
||||
/src/.idea/
|
||||
|
2
LICENSE
2
LICENSE
@@ -85,7 +85,7 @@
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
as of the date such litigation is field.
|
||||
|
||||
4. Cachetribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
|
101
README.md
101
README.md
@@ -1,72 +1,101 @@
|
||||
# ThingsGateway
|
||||
|
||||
|
||||
|
||||
## Introduction
|
||||
|
||||
|
||||
A cross-platform, high-performance edge data collection gateway based on net8, capable of handling millions of data points per.
|
||||
A cross-platform, high-performance edge data collection gateway based on net9.
|
||||
|
||||
|
||||
## Documentation
|
||||
|
||||
|
||||
[Documentation](https://kimdiego2098.github.io/).
|
||||
[Documentation](https://thingsgateway.cn/).
|
||||
|
||||
[NuGet](https://www.nuget.org/packages?q=Tags%3A%22ThingsGateway%22)
|
||||
|
||||
### Plugin List
|
||||
|
||||
#### Data Collection Plugins
|
||||
|
||||
| Plugin Name | Remarks |
|
||||
|-------|-------|
|
||||
| Modbus | Supports Rtu/Tcp message formats, with Serial/Tcp/Udp links |
|
||||
| SiemensS7 | Siemens PLC S7 series |
|
||||
| Dlt6452007 | Supports Serial/Tcp/Udp links |
|
||||
| OpcDaMaster | Compiled for 64-bit |
|
||||
| OpcUaMaster | Supports certificate login, object extension, Json read/write |
|
||||
|
||||
#### Business Plugins
|
||||
|
||||
| Plugin Name | Remarks |
|
||||
|-------|-------|
|
||||
| ModbusSlave | Supports Rtu/Tcp message formats, with Serial/Tcp/Udp links, supports Rpc reverse writing |
|
||||
| OpcUaServer | OpcUa server, supports Rpc reverse writing |
|
||||
| MqttClient | Mqtt client, supports Rpc reverse writing, script-customizable upload content |
|
||||
| MqttServer | Mqtt server, supports WebSocket, supports Rpc reverse writing, script-customizable upload content |
|
||||
| KafkaProducer | Script-customizable upload content |
|
||||
| RabbitMQProducer | Script-customizable upload content |
|
||||
| SqlDB | Relational database storage, supports historical storage and real-time data updates |
|
||||
| SqlHisAlarm | Alarm historical data relational database storage |
|
||||
| TDengineDB | Time-series database storage |
|
||||
| QuestDB | Time-series database storage |
|
||||
|
||||
|
||||
## License
|
||||
|
||||
[Apache-2.0](https://gitee.com/diego2098/ThingsGateway/blob/master/LICENSE)
|
||||
|
||||
## Demo
|
||||
|
||||
|
||||
[ThingsGateway Demo Address](http://47.119.161.158:5000/)
|
||||
[Demo](https://demo.thingsgateway.cn/)
|
||||
|
||||
|
||||
Account: **SuperAdmin**
|
||||
|
||||
|
||||
Password: **111111**
|
||||
|
||||
|
||||
**In the upper-right corner, switch to the IoT Gateway module in the personal popup box**
|
||||
|
||||
## Docker
|
||||
## Docker
|
||||
|
||||
```shell
|
||||
|
||||
docker pull registry.cn-shenzhen.aliyuncs.com/thingsgateway/thingsgateway
|
||||
|
||||
docker pull registry.cn-shenzhen.aliyuncs.com/thingsgateway/thingsgateway_arm64
|
||||
```
|
||||
|
||||
|
||||
|
||||
### Plugin List
|
||||
|
||||
|
||||
|
||||
#### Data Collection Plugins
|
||||
|
||||
|
||||
| Plugin Name | Remarks |
|
||||
| ----------- | ------------------------------------------------------------- |
|
||||
| Modbus | Supports Rtu/Tcp message formats, with Serial/Tcp/Udp links |
|
||||
| SiemensS7 | Siemens PLC S7 series |
|
||||
| Dlt6452007 | Supports Serial/Tcp/Udp links |
|
||||
| OpcDaMaster | Compiled for 64-bit |
|
||||
| OpcUaMaster | Supports certificate login, object extension, Json read/write |
|
||||
| Webhook | Webhook |
|
||||
|
||||
#### Business Plugins
|
||||
|
||||
|
||||
| Plugin Name | Remarks |
|
||||
| ---------------- | ------------------------------------------------------------------------------------------------- |
|
||||
| ModbusSlave | Supports Rtu/Tcp message formats, with Serial/Tcp/Udp links, supports Rpc reverse writing |
|
||||
| OpcUaServer | OpcUa server, supports Rpc reverse writing |
|
||||
| MqttClient | Mqtt client, supports Rpc reverse writing, script-customizable upload content |
|
||||
| MqttServer | Mqtt server, supports WebSocket, supports Rpc reverse writing, script-customizable upload content |
|
||||
| KafkaProducer | Script-customizable upload content |
|
||||
| RabbitMQProducer | Script-customizable upload content |
|
||||
| SqlDB | Relational database storage, supports historical storage and real-time data updates |
|
||||
| SqlHistoryAlarm | Alarm historical data relational database storage |
|
||||
| TDengineDB | Time-series database storage |
|
||||
| QuestDB | Time-series database storage |
|
||||
|
||||
|
||||
|
||||
## License
|
||||
|
||||
|
||||
[License](https://thingsgateway.cn/docs/1)
|
||||
|
||||
|
||||
|
||||
## Sponsorship
|
||||
|
||||
|
||||
[Sponsorship Approach](https://kimdiego2098.github.io/docs/1000)
|
||||
[Sponsorship Approach](https://thingsgateway.cn/docs/1000)
|
||||
|
||||
|
||||
## Community
|
||||
|
||||
|
||||
QQ Group: 605534569 [Jump](http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=NnBjPO-8kcNFzo_RzSbdICflb97u2O1i&authKey=V1MI3iJtpDMHc08myszP262kDykbx2Yev6ebE4Me0elTe0P0IFAmtU5l7Sy5w0jx&noverify=0&group_code=605534569)
|
||||
|
||||
|
||||
## Pro Plugins
|
||||
|
||||
|
||||
[Plugin List](https://kimdiego2098.github.io/docs/1001)
|
||||
[Plugin List](https://thingsgateway.cn/docs/1001)
|
||||
|
@@ -1,65 +1,74 @@
|
||||
|
||||
# ThingsGateway
|
||||
|
||||
## 介绍
|
||||
|
||||
基于net8的跨平台高性能边缘采集网关,单机采集数据点位可达百万
|
||||
基于net9的跨平台高性能边缘采集网关
|
||||
|
||||
## 文档
|
||||
|
||||
[文档](https://kimdiego2098.github.io/)
|
||||
[文档](https://thingsgateway.cn/)
|
||||
|
||||
[NuGet](https://www.nuget.org/packages?q=Tags%3A%22ThingsGateway%22)
|
||||
|
||||
### 插件列表
|
||||
|
||||
#### 采集插件
|
||||
| 插件名称 | 备注 |
|
||||
|-------|-------|
|
||||
| Modbus | Rtu/Tcp报文格式,支持串口/Tcp/Udp链路 |
|
||||
| SiemensS7 | 西门子PLC S7系列 |
|
||||
| Dlt6452007 | 支持串口/Tcp/Udp链路 |
|
||||
| OpcDaMaster | 64位编译 |
|
||||
| OpcUaMaster | 支持证书登录,扩展对象,Json读写 |
|
||||
|
||||
#### 业务插件
|
||||
| 插件名称 | 备注 |
|
||||
|-------|-------|
|
||||
| ModbusSlave | Rtu/Tcp报文格式,支持串口/Tcp/Udp链路,支持Rpc反写 |
|
||||
| OpcUaServer | OpcUa服务端,支持Rpc反写 |
|
||||
| MqttClient | Mqtt客户端,支持Rpc反写,脚本自定义上传内容 |
|
||||
| MqttServer | Mqtt服务端,支持WebSocket,支持Rpc反写,脚本自定义上传内容 |
|
||||
| KafkaProducer | 脚本自定义上传内容 |
|
||||
| RabbitMQProducer | 脚本自定义上传内容 |
|
||||
| SqlDB | 关系数据库存储,支持历史存储和实时数据更新 |
|
||||
| SqlHisAlarm | 报警历史数据关系数据库存储 |
|
||||
| TDengineDB | 时序数据库存储 |
|
||||
| QuestDB | 时序数据库存储 |
|
||||
|
||||
## 协议
|
||||
|
||||
[Apache-2.0](https://gitee.com/diego2098/ThingsGateway/blob/master/LICENSE)
|
||||
|
||||
## 演示
|
||||
|
||||
[ThingsGateway演示地址](http://47.119.161.158:5000/)
|
||||
[ThingsGateway演示地址](https://demo.thingsgateway.cn/)
|
||||
|
||||
账户 : **SuperAdmin**
|
||||
账户 : **SuperAdmin**
|
||||
|
||||
密码 : **111111**
|
||||
|
||||
**右上角个人弹出框中,切换到物联网关模块**
|
||||
|
||||
## Docker
|
||||
## Docker
|
||||
|
||||
```shell
|
||||
|
||||
docker pull registry.cn-shenzhen.aliyuncs.com/thingsgateway/thingsgateway
|
||||
|
||||
docker pull registry.cn-shenzhen.aliyuncs.com/thingsgateway/thingsgateway_arm64
|
||||
```
|
||||
|
||||
|
||||
### 插件列表
|
||||
|
||||
#### 采集插件
|
||||
|
||||
|
||||
| 插件名称 | 备注 |
|
||||
| ----------- | ------------------------------------- |
|
||||
| Modbus | Rtu/Tcp报文格式,支持串口/Tcp/Udp链路 |
|
||||
| SiemensS7 | 西门子PLC S7系列 |
|
||||
| Dlt6452007 | 支持串口/Tcp/Udp链路 |
|
||||
| OpcDaMaster | 64位编译 |
|
||||
| OpcUaMaster | 支持证书登录,扩展对象,Json读写 |
|
||||
|
||||
#### 业务插件
|
||||
|
||||
|
||||
| 插件名称 | 备注 |
|
||||
| ---------------- | ---------------------------------------------------------- |
|
||||
| ModbusSlave | Rtu/Tcp报文格式,支持串口/Tcp/Udp链路,支持Rpc反写 |
|
||||
| OpcUaServer | OpcUa服务端,支持Rpc反写 |
|
||||
| MqttClient | Mqtt客户端,支持Rpc反写,脚本自定义上传内容 |
|
||||
| MqttServer | Mqtt服务端,支持WebSocket,支持Rpc反写,脚本自定义上传内容 |
|
||||
| KafkaProducer | 脚本自定义上传内容 |
|
||||
| RabbitMQProducer | 脚本自定义上传内容 |
|
||||
| SqlDB | 关系数据库存储,支持历史存储和实时数据更新 |
|
||||
| SqlHistoryAlarm | 报警历史数据关系数据库存储 |
|
||||
| TDengineDB | 时序数据库存储 |
|
||||
| QuestDB | 时序数据库存储 |
|
||||
| Webhook | Webhook |
|
||||
|
||||
## 协议
|
||||
|
||||
[版权声明](https://thingsgateway.cn/docs/1)
|
||||
|
||||
|
||||
## 赞助
|
||||
|
||||
[赞助途径](https://kimdiego2098.github.io/docs/1000)
|
||||
[赞助途径](https://thingsgateway.cn/docs/1000)
|
||||
|
||||
## 社区
|
||||
|
||||
@@ -67,7 +76,11 @@ QQ群:605534569 [跳转](http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=NnBjPO-8kcN
|
||||
|
||||
## Pro插件
|
||||
|
||||
[插件列表](https://kimdiego2098.github.io/docs/1001)
|
||||
[插件列表](https://thingsgateway.cn/docs/1001)
|
||||
|
||||
|
||||
## 特别声明
|
||||
|
||||
ThingsGateway 项目已加入 [dotNET China](https://gitee.com/dotnetchina) 组织。<br/>
|
||||
|
||||

|
201
doc/LICENSE.txt
201
doc/LICENSE.txt
@@ -1,201 +0,0 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
@@ -1,15 +0,0 @@
|
||||
文档基于 [https://www.docusaurus.io/](https://www.docusaurus.io/) 构建。
|
||||
|
||||
### 本地运行
|
||||
|
||||
```bash
|
||||
npm install
|
||||
|
||||
npm run start
|
||||
```
|
||||
|
||||
### 发布部署
|
||||
|
||||
```bash
|
||||
npm run build
|
||||
```
|
@@ -1,3 +0,0 @@
|
||||
module.exports = {
|
||||
presets: [require.resolve('@docusaurus/core/lib/babel/preset')],
|
||||
};
|
@@ -1,57 +0,0 @@
|
||||
---
|
||||
id: 1
|
||||
title: 版权说明
|
||||
---
|
||||
|
||||
:::tip 公告
|
||||
|
||||
注意以下常见版权问题:
|
||||
|
||||
- 社区版本不得去除可视页面的ThingsGateway Logo
|
||||
- 不得将程序集单独包装售卖,申请专利,开发竞品
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 使用前必要阅读
|
||||
|
||||
ThingsGateway 由作者Diego及其他贡献者开发,所有版权归作者Diego所有,程序集源代码在遵循 Apache License 2.0 的开源协议以及**附加协议**下,可**免费**供其他开发者二次开发或(商业)使用。
|
||||
|
||||
|
||||
### 个人使用须知:
|
||||
|
||||
- 不得将程序集用作违法犯罪活动。
|
||||
- 不得将程序集单独包装售卖,申请专利等。
|
||||
- 不得擦除程序集所有有关作者的信息。
|
||||
|
||||
**以上内容必须全部符合,个人使用授权才成立。**
|
||||
|
||||
### 二次开发须知:
|
||||
|
||||
- 不得将程序集用作违法犯罪活动。
|
||||
- 不得将程序集单独包装售卖,申请专利等。
|
||||
- 不得擦除程序集所有有关作者的信息。
|
||||
- 二次开发完成后的作品必须附带源作品所有作者信息,包括但不限于作者名、Gitee、Github 地址等。
|
||||
|
||||
**以上内容必须全部符合,二次开发授权才成立。**
|
||||
|
||||
### 盈利性(商业)用途使用须知:
|
||||
|
||||
- 不得将程序集用作违法犯罪活动。
|
||||
- 不得将程序集单独包装售卖,申请专利等。
|
||||
- **不得擦除程序集所有有关作者的信息,并必须于用户可见界面(如关于)中提名。**
|
||||
|
||||
**以上内容必须全部符合,商业使用授权才成立。**
|
||||
|
||||
|
||||
## ThingsGatewayPro 商用许可
|
||||
|
||||
ThingsGatewayPro 软件框架与 ThingsGateway 一致,另包含其他定制插件。所有版权归作者Diego所有。
|
||||
|
||||
ThingsGatewayPro 不公开开源。
|
||||
|
||||
|
||||
|
||||
# 免责申明
|
||||
|
||||
**在使用 ThingsGateway 之前请进行缜密的测试。在使用期间,由本程序集造成或间接造成的所有损失,均自己承担,与本程序集无关。**
|
@@ -1,45 +0,0 @@
|
||||
---
|
||||
id: 100
|
||||
title: 驱动调试
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `配置须知`
|
||||
|
||||
变量地址的格式可从浮动提示中查看,如需要详细说明,可查看对应的插件章节
|
||||
|
||||
:::
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 网关程序中包含了调试页面,也单独提供跨平台的桌面端调试软件
|
||||
|
||||
<img src={require("@site/static/img/docs/驱动调试.png").default} />
|
||||
|
||||
下面举例说明Modbus驱动的调试流程
|
||||
|
||||
## 二、Modbus调试流程
|
||||
|
||||
选择需要的驱动,进入页面后,新建通道
|
||||
<img src={require("@site/static/img/docs/驱动调试1.png").default} />
|
||||
|
||||
<img src={require("@site/static/img/docs/驱动调试2.png").default} />
|
||||
|
||||
2、 查看变量寄存器地址的填写格式
|
||||
<img src={require("@site/static/img/docs/驱动调试3.png").default} />
|
||||
|
||||
3、 打开模拟软件,点击读取
|
||||
|
||||
<img src={require("@site/static/img/docs/驱动调试4.png").default} />
|
||||
|
||||
可以看到交互的报文以及读取结果
|
||||
|
||||
|
||||
## 三、网关中的调试页面
|
||||
|
||||
<img src={require("@site/static/img/docs/驱动调试5.png").default} />
|
||||
|
||||
操作与桌面软件一样
|
@@ -1,28 +0,0 @@
|
||||
---
|
||||
id: 1000
|
||||
title: 赞助项目
|
||||
---
|
||||
|
||||
## 赞助ThingsGateway项目
|
||||
> 您的支持就是我不懈努力的动力。<br></br>如果对您有帮助,请⭐Star关注或扫码捐赠,感谢支持开源!
|
||||
|
||||
### 赞助途径
|
||||

|
||||
|
||||
|
||||
### 赞助名单(以下排名只按照赞助时间顺序)
|
||||
|
||||
|序号|名称|金额|
|
||||
|-----------|--------------|-----------------|
|
||||
|1| 绢| 10¥|
|
||||
|2| 小蚂蚁 |500+¥|
|
||||
|3| *伟 |18.8¥|
|
||||
|4| *碟 |20¥|
|
||||
|5| *长 |6.66¥|
|
||||
|6| 小黄鸭 |38.8¥|
|
||||
|7| *交 |50¥|
|
||||
|8| *洋 |200¥+50¥|
|
||||
|9| *元 |20¥|
|
||||
|10| 冬日暖阳 |66.66¥|
|
||||
|
||||
|
@@ -1,9 +0,0 @@
|
||||
---
|
||||
id: 10001
|
||||
title: ABCipMatser
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
@@ -1,96 +0,0 @@
|
||||
---
|
||||
id: 1001
|
||||
title: Pro版
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
:::tip 公告
|
||||
|
||||
注意以下常见版权问题:
|
||||
|
||||
- 社区版本不得去除可视页面的ThingsGateway Logo
|
||||
- ThingsGatewayPro授权后可去除Logo,但Pro插件不开放源代码
|
||||
- 任何版本不得将程序集单独包装售卖,申请专利,开发竞品
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
ThingsGatewayPro是ThingsGateway的加强版本,**基础功能与ThingsGateway一致,并添加一些额外功能插件**
|
||||
|
||||
同时ThingsGatewayPro提供企业定制服务及必要的远程协助,具体收费可以咨询**作者Diego,联系方式:QQ:2248356998**
|
||||
|
||||
## 二、授权
|
||||
|
||||
** ThingsGatewayPro分为个人授权与企业授权,区别在于授权归属**
|
||||
|
||||
ThingsGatewayPro授权不开放源代码,**Pro版本基础代码和开源版本相同**
|
||||
|
||||
授权后获得证书凭据(图片形式)
|
||||
|
||||
### 2.1 个人授权
|
||||
|
||||
- **授权归属于购买者个人所有**
|
||||
- 价格 998¥
|
||||
|
||||
### 2.2 企业授权
|
||||
|
||||
- **授权归属于企业所有,仅企业主体享有授权**
|
||||
- 价格 1998¥
|
||||
|
||||
|
||||
## 三、插件差异
|
||||
|
||||
|序号| 插件名称 | 说明 |
|
||||
|----| ---------------| --------------------------|
|
||||
|1| Vigor | 丰炜串口/TCP通信插件,支持VS系列|
|
||||
|2| Fins Tcp/Udp | 欧姆龙Fins通信插件,支持CJ系列、CV系列、CS系列、NX系列等,一般欧姆龙带网口的都支持FINS|
|
||||
|3| ABCIP Tcp | 罗克韦尔CIP通信插件,支持1756,1769系列等|
|
||||
|4| SECS | SECS半导体协议|
|
||||
|5| 三菱MC QnA3E_Binary | MC 3E帧 二进制 |
|
||||
|6| USB扫码枪 | USB扫码枪(键盘输入式),键盘钩子获取的方式,目前只有windows版本|
|
||||
|7| URF_R330 读卡器 | dll,目前只有windows版本|
|
||||
|8| 精伦idr 210 读卡器 | dll,目前只有windows版本|
|
||||
|9| 明泰URF_R330 读卡器 | dll,目前只有windows版本|
|
||||
|10| 新中新DKQ-A16D 读卡器 | dll,目前只有windows版本|
|
||||
|
||||
## 四、插件开发计划
|
||||
|
||||
|序号| 插件名称 | 说明 |
|
||||
|----| ---------------| --------------------------|
|
||||
|1| 双机热备 | 网关双机冗余|
|
||||
|2| 远程更新 | 远程更新软件|
|
||||
|
||||
|
||||
## 五、授权名单(部分企业用户不公示)
|
||||
|
||||
|序号| 被授权主体 | 说明 | 时间 |
|
||||
|----| ---------------| --------------------------|-------------------|
|
||||
|1| 成都**创新科技有限公司 | | 2023-4-21|
|
||||
|2| 超级士兵 | | 2023-5-18|
|
||||
|3| SunnyUI | | 2023-7-13|
|
||||
|4| 俞智峰 | | 2023-7-13|
|
||||
|5| 西安***物联网科技有限公司 | | 2023-7-15|
|
||||
|6| 深圳市***自动化技术有限公司 | | 2023-7-16|
|
||||
|7| 西安***信息技术有限责任公司 | | 2023-9-4|
|
||||
|8| 北京****网络科技发展有限公司 | | 2023-9-26|
|
||||
|9| 长沙**软件科技有限公司 | | 2023-10-16|
|
||||
|10| 航科**科技有限公司 | | 2023-10-30|
|
||||
|11| 福建**包装有限公司 | | 2023-11-17|
|
||||
|12| 内蒙古**科技有限公司 | | 2023-11-26|
|
||||
|13| 佛山**自动化科技有限公司 | | 2023-11-27|
|
||||
|14| Z | | 2023-12-03|
|
||||
|15| 狼有一心 | | 2023-05-29|
|
||||
|
||||
## 六、购买途径
|
||||
|
||||
**购买前请先联系作者Diego**。联系QQ:2248356998。
|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
|
@@ -1,24 +0,0 @@
|
||||
---
|
||||
id: 1002
|
||||
title: 联系我们
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
**ThingsGateway团队**成立1年来一直致力于工业物联网关解决方案。我们的初衷是使设备接入更简单,为用户打造提高效率的产品。
|
||||
|
||||
可以通过以下方式找到我们:
|
||||
|
||||
### 技术支持
|
||||
|
||||
QQ群:605534569
|
||||
|
||||
QQ:2248356998
|
||||
|
||||
### 咨询、合作
|
||||
|
||||
手机:15622119120 林工
|
||||
|
||||
微信:15622119120
|
@@ -1,37 +0,0 @@
|
||||
---
|
||||
id: 101
|
||||
title: 插件管理
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `配置须知`
|
||||
|
||||
更改设备/变量/插件等,需要重启后台(右上角重启后台按钮)
|
||||
|
||||
:::
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 网关核心代码都由插件完成,主程序只负责调度执行
|
||||
|
||||
插件支持热重载,可由外部上传到网关中
|
||||
|
||||
## 二、上传插件
|
||||
|
||||
|
||||
<img src={require("@site/static/img/docs/上传插件.png").default} />
|
||||
|
||||
## 二、手动重载插件
|
||||
|
||||
<img src={require("@site/static/img/docs/重载插件.png").default} />
|
||||
|
||||
可由顶部按钮或者插件管理页面按钮执行手动重载
|
||||
|
||||
:::tip 提示
|
||||
|
||||
插件重新检测文件后,运行态的插件不会发送任何改变,如果立即生效,请按右上角的重启后台按钮
|
||||
|
||||
:::
|
@@ -1,39 +0,0 @@
|
||||
---
|
||||
id: 102
|
||||
title: 通道
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `配置须知`
|
||||
|
||||
更改设备/变量/插件等,需要重启后台(右上角重启后台按钮)
|
||||
|
||||
:::
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 网关通道其实是一个实际的串口/TCP/UDP链路,或者是线程池中的一个任务
|
||||
|
||||
## 二、添加通道/修改通道
|
||||
|
||||
<img src={require("@site/static/img/docs/添加通道.png").default} />
|
||||
|
||||
## 三、通道配置项
|
||||
| 属性| 说明 |
|
||||
| --- | --- |
|
||||
| 名称 | 通道名称|
|
||||
| 通道类型 | 选择 TcpClient/TcpService/SerialPortClient/UdpSession/Other |
|
||||
| 使能 | 是否启用此通道 |
|
||||
| 调试日志 | 初始运行时,是否启用调试日志,可在运行状态界面中再次启用/停用 |
|
||||
| 远程地址 | 对于TcpClient/UdpSession 作为客户端有效, 填入服务端的Url信息,比如192.168.0.1:502 |
|
||||
| 本地地址 | 对于TcpClient/TcpService/UdpSession 有效,作为本机的绑定地址,可选择填入,为空时是随机绑定端口 |
|
||||
| COM口 | 对于SerialPortClient有效,串口名称 |
|
||||
| 波特率 | 对于SerialPortClient有效,串口波特率 |
|
||||
| 数据位 | 对于SerialPortClient有效,串口数据位 |
|
||||
| 校验位 | 对于SerialPortClient有效,串口校验位 |
|
||||
| 停止位 | 对于SerialPortClient有效,串口停止位 |
|
||||
| 启用Dtr | 对于SerialPortClient有效,串口DtrEnable |
|
||||
| 启用Rts | 对于SerialPortClient有效,串口RtsEnable |
|
@@ -1,46 +0,0 @@
|
||||
---
|
||||
id: 103
|
||||
title: 设备
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `配置须知`
|
||||
|
||||
更改设备/变量/插件等,需要重启后台(右上角重启后台按钮)
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 网关设备对应每个实际采集设备/上传业务
|
||||
|
||||
## 二、添加设备/修改设备
|
||||
|
||||
<img src={require("@site/static/img/docs/添加设备.png").default} />
|
||||
|
||||
## 三、设备属性配置项
|
||||
|
||||
| 属性| 说明 |
|
||||
| --- | --- |
|
||||
|名称| 设备名称|
|
||||
|描述| 当前设备描述 |
|
||||
|默认执行间隔| 执行间隔,对于采集设备,这个属性是默认的采集间隔,对于业务设备,这个属性是循环线程的等待间隔时间 |
|
||||
|设备使能| 启动/停用采集设备 |
|
||||
|通道| 选择对应的通道 |
|
||||
|插件| 选择对应的插件 |
|
||||
|是否冗余| 启动/停用设备冗余 |
|
||||
|冗余设备| 备用设备选择,当此设备离线时,会在适当的时间切换到备用设备,注意备用设备初始时不会有实际通讯线程创建,链接的变量也不会生效 |
|
||||
|备用字段| 存储自定义信息 |
|
||||
|
||||
## 四、插件属性配置项
|
||||
|
||||
对于不同的插件,插件属性项也不相同,查看对应插件章节中的详细说明。
|
||||
|
||||
比如ModbusMaster
|
||||
|
||||
<img src={require("@site/static/img/docs/插件属性.png").default} />
|
||||
|
124
doc/docs/104.mdx
124
doc/docs/104.mdx
@@ -1,124 +0,0 @@
|
||||
---
|
||||
id: 104
|
||||
title: 变量
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `配置须知`
|
||||
|
||||
更改设备/变量/插件等,需要重启后台(右上角重启后台按钮)
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 网关变量对应每个寄存器点位
|
||||
|
||||
## 二、添加变量/修改变量
|
||||
|
||||
### 变量基础属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/添加变量.png").default} />
|
||||
|
||||
|属性名称| 属性描述| 备注|
|
||||
|-----------|--------------|-----------------|
|
||||
|名称| 当前变量名称,全局唯一(变量)| |
|
||||
|描述| 当前变量描述 ||
|
||||
|单位| 变量值单位 ||
|
||||
|读写权限| 读写/只写/只读 ||
|
||||
|使能| 启用/停用变量 ||
|
||||
|远程写入| 对于变量的写入使能配置 ||
|
||||
|设备| 当前采集设备选择的设备,通过级联选择器选择对应设备名称设置 ||
|
||||
|变量地址| PLC寄存器/OPC ITEMID等 |对于不同插件的设备,变量地址配置不相同,查看对应的插件说明|
|
||||
|执行间隔| 读取时间间隔/执行特殊方法读取的间隔 ||
|
||||
|特殊方法| 某些插件特有的方法 |对于不同的插件,特殊方法配置不相同,查看对应的插件说明|
|
||||
|数据类型| 对应的数据类型 |注意除了特殊驱动,一般不应该选择object|
|
||||
|读取表达式| 动态解析的表达式 ,原始值的代码为raw|示例:``raw.ToInt()*10+3`` 结果:原始值raw为8,输出实时值83 。|
|
||||
|写入表达式| 动态解析的表达式,在写入值时转化,原始值的代码为raw|示例:``raw.ToInt()/10`` 结果:写入值为230时,会下发23到PLC 。|
|
||||
|备用字段| 存储自定义信息 |
|
||||
|
||||
|
||||
|
||||
:::tip `变量地址通用说明`
|
||||
|
||||
通用格式,不区分大小写
|
||||
|
||||
4字节转换格式
|
||||
|
||||
DATA=ABCD;
|
||||
|
||||
举例:
|
||||
|
||||
DATA=ABCD; ,代表大端格式,其中
|
||||
|
||||
ABCD=>Big-Endian;
|
||||
|
||||
BADC=>Big-Endian Byte Swap;
|
||||
|
||||
CDAB=>Little-Endian Byte Swap;
|
||||
|
||||
DCBA=>Little-Endian
|
||||
|
||||
字符串长度:
|
||||
|
||||
LEN=1;
|
||||
|
||||
BCD格式:
|
||||
|
||||
BCD=C8421;,其中有C8421;C5421;C2421;C3;Gray
|
||||
|
||||
字符格式:
|
||||
|
||||
encoding=UTF8;,其中有UTF8;ASCII;Default;Unicode
|
||||
|
||||
数组长度:
|
||||
|
||||
arraylen=2;
|
||||
|
||||
:::
|
||||
|
||||
|
||||
### 报警属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/添加变量1.png").default} />
|
||||
|
||||
:::tip `说明`
|
||||
|
||||
报警属性中定义变量产生报警的规则所需的配置
|
||||
|
||||
:::
|
||||
|
||||
|属性名称| 属性描述| 备注|
|
||||
|-----------|--------------|-----------------|
|
||||
|报警使能| 启用对应报警功能| |
|
||||
|报警限值| 超限时产生报警,布尔量为固定 ||
|
||||
|报警文本| 对应显示的报警文本 ||
|
||||
|报警约束| 动态解析的表达式 ,原始值的代码为raw,计算值为true时才能产生报警 ||
|
||||
|
||||
:::tip `例子`
|
||||
|
||||
数值高高报警
|
||||
|
||||
变量值大于报警限值,并且报警约束为true或者报警约束不存在时,产生报警
|
||||
|
||||
比如设置高高限值为1,其他默认,当变量值大于1时,产生报警
|
||||
|
||||
:::
|
||||
|
||||
|
||||
### 业务属性配置项
|
||||
<img src={require("@site/static/img/docs/添加变量2.png").default} />
|
||||
|
||||
:::tip `说明`
|
||||
|
||||
上传属性中定义变量关联的上传设备所需的配置
|
||||
|
||||
对于不同的插件,插件属性项也不相同,查看对应插件章节中的详细说明。
|
||||
|
||||
:::
|
||||
|
||||
|
@@ -1,34 +0,0 @@
|
||||
---
|
||||
id: 105
|
||||
title: 网关状态
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway**
|
||||
|
||||
运行状态页面,可查看采集/业务设备的运行状态,调试日志等信息
|
||||
|
||||
实时数据页面,可查看变量实时信息
|
||||
|
||||
实时报警页面,可查看变量实时报警
|
||||
|
||||
硬件信息页面,可查看服务器CPU信息等
|
||||
|
||||
## 二、图示
|
||||
|
||||
<img src={require("@site/static/img/docs/运行状态详情.png").default} />
|
||||
|
||||
<img src={require("@site/static/img/docs/实时数据详情.png").default} />
|
||||
|
||||
<img src={require("@site/static/img/docs/实时报警详情.png").default} />
|
||||
|
||||
<img src={require("@site/static/img/docs/硬件信息详情.png").default} />
|
||||
|
||||
|
@@ -1,26 +0,0 @@
|
||||
---
|
||||
id: 106
|
||||
title: 网关日志
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway**
|
||||
|
||||
后台日志记录 有关采集/业务上传的全部网关后台日志
|
||||
|
||||
RPC日志记录 全部反写RPC日志
|
||||
|
||||
## 二、图示
|
||||
|
||||
<img src={require("@site/static/img/docs/RPC日志详情.png").default} />
|
||||
|
||||
<img src={require("@site/static/img/docs/后台日志详情.png").default} />
|
||||
|
||||
|
@@ -1,63 +0,0 @@
|
||||
---
|
||||
id: 2
|
||||
title: 产品介绍
|
||||
---
|
||||
|
||||
## 产品介绍
|
||||
|
||||
**ThingsGateway** 是c#开发的一款边缘采集网关,核心分为四大部分
|
||||
|
||||
### 通道
|
||||
|
||||
通道,实际上相当于一个实际的通讯链路,比如一个串口,一个TCP连接等,在**ThingsGateway**中,
|
||||
通道也会作为线程池中的一个任务,对于同一个通道中的不同设备,采集/业务方法是顺序进行的。
|
||||
|
||||
### 🔥插件
|
||||
|
||||
ThingsGateway中的采集方法或者上传方法等都由插件完成,主程序只负责调度执行。
|
||||
对于不同的采集协议或者业务需求,可以通过开发插件完成自定义的业务操作。
|
||||
|
||||
### 设备
|
||||
|
||||
建立设备,必须指定通道以及插件,也可以说设备其实是插件的配置。
|
||||
同时对于采集设备、业务设备,会有些许差别。
|
||||
|
||||
采集设备:采集数据入网关/写入数据到现场
|
||||
|
||||
业务设备:上传数据到第三方/第三方RPC反写
|
||||
|
||||
### 变量
|
||||
|
||||
变量,用于配置采集设备的具体点位详情,以及对应业务设备中的配置项
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
## 产品特性
|
||||
|
||||
|
||||
|
||||
### 可视化操作
|
||||
|
||||
通过web浏览器配置,调试,验证整个流程
|
||||
|
||||
### 🔥脚本支持
|
||||
|
||||
灵活的数据转换脚本以及数据上传自定义实体脚本,可适配各大云平台的物模型
|
||||
|
||||
### 🔥自定义插件支持
|
||||
|
||||
通过开发插件完成自定义的业务操作。
|
||||
|
||||
### 🔥性能
|
||||
|
||||
测试100w变量点位,500ms-1000ms全部采集完成,稳定连续采集占用CPU资源、内存资源低
|
||||
|
||||
### 断线缓存
|
||||
|
||||
支持断线缓存,恢复后自动上传
|
||||
|
||||
### 🔥完整可商用的边缘网关
|
||||
|
||||
完善的配置权限,操作日志功能等,还有OPC,Web Api,Mqtt,Kafka,时序库,变量报警等更多功能等待你发现
|
@@ -1,78 +0,0 @@
|
||||
---
|
||||
id: 200
|
||||
title: ModbusMatser
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
ModbusMatser作为主站,主动采集Modbus从站协议的设备
|
||||
|
||||
插件支持modbusTcp/modbusRtu格式报文
|
||||
|
||||
通讯链路支持 TcpClient/TcpService(DTU)/串口/Udp
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/ModbusMaster.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| Modbus协议类型 | modbusTcp/modbusRtu格式报文 | |
|
||||
| 默认站号 | 默认的mudbus站号id | **变量可单独配置站号** |
|
||||
| 无交互2min时断开连接 | 没有发送/收到消息 ,2分钟后断开连接 | 仅适用于TcpService链路(DTU模式)|
|
||||
| 心跳检测 | 大写16进制字符串,符合心跳内容会自动回应 | 仅适用于TcpService链路(DTU模式)|
|
||||
| 读写超时时间 | 读写超时时间 | 3000|
|
||||
| 连接超时时间 | 建立通讯链路的超时时间 | 3000|
|
||||
| 发送延时时间 | 在发送请求前的延时时间 | 0|
|
||||
| 组包缓存超时 | 返回分包时的分包间隔超时时间 | 1000 |
|
||||
| 默认解析顺序 | 4个字节以上的数据解析,可设置为ABCD/BADC/CDBA/DCBA,默认ABCD , **变量可单独配置**|ABCD:Big-Endian<br></br>BADC:Big-Endian Byte Swap<br></br>CDAB:Little-Endian Byte Swap<br></br>DCBA:Little-Endian |
|
||||
| 最大打包长度 | 打包长度,最大限值是125 | 100 |
|
||||
| 离线重试间隔 | 设备检测到离线时,重新连接的间隔时间(秒) | 30 |
|
||||
| 失败重试次数 | 读取失败时,重试n次后判定变量为离线 | 3 |
|
||||
| 最大并发数量 | ModbusTcp格式报文特有,ModbusTcp可并发采集 | 1 |
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
- 1、基本地址
|
||||
|
||||
Modbus PLC寄存器
|
||||
|
||||
| 地址 | 功能码 | 说明 |
|
||||
| ---------------| --------------|--------------------------|
|
||||
| 4xxxxx | 03 | 读取03功能码 |
|
||||
| 3xxxxx | 04 | 读取04功能码 |
|
||||
| 1xxxxx | 02 | 读取02功能码 |
|
||||
| 0xxxxx | 01 | 读取01功能码 |
|
||||
|
||||
- 2、站号(可选)
|
||||
|
||||
当需要指定站号地址时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| s=2;10001 | 读取02功能码 ,设备地址为2 |
|
||||
| s=11;40001 | 读取03功能码 ,设备地址为11 |
|
||||
|
||||
- 3、写入功能码(可选)
|
||||
|
||||
当需要指定16/15功能码时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| w=15;10001 | 读取02功能码 ,写入15功能码 |
|
||||
| w=16;40001 | 读取03功能码 ,写入16功能码 |
|
||||
|
||||
- 3、Dtu注册(可选)
|
||||
|
||||
当需要指定Dtu客户端可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| id=12;40001 | 读取03功能码 ,设备地址为默认,Dtu注册包为"12",注意是UTF8格式 |
|
||||
|
@@ -1,96 +0,0 @@
|
||||
---
|
||||
id: 20001
|
||||
title: Modbus
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
## 定义
|
||||
|
||||
程序集:[ThingsGateway.Foundation.Modbus](https://www.nuget.org/packages/ThingsGateway.Foundation.Modbus)
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway.Foundation.Modbus**是对于Modbus协议的封装类库
|
||||
|
||||
支持Tcp/Rtu格式
|
||||
|
||||
支持多个通讯链路:Tcp/Udp/SerialPort
|
||||
|
||||
支持Dtu
|
||||
|
||||
## 二、Modbus主站
|
||||
|
||||
1、创建ModbusMaster
|
||||
|
||||
```
|
||||
/// <summary>
|
||||
/// 新建链路
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public IChannel GetChannel()
|
||||
{
|
||||
TouchSocketConfig touchSocketConfig = new TouchSocketConfig();
|
||||
return touchSocketConfig.GetSerialPortWithOption(new("COM1")); //直接获取串口对象
|
||||
//return touchSocketConfig.GetChannel(ChannelTypeEnum.SerialPortClient, null, null, new("COM1"));//通过链路枚举获取对象
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 新建协议对象
|
||||
/// </summary>
|
||||
/// <param name="channel"></param>
|
||||
/// <returns></returns>
|
||||
public IProtocol GetProtocol(IChannel channel)
|
||||
{
|
||||
var client = new ModbusMaster(channel);
|
||||
return client;
|
||||
}
|
||||
```
|
||||
2、读写操作
|
||||
|
||||
|
||||
```
|
||||
ModbusMaster modbusMasterTest = new ModbusMaster();
|
||||
var channel = modbusMasterTest.GetChannel();
|
||||
var protocol = modbusMasterTest.GetProtocol(channel);
|
||||
var data = await protocol.ReadDoubleAsync("400001"); //读取保持寄存器地址0
|
||||
|
||||
```
|
||||
|
||||
`400001`是PLC Modbus的地址表示方式,代表保持寄存器地址0
|
||||
|
||||
- 基本地址
|
||||
|
||||
Modbus PLC寄存器
|
||||
|
||||
| 地址 | 功能码 | 说明 |
|
||||
| ---------------| --------------|--------------------------|
|
||||
| 4xxxxx | 03 | 读取03功能码 |
|
||||
| 3xxxxx | 04 | 读取04功能码 |
|
||||
| 1xxxxx | 02 | 读取02功能码 |
|
||||
| 0xxxxx | 01 | 读取01功能码 |
|
||||
|
||||
- 站号(可选)
|
||||
|
||||
当需要指定站号地址时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| s=2;10001 | 读取02功能码 ,设备地址为2 |
|
||||
| s=11;40001 | 读取03功能码 ,设备地址为11 |
|
||||
|
||||
- Dtu注册(可选)
|
||||
|
||||
当需要指定Dtu客户端可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| id=12;40001 | 读取03功能码 ,设备地址为默认,Dtu注册包为"12",注意是UTF8格式 |
|
||||
|
||||
|
||||
## 三、Modbus从站
|
||||
|
@@ -1,9 +0,0 @@
|
||||
---
|
||||
id: 20002
|
||||
title: SiemensS7
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
@@ -1,9 +0,0 @@
|
||||
---
|
||||
id: 20003
|
||||
title: OpcDa
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
@@ -1,9 +0,0 @@
|
||||
---
|
||||
id: 20004
|
||||
title: OpcUa
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
@@ -1,112 +0,0 @@
|
||||
---
|
||||
id: 20005
|
||||
title: Dlt645
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 定义
|
||||
|
||||
程序集:[ThingsGateway.Foundation.Dlt645](https://www.nuget.org/packages/ThingsGateway.Foundation.Dlt645)
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway.Foundation.Dlt645**是对于Dlt645-2007协议的封装类库
|
||||
|
||||
支持多个通讯链路:Tcp/Udp/SerialPort
|
||||
|
||||
## 二、Dlt645-2007主站
|
||||
|
||||
1、创建Dlt645Master
|
||||
|
||||
```
|
||||
/// <summary>
|
||||
/// 新建链路
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public IChannel GetChannel()
|
||||
{
|
||||
TouchSocketConfig touchSocketConfig = new TouchSocketConfig();
|
||||
return touchSocketConfig.GetSerialPortWithOption(new("COM1")); //直接获取串口对象
|
||||
//return touchSocketConfig.GetChannel(ChannelTypeEnum.SerialPortClient, null, null, new("COM1"));//通过链路枚举获取对象
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 新建协议对象
|
||||
/// </summary>
|
||||
/// <param name="channel"></param>
|
||||
/// <returns></returns>
|
||||
public IProtocol GetProtocol(IChannel channel)
|
||||
{
|
||||
var client = new Dlt645_2007Master(channel);
|
||||
client.Station = "311111111114";//表号
|
||||
return client;
|
||||
}
|
||||
```
|
||||
2、读写操作
|
||||
|
||||
|
||||
```
|
||||
Dlt645MasterTest dlt645MasterTest = new Dlt645MasterTest();
|
||||
var channel = dlt645MasterTest.GetChannel();
|
||||
var protocol = dlt645MasterTest.GetProtocol(channel);
|
||||
var data = await protocol.ReadDoubleAsync("02010100"); //读取A相电压
|
||||
|
||||
```
|
||||
|
||||
`02010100`是Dlt645中的地址表示方式,代表A相电压,请查看相关协议文档,可在源码附件中找到文档
|
||||
|
||||
- 基本地址
|
||||
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| 02010100 | 读取02010100(A相电压) |
|
||||
|
||||
参考DLT2007协议文档数据标识,可在插件源码中找到附件
|
||||
|
||||
- 站号(可选)
|
||||
|
||||
当需要指定站号地址时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| s=111111111111;02010100 | 读取02010100 ,设备地址为111111111111 |
|
||||
|
||||
- Dtu注册(可选)
|
||||
|
||||
当需要指定Dtu客户端可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| id=12;40001 | 读取03功能码 ,设备地址为默认,Dtu注册包为"12",注意是UTF8格式 |
|
||||
|
||||
|
||||
3、其他方法
|
||||
|
||||
修改密码
|
||||
|
||||
```
|
||||
var result = await protocol.WritePasswordAsync(level, oldPassword, newPassword);
|
||||
```
|
||||
|
||||
更改表号
|
||||
|
||||
```
|
||||
var result = await protocol.WriteDeviceStationAsync(station);
|
||||
```
|
||||
|
||||
修改波特率
|
||||
|
||||
```
|
||||
var result = await protocol.WriteBaudRateAsync(baudRate);
|
||||
```
|
||||
|
||||
读取表号
|
||||
|
||||
```
|
||||
var result = await protocol.ReadDeviceStationAsync;
|
||||
```
|
@@ -1,58 +0,0 @@
|
||||
---
|
||||
id: 201
|
||||
title: ModbusSlave
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
ModbusSlave作为从站,响应主站的采集报文
|
||||
|
||||
插件支持modbusTcp/modbusRtu格式报文
|
||||
|
||||
通讯链路支持 TcpClient/TcpService(DTU)/串口/Udp
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/ModbusSlave.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| Modbus协议类型 | modbusTcp/modbusRtu格式报文 | |
|
||||
| 默认站号 | 默认的mudbus站号id | **变量可单独配置站号** |
|
||||
| 默认解析顺序 | 4个字节以上的数据解析,可设置为ABCD/BADC/CDBA/DCBA,默认ABCD , **变量可单独配置**|ABCD:Big-Endian<br></br>BADC:Big-Endian Byte Swap<br></br>CDAB:Little-Endian Byte Swap<br></br>DCBA:Little-Endian |
|
||||
| 无交互2min时断开连接 | 没有发送/收到消息 ,2分钟后断开连接 | 仅适用于TcpService链路|
|
||||
| 组包缓存超时 | 分包时的分包间隔超时时间 | 1000 |
|
||||
| 多站点 | 是否区分不同的站号的数据 | true|
|
||||
| 允许写入 | 写入权限使能 | Flase |
|
||||
| 立即写入内存 | 外部写入时,是否立即写入内存池 | Flase |
|
||||
|
||||
## 三、变量业务属性
|
||||
|
||||
### 1、从站地址
|
||||
|
||||
- 1、基本地址
|
||||
|
||||
Modbus PLC寄存器
|
||||
|
||||
| 地址 | 功能码 | 说明 |
|
||||
| ---------------| --------------|--------------------------|
|
||||
| 4xxxxx | 03 | 读取03功能码 |
|
||||
| 3xxxxx | 04 | 读取04功能码 |
|
||||
| 1xxxxx | 02 | 读取02功能码 |
|
||||
| 0xxxxx | 01 | 读取01功能码 |
|
||||
|
||||
- 2、站号(可选)
|
||||
|
||||
当需要指定站号地址时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| s=2;10001 | 读取02功能码 ,设备地址为2 |
|
||||
| s=11;40001 | 读取03功能码 ,设备地址为11 |
|
||||
|
@@ -1,72 +0,0 @@
|
||||
---
|
||||
id: 202
|
||||
title: Dlt645Master
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
## 一、说明
|
||||
|
||||
Dlt645Master作为主站,主动采集Dlt645协议的设备
|
||||
|
||||
插件支持Dlt645-2007格式报文
|
||||
|
||||
通讯链路支持 TcpClient/TcpService(DTU)/串口/Udp
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/Dlt645Master.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 无交互2min时断开连接 | 没有发送/收到消息 ,2分钟后断开连接 | 仅适用于TcpService链路(DTU模式)|
|
||||
| 心跳检测 | 大写16进制字符串,符合心跳内容会自动回应 | 仅适用于TcpService链路(DTU模式)|
|
||||
| 读写超时时间 | 读写超时时间 | 3000|
|
||||
| 连接超时时间 | 建立通讯链路的超时时间 | 3000|
|
||||
| 发送延时时间 | 在发送请求前的延时时间 | 0|
|
||||
| 组包缓存超时 | 返回分包时的分包间隔超时时间 | 1000 |
|
||||
| 默认解析顺序 | 4个字节以上的数据解析,可设置为ABCD/BADC/CDBA/DCBA,默认ABCD , **变量可单独配置**|ABCD:Big-Endian<br></br>BADC:Big-Endian Byte Swap<br></br>CDAB:Little-Endian Byte Swap<br></br>DCBA:Little-Endian |
|
||||
| 默认地址 | 电表地址,12个字符 | |
|
||||
| 密码 | 协议写入所需密码 | Flase |
|
||||
| 操作员代码 | 协议写入所需操作员代码 | Flase |
|
||||
| 前导符报文头 | 设为true时,发送请求将添加4个0xFE到报文头部 | Flase |
|
||||
| 离线重试间隔 | 设备检测到离线时,重新连接的间隔时间(秒) | 30 |
|
||||
| 失败重试次数 | 读取失败时,重试n次后判定变量为离线 | 3 |
|
||||
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
- 1、基本地址
|
||||
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| 02010100 | 读取02010100(A相电压) |
|
||||
|
||||
参考DLT2007协议文档数据标识,可在插件源码中找到附件
|
||||
|
||||
- 2、站号(可选)
|
||||
|
||||
当需要指定站号地址时可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| s=111111111111;02010100 | 读取02010100 ,设备地址为111111111111 |
|
||||
|
||||
- 3、Dtu注册(可选)
|
||||
|
||||
当需要指定Dtu客户端可使用,举例:
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| id=12;02010100 | 读取02010100 ,设备地址为默认,Dtu注册包为"12",注意是UTF8格式 |
|
||||
|
||||
|
||||
:::tip `说明`
|
||||
|
||||
注意DLT645协议中,所有的变量都支持String!
|
||||
|
||||
:::
|
||||
|
@@ -1,51 +0,0 @@
|
||||
---
|
||||
id: 203
|
||||
title: SiemensS7Master
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
## 一、说明
|
||||
|
||||
SiemensS7Master作为主站,主动采集西门子S7协议的设备
|
||||
|
||||
插件支持S7格式报文,支持S7-200;S7200-SMART;S7-300;S7-400;S7-1200;S7-1500;
|
||||
|
||||
通讯链路支持 TcpClient/Udp(通常不存在)
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/SiemensS7Master.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| S7类型 | S200;S200SMART;S300;S400;S1200;S1500; | |
|
||||
| 机架号 | 机架号 | 0|
|
||||
| 槽位号 | 槽位号 | 0|
|
||||
| LocalTSAP | 查看西门子localTsap说明,网关中一般不需要再设置 | 0 |
|
||||
| 读写超时时间 | 读写超时时间 | 3000|
|
||||
| 连接超时时间 | 建立通讯链路的超时时间 | 3000|
|
||||
| 发送延时时间 | 在发送请求前的延时时间 | 0|
|
||||
| 组包缓存超时 | 返回分包时的分包间隔超时时间 | 1000 |
|
||||
| 默认解析顺序 | 4个字节以上的数据解析,可设置为ABCD/BADC/CDBA/DCBA,默认ABCD , **变量可单独配置**|ABCD:Big-Endian<br></br>BADC:Big-Endian Byte Swap<br></br>CDAB:Little-Endian Byte Swap<br></br>DCBA:Little-Endian |
|
||||
| 离线重试间隔 | 设备检测到离线时,重新连接的间隔时间(秒) | 30 |
|
||||
| 失败重试次数 | 读取失败时,重试n次后判定变量为离线 | 3 |
|
||||
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
- 1、基本地址
|
||||
|
||||
| 地址 | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| Txxxxx | Timer寄存器,例如T100/T100.1 |
|
||||
| Cxxxxx | Counter寄存器,例如C100/C100.1 |
|
||||
| AIxxxxx | AI寄存器,例如AI100/AI100.1 |
|
||||
| AQxxxxx | AQ寄存器,例如AQ100/AQ100.1 |
|
||||
| Ixxxxx | I寄存器,例如I100/I100.1 |
|
||||
| Qxxxxx | Q寄存器,例如Q100/Q100.1 |
|
||||
| Mxxxxx | M寄存器,例如M100/M100.1 |
|
||||
| DBxxxxx | DB寄存器,例如DB100.1/DB100.1.1 |
|
||||
|
@@ -1,51 +0,0 @@
|
||||
---
|
||||
id: 204
|
||||
title: OpcDaMaster
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `OPCDA驱动注意`
|
||||
|
||||
使用OPCDA插件时,需安装[OPC核心库](https://gitee.com/diego2098/ThingsGateway/attach_files)
|
||||
|
||||
:::
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
可以通过调试页面,导出/导入OPC节点到网关
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
OpcDaMaster作为主站,主动采集OPCDA协议的设备
|
||||
|
||||
插件支持远程OPCDA,但需要配置DCOM,相关知识请自行查阅资料
|
||||
|
||||
通道只支持 Other 类型
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/OpcDaMaster.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| IP | 连接IP | localhost|
|
||||
| Opc名称 | OPC名称,可识别ProgID或CLSID | Kepware.KEPServerEX.V6|
|
||||
| 激活订阅 | 是否采用OPC订阅方式读取变量 | True|
|
||||
| 检查重连频率 | 每隔设定时间获取一次服务器状态,并尝试重新连接(min) |10|
|
||||
| 死区 | OPC死区 | 0|
|
||||
| 最大组大小 | 每隔设定大小分一个OPCGroup | 500|
|
||||
| 更新频率 | 订阅更新频率或者连读频率 (ms) | 1000 |
|
||||
| 离线重试间隔 | 设备检测到离线时,重新连接的间隔时间(秒) ,只适用于非订阅模式 | 30 |
|
||||
| 失败重试次数 | 读取失败时,重试n次后判定变量为离线 ,只适用于非订阅模式 | 3 |
|
||||
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
- 变量地址即为 OPC ItemID
|
||||
|
||||
|
@@ -1,53 +0,0 @@
|
||||
---
|
||||
id: 205
|
||||
title: OpcUaMaster
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
可以通过调试页面,导出/导入OPC节点到网关
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
插件支持OPCUA扩展类型,自定义类型等等,最终体现为json格式
|
||||
|
||||
通道只支持 Other 类型
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/OpcUaMaster.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| OPCURL | OPCUA URL | opc.tcp://127.0.0.1:49320|
|
||||
| 登录账号 | 为空时采用匿名方式登录 | |
|
||||
| 登录密码 | | |
|
||||
| 检查域 | 是否检查域 | Flase|
|
||||
| 安全策略 | 是否安全认证/证书方式登录 | True|
|
||||
| 使用SourceTime | 是否采用服务端的变量时间 | True|
|
||||
| 加载服务端数据类型 | 是否加载服务端的数据类型,对应OPCUA自定义类型,必须为true | True|
|
||||
| 激活订阅 | 是否采用OPC订阅方式读取变量 | True|
|
||||
| 更新频率 | 订阅更新频率或者连读频率 | 1000 |
|
||||
| 死区 | OPC死区 | 0|
|
||||
| 最大组大小 | 每隔设定大小分一个OPCGroup | 500|
|
||||
| 心跳频率 | |3000|
|
||||
| 离线重试间隔 | 设备检测到离线时,重新连接的间隔时间(秒) ,只适用于非订阅模式 | 30 |
|
||||
| 失败重试次数 | 读取失败时,重试n次后判定变量为离线 ,只适用于非订阅模式 | 3 |
|
||||
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
- 变量地址即为 OPC NodeId
|
||||
|
||||
## 四、证书说明
|
||||
|
||||
证书可以在软件目录\OPCUAClientCertificate下查看或者导出/复制
|
||||
|
||||
|
||||
<img src={require("@site/static/img/docs/OpcUaMaster1.png").default} />
|
@@ -1,24 +0,0 @@
|
||||
---
|
||||
id: 206
|
||||
title: VariableExpression
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
## 一、说明
|
||||
|
||||
VariableExpression不与工业设备交互,实际上是一个不依赖采集的表达式脚本计算方法
|
||||
如果不填写变量表达式,变量值会自增
|
||||
|
||||
有关变量表达式的说明,请查看[变量表达式](./104.mdx#变量基础属性配置项)
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
无
|
||||
|
||||
## 三、变量地址配置项
|
||||
|
||||
无
|
||||
|
134
doc/docs/3.mdx
134
doc/docs/3.mdx
@@ -1,134 +0,0 @@
|
||||
---
|
||||
id: 3
|
||||
title: 入门指南
|
||||
slug: /
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
:::tip 提示
|
||||
|
||||
如果你的开发机不是**Windows**系统,在解决方案中,可能存在一些vs生成事件脚本(目录拷贝等不支持),会提示编译失败,请删除.csproj文件中的对应事件,手动拷贝插件类库
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
**ThingsGateway** 基于NET6、8,默认开发IDE为VS2022(**17.8版本以上**),安装VS时需勾选ASP.NET类别.
|
||||
|
||||
<img src={require("@site/static/img/docs/vs2022install.png").default} />
|
||||
|
||||
## 二、下载源码
|
||||
|
||||
[最新版本](https://gitee.com/diego2098/ThingsGateway)
|
||||
|
||||
## 三、编译运行
|
||||
|
||||
下面我们将以vs2022作为示例:
|
||||
|
||||
:::tip 提示
|
||||
|
||||
**注意需要编译解决方案,因为插件与主体没有引用关系**
|
||||
|
||||
:::
|
||||
|
||||
|
||||
1、 vs2022打开解决方案,编译解决方案
|
||||
|
||||
<img src={require("@site/static/img/docs/生成解决方案.png").default} />
|
||||
|
||||
2、 设置ThingsGateway.Server为启动项目,开始调试或开始执行
|
||||
<img src={require("@site/static/img/docs/设置启动项目.png").default} />
|
||||
<img src={require("@site/static/img/docs/开始执行.png").default} />
|
||||
|
||||
3、 启动后会显示登录界面
|
||||
|
||||
<img src={require("@site/static/img/docs/login.png").default} />
|
||||
|
||||
恭喜你体验了软件的启动第一步!
|
||||
|
||||
:::tip 提示
|
||||
|
||||
测试环境下,账密会自动填充为超级管理员账号,默认账户:**SuperAdmin**,密码:**111111**
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 四、建立一个完整的流程
|
||||
|
||||
下面举例说明 采集ModbusTcp设备中的寄存器,通过MqttServer发布 的具体流程
|
||||
|
||||
### 1、建立通道
|
||||
<img src={require("@site/static/img/docs/添加通道.png").default} />
|
||||
|
||||
添加tcpClient通道
|
||||
<img src={require("@site/static/img/docs/通道配置1.png").default} />
|
||||
|
||||
添加mqttClient通道,选择other即可
|
||||
<img src={require("@site/static/img/docs/通道配置2.png").default} />
|
||||
|
||||
### 2、建立采集设备
|
||||
添加采集设备,选择tcpClient通道,modbusTcp驱动
|
||||
<img src={require("@site/static/img/docs/采集设备1.png").default} />
|
||||
<img src={require("@site/static/img/docs/采集设备2.png").default} />
|
||||
|
||||
### 3、建立业务设备
|
||||
添加业务设备,选择mqttClient通道,mqttClient驱动,插件属性中填入第三方MqttBroker的连接信息
|
||||
<img src={require("@site/static/img/docs/业务设备1.png").default} />
|
||||
<img src={require("@site/static/img/docs/业务设备2.png").default} />
|
||||
|
||||
### 4、建立变量
|
||||
|
||||
添加变量,选择modbusTcp设备,填写变量寄存器地址
|
||||
<img src={require("@site/static/img/docs/变量1.png").default} />
|
||||
<img src={require("@site/static/img/docs/变量2.png").default} />
|
||||
|
||||
|
||||
### 5、验证
|
||||
|
||||
经过以上的配置,已经可以从127.0.0.1:502的模拟Modbus设备中,采集到PLC地址(400001),并通过网关的mqttClient插件发布到第三方mqttBroker
|
||||
。下面来验证一下
|
||||
|
||||
首先先启动模拟的modbusSlave软件
|
||||
<img src={require("@site/static/img/docs/modbus模拟软件.png").default} />
|
||||
|
||||
|
||||
然后重启网关后台服务,注意并不是需要重新启动软件进程,
|
||||
而是**重新加载网关的组态配置到运行态中**,通过**网页右下角的重启运行时按钮**进行操作
|
||||
|
||||
<img src={require("@site/static/img/docs/重启后台.png").default} />
|
||||
|
||||
跳转到网关的运行状态查看
|
||||
|
||||
<img src={require("@site/static/img/docs/运行状态.png").default} />
|
||||
|
||||
开启调试日志的话,可以看到每次交互的modbus报文以及结果状态
|
||||
|
||||
采集的数据点位值与相关信息跳转到实时数据页面
|
||||
|
||||
<img src={require("@site/static/img/docs/实时数据.png").default} />
|
||||
|
||||
可以看到值与采集时间等等的变化,注意这里的页面实时值变化是1s的间隔时间,如果配置了采集间隔小于1s,页面刷新不及时是正常的,不影响业务上传
|
||||
|
||||
MqttClient的日志也可以在运行状态中看到
|
||||
<img src={require("@site/static/img/docs/运行状态1.png").default} />
|
||||
|
||||
|
||||
## 五、详细说明
|
||||
|
||||
:::tip 提示
|
||||
|
||||
在查看案例前,请先查看**关于网关的基础内容**
|
||||
|
||||
:::
|
||||
- [文档](https://diego2098.gitee.io/thingsgateway-docs)
|
||||
|
||||
- [博客](https://www.cnblogs.com/ThingsGateway/collections/1104)
|
||||
|
||||
- [视频](https://space.bilibili.com/88105259/channel/series)
|
||||
|
@@ -1,31 +0,0 @@
|
||||
---
|
||||
id: 30001
|
||||
title: 串口
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
### 前言
|
||||
|
||||
串口使用一个称为串行通信协议的协议来管理数据传输。串行通信协议在数据传输期间控制数据流,包括起始位、数据位、波特率、校验位和停止位等。
|
||||
下面每个名称做一个简单的解释。
|
||||
|
||||
``波特率``是指串口通信中每秒传输的二进制位数
|
||||
``起始位``是1位时间、值为0的位。
|
||||
``数据位``通常可能为1位、1.5位、2位时间。
|
||||
``校验位``是1位时间,根据校验方式确定验证值,比如奇校验时,计算数据位中的值为1的个数,如果是奇数,则为1,否则应为0
|
||||
``停止位``通常可能为1位、1.5位、2位时间。停止位是值为1的位。停止位代表着数据传输结束。
|
||||
|
||||
线路路空闲或者数据传输结束时,值总是1。
|
||||
对于正逻辑的TTL电平,值为1是高电平,对于负逻辑(如RS-232电平)则相反。
|
||||
|
||||
单看文字很难理解具体含义,所以我们看图说话,下面这张串口示波器图清晰的表现出二进制的传输原理
|
||||
|
||||
<img src={require("@site/static/img/docs/串口1.png").default} />
|
||||
|
||||
|
||||
如上图,可以看出2进制是 起始``1``、数据(右到左)``01010101``、停止``0`` ,那么解析出来的数据就是``0x55``
|
||||
|
||||
看到这里,相信大家都对串口知识有了一定的理解,这些基础知识对于c#工程师看似没有必要,但可以让你的实际调试开发工作更加得心应手
|
287
doc/docs/301.mdx
287
doc/docs/301.mdx
@@ -1,287 +0,0 @@
|
||||
---
|
||||
id: 301
|
||||
title: MqttClient
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
通过自定义脚本,可快速适配业务模型,比如各大云平台的Iot物模型
|
||||
|
||||
脚本的示例请查看**常见问题**
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
MqttClient通过Tcp/WebSocket的方式,发布内容到Broker(Server),可以定时/变化发布数据
|
||||
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/MqttClient.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| IP | ServerIP,为空时指任意IP | |
|
||||
| 端口 | 连接端口 | 1883|
|
||||
| 是否WebSocket连接 | 是否WebSocket连接 | False |
|
||||
| WebSocketUrl | WebSocketUrl | ws://127.0.0.1:8083/mqtt |
|
||||
| 账号 | 账号 | |
|
||||
| 密码 | 密码 | |
|
||||
| 连接Id | 连接Id | |
|
||||
| 连接超时时间 | 连接超时时间 | |
|
||||
| 允许Rpc写入 | 是否允许写入变量 | |
|
||||
| Rpc写入Topic | 写入变量的主题 | 实际的写入主题为固定通配 {RpcWrite/+} ,其中RpcWrite为该属性填入内容,+通配符是请求GUID值;返回结果主题会在主题后添加Response , 也就是{RpcWrite/+/Response} |
|
||||
| 数据请求Topic | 该主题接受到任何消息都会发布全部信息到对应的变量/设备/报警主题中 | |
|
||||
| 设备是否列表 | 设备是否列表上传,false时每个设备实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 变量是否列表 | 变量是否列表上传,false时每个变量实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 报警是否列表 | 报警是否列表上传,false时每个报警实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 设备Topic | 设备实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 变量Topic | 变量实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 报警Topic | 报警实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 设备实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**DeviceData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 变量实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**VariableData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 报警实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**AlarmVariable**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
### 脚本接口
|
||||
```
|
||||
|
||||
public interface IDynamicModel
|
||||
{
|
||||
IEnumerable<dynamic> GetList(IEnumerable<dynamic> datas);
|
||||
}
|
||||
|
||||
|
||||
```
|
||||
|
||||
### DeviceData
|
||||
```
|
||||
|
||||
/// <summary>
|
||||
/// 设备业务变化数据
|
||||
/// </summary>
|
||||
public class DeviceData
|
||||
{
|
||||
/// <inheritdoc cref="PrimaryIdEntity.Id"/>
|
||||
public long Id { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Name"/>
|
||||
public string Name { get; set; }
|
||||
|
||||
/// <inheritdoc cref="DeviceRunTime.ActiveTime"/>
|
||||
public DateTime ActiveTime { get; set; }
|
||||
|
||||
/// <inheritdoc cref="DeviceRunTime.DeviceStatus"/>
|
||||
public DeviceStatusEnum DeviceStatus { get; set; }
|
||||
|
||||
/// <inheritdoc cref="DeviceRunTime.LastErrorMessage"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string LastErrorMessage { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark1"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark1 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark2"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark2 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark3"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark3 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark4"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark4 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark5"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark5 { get; set; }
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
### VariableData
|
||||
```
|
||||
|
||||
/// <summary>
|
||||
/// 变量业务变化数据
|
||||
/// </summary>
|
||||
public class VariableData
|
||||
{
|
||||
/// <inheritdoc cref="PrimaryIdEntity.Id"/>
|
||||
public long Id { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Variable.Name"/>
|
||||
public string Name { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.DeviceName"/>
|
||||
public string DeviceName { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.Value"/>
|
||||
public object Value { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.ChangeTime"/>
|
||||
public DateTime ChangeTime { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.CollectTime"/>
|
||||
public DateTime CollectTime { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.IsOnline"/>
|
||||
public bool IsOnline { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.LastErrorMessage"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string? LastErrorMessage { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark1"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark1 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark2"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark2 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark3"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark3 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark4"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark4 { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Device.Remark5"/>
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark5 { get; set; }
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
### AlarmVariable
|
||||
```
|
||||
|
||||
/// <summary>
|
||||
/// 报警变量
|
||||
/// </summary>
|
||||
public class AlarmVariable
|
||||
{
|
||||
/// <inheritdoc cref="Variable.Name"/>
|
||||
[SugarColumn(ColumnDescription = "变量名称", IsNullable = false)]
|
||||
public string Name { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Variable.Description"/>
|
||||
[SugarColumn(ColumnDescription = "描述", IsNullable = true)]
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string? Description { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.DeviceName"/>
|
||||
[SugarColumn(ColumnDescription = "设备名称", IsNullable = true)]
|
||||
public string DeviceName { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Variable.RegisterAddress"/>
|
||||
[SugarColumn(ColumnDescription = "变量地址")]
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string RegisterAddress { get; set; }
|
||||
|
||||
/// <inheritdoc cref="Variable.DataType"/>
|
||||
[SugarColumn(ColumnDescription = "数据类型", ColumnDataType = "varchar(100)")]
|
||||
public DataTypeEnum DataType { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.AlarmCode"/>
|
||||
[SugarColumn(ColumnDescription = "报警值", IsNullable = false)]
|
||||
public string AlarmCode { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.AlarmLimit"/>
|
||||
[SugarColumn(ColumnDescription = "报警限值", IsNullable = false)]
|
||||
public string AlarmLimit { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.AlarmText"/>
|
||||
[SugarColumn(ColumnDescription = "报警文本", IsNullable = true)]
|
||||
public string? AlarmText { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.AlarmTime"/>
|
||||
[SugarColumn(ColumnDescription = "报警时间", IsNullable = false)]
|
||||
public DateTime AlarmTime { get; set; }
|
||||
|
||||
/// <inheritdoc cref="VariableRunTime.EventTime"/>
|
||||
public DateTime EventTime { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 报警类型
|
||||
/// </summary>
|
||||
public AlarmTypeEnum? AlarmType { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// 事件类型
|
||||
/// </summary>
|
||||
public EventTypeEnum EventType { get; set; }
|
||||
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark1 { get; set; }
|
||||
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark2 { get; set; }
|
||||
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark3 { get; set; }
|
||||
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark4 { get; set; }
|
||||
|
||||
[JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
|
||||
public string Remark5 { get; set; }
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
## 三、变量业务属性
|
||||
|
||||
### 允许写入
|
||||
|
||||
单独配置变量是否允许写入
|
||||
|
||||
|
||||
|
||||
## 四、Rpc
|
||||
|
||||
### 1、请求内容
|
||||
|
||||
MqttRpc的请求内容与WebApi一致,请求参数为Dictionary<string, string>,比如
|
||||
|
||||
```
|
||||
{
|
||||
|
||||
"D500":"1"
|
||||
|
||||
}
|
||||
```
|
||||
|
||||
键为变量名称,值为写入参数值
|
||||
|
||||
### 2、请求主题
|
||||
|
||||
请求主题在配置属性中设置,查看**Rpc写入Topic**
|
||||
|
||||
注意,实际的请求主题为 `{ThingsGateway.Rpc/[自定义GUID或者雪花ID]/[Rpc写入Topic]}`
|
||||
|
||||
|
||||
### 3、Rpc返回主题
|
||||
|
||||
`{ThingsGateway.Rpc/[自定义GUID或者雪花ID]/[Rpc写入Topic]/Response}`
|
||||
|
||||
### 4、图示
|
||||
|
||||
<img src={require("@site/static/img/docs/MqttRpc.png").default} />
|
@@ -1,74 +0,0 @@
|
||||
---
|
||||
id: 302
|
||||
title: MqttServer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
通过自定义脚本,可快速适配业务模型
|
||||
|
||||
脚本的示例请查看**常见问题**
|
||||
|
||||
:::
|
||||
|
||||
:::tip `权限注意`
|
||||
|
||||
Server的连接权限除了Id前缀限制外,账号密码同样要求,在网关后台创建的所有账号密码都可以登录MqttServer
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
MqttServer支持Tcp/webSocket方式接入,可以定时/变化发布数据,支持Rpc写入
|
||||
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/MqttServer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| IP | ServerIP,为空时指任意IP | |
|
||||
| 端口 | Tcp绑定端口 | 1883|
|
||||
| WebSocket端口 | WebSocket绑定端口 | 8083,固定/mqtt路由 |
|
||||
| 允许连接的ID(前缀) | 允许连接的ID(前缀) |ClientId必须以这个属性开头 |
|
||||
| 允许Rpc写入 | 是否允许写入变量 | |
|
||||
| Rpc写入Topic | 写入变量的主题 | 实际的写入主题为固定通配 {RpcWrite/+} ,其中RpcWrite为该属性填入内容,+通配符是请求GUID值;返回结果主题会在主题后添加Response , 也就是{RpcWrite/+/Response} |
|
||||
| 设备是否列表 | 设备是否列表上传,false时每个设备实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 变量是否列表 | 变量是否列表上传,false时每个变量实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 报警是否列表 | 报警是否列表上传,false时每个报警实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 设备Topic | 设备实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 变量Topic | 变量实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 报警Topic | 报警实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 设备实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**DeviceData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 变量实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**VariableData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 报警实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**AlarmVariable**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
### 脚本与实体
|
||||
|
||||
查看MqttClient页面[脚本接口](./301.mdx#脚本接口)
|
||||
|
||||
## 三、变量业务属性
|
||||
|
||||
### 允许写入
|
||||
|
||||
单独配置变量是否允许写入
|
||||
|
||||
|
||||
## 四、Rpc
|
||||
|
||||
查看MqttClient页面[Rpc](./301.mdx#四rpc)
|
@@ -1,58 +0,0 @@
|
||||
---
|
||||
id: 303
|
||||
title: RabbitMQProducer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
通过自定义脚本,可快速适配业务模型
|
||||
|
||||
脚本的示例请查看**常见问题**
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
RabbitMQProducer适配RabbitMQ协议,主动发布内容到服务端,可以定时/变化发布数据
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/RabbitMQProducer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| IP | ServerIP,为空时指任意IP | |
|
||||
| 端口 | 连接端口 | |
|
||||
| 账号 | 账号 | |
|
||||
| 密码 | 密码 | |
|
||||
| 是否声明队列 | 初始化时是否自动创建队列 | |
|
||||
| 虚拟Host | / | |
|
||||
| 交换机名称 | 交换机名称 | |
|
||||
| 设备是否列表 | 设备是否列表上传,false时每个设备实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 变量是否列表 | 变量是否列表上传,false时每个变量实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 报警是否列表 | 报警是否列表上传,false时每个报警实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 设备Topic | 设备实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 变量Topic | 变量实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 报警Topic | 报警实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 设备实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**DeviceData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 变量实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**VariableData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 报警实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**AlarmVariable**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
### 脚本与实体
|
||||
|
||||
查看MqttClient页面[脚本接口](./301.mdx#脚本接口)
|
||||
|
||||
|
@@ -1,77 +0,0 @@
|
||||
---
|
||||
id: 304
|
||||
title: KafkaProducer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
通过自定义脚本,可快速适配业务模型
|
||||
|
||||
脚本的示例请查看**常见问题**
|
||||
|
||||
:::
|
||||
|
||||
:::tip `须知`
|
||||
|
||||
插件使用**librdkafka**,注意按需安装c库
|
||||
|
||||
On Mac OSX, install librdkafka with homebrew:
|
||||
```
|
||||
$ brew install librdkafka
|
||||
```
|
||||
On Debian and Ubuntu, install librdkafka from the Confluent APT repositories, see instructions here and then install librdkafka:
|
||||
```
|
||||
$ apt install librdkafka-dev
|
||||
|
||||
```
|
||||
On RedHat, CentOS, Fedora, install librdkafka from the Confluent YUM repositories, instructions here and then install librdkafka:
|
||||
```
|
||||
$ yum install librdkafka-devel
|
||||
```
|
||||
For other platforms, follow the source building instructions below.
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
KafkaProducer适配Kafka协议,主动发布内容到服务端,可以定时/变化发布数据
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/KafkaProducer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 服务地址 | 服务地址 | 127.0.0.1:9092|
|
||||
| 发布超时时间 | 发布超时时间 |5000 |
|
||||
| 用户名 | 用户名 | |
|
||||
| 密码 | 密码 | |
|
||||
| SecurityProtocol | SecurityProtocol | |
|
||||
| SaslMechanism | SaslMechanism | |
|
||||
| 设备是否列表 | 设备是否列表上传,false时每个设备实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 变量是否列表 | 变量是否列表上传,false时每个变量实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 报警是否列表 | 报警是否列表上传,false时每个报警实体都会单独发布,注意性能需求,默认为true | |
|
||||
| 设备Topic | 设备实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 变量Topic | 变量实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 报警Topic | 报警实体的发布主题 ,使用${key}作为匹配项,key必须是上传实体中的属性 | |
|
||||
| 设备实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**DeviceData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 变量实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**VariableData**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 报警实体脚本 | 脚本返回新的实体列表,动态类中需继承**IDynamicModel**,传入列表为**AlarmVariable**,查看以下具体属性 | 编辑页面中,可通过检查按钮验证脚本,脚本示例请查看**常见问题** |
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
### 脚本与实体
|
||||
|
||||
查看MqttClient页面[脚本接口](./301.mdx#脚本接口)
|
||||
|
||||
|
@@ -1,34 +0,0 @@
|
||||
---
|
||||
id: 305
|
||||
title: TDengineDBProducer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
TDengineDBProducer适配TDengineDB时序数据库,可以定时/变化存储变量数据
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/TDengineDBProducer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 链接字符串 | 链接字符串 | Host=localhost;Port=6030;Username=root;Password=taosdata;Database=test|
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
|
||||
|
@@ -1,34 +0,0 @@
|
||||
---
|
||||
id: 306
|
||||
title: QuestDBProducer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
QuestDBProducer适配QuestDB时序数据库,可以定时/变化存储变量数据
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/QuestDBProducer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 链接字符串 | 链接字符串 | host=localhost;port=8812;username=admin;password=quest;database=qdb;ServerCompatibilityMode=NoTypeLoading;|
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
|
||||
|
@@ -1,38 +0,0 @@
|
||||
---
|
||||
id: 307
|
||||
title: SqlDBProducer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
SqlDBProducer适配关系数据库,可以定时/变化存储变量数据,也可以实时更新数据到实时表
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/SqlDBProducer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 是否实时表 | 开启实时更新数据功能 | |
|
||||
| 是否历史表 | 开始历史存储功能 |true |
|
||||
| 实时表名称 | 实时表名称 | |
|
||||
| 数据库类型 | 数据库类型 | |
|
||||
| 链接字符串 | 链接字符串 | server=.;uid=sa;pwd=111111;database=test;|
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 是否间隔执行 | 是否选择全部变量,true间隔上传,False变化检测上传 | |
|
||||
| 间隔执行时间 | 间隔执行时间 | |
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
|
||||
|
@@ -1,32 +0,0 @@
|
||||
---
|
||||
id: 308
|
||||
title: SqlHisAlarm
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
## 一、说明
|
||||
|
||||
SqlHisAlarm适配关系数据库,可以变化存储变量报警数据
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/SqlHisAlarm.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 数据库类型 | 数据库类型 | |
|
||||
| 链接字符串 | 链接字符串 | server=.;uid=sa;pwd=111111;database=test;|
|
||||
| 启用缓存 | 是否启用缓存 | |
|
||||
| 上传列表最大数量 | 每一次上传的列表最大数量 | |
|
||||
| 内存队列最大数量 | 内存队列的最大数量,超出或失败时转入文件缓存,根据数据量设定适当值 | |
|
||||
|
||||
|
||||
|
@@ -1,53 +0,0 @@
|
||||
---
|
||||
id: 309
|
||||
title: OpcUaServer
|
||||
---
|
||||
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
:::tip `权限注意`
|
||||
|
||||
如果开启安全策略,在网关后台创建的所有账号密码都可以登录OpcUaServer
|
||||
|
||||
如果不开启安全策略,则可以匿名登录
|
||||
|
||||
:::
|
||||
|
||||
## 一、说明
|
||||
|
||||
OpcUaServer支持外部OpcUa客户端读写
|
||||
|
||||
通道只支持 Other
|
||||
|
||||
## 二、插件属性配置项
|
||||
|
||||
<img src={require("@site/static/img/docs/OpcUaServer.png").default} />
|
||||
|
||||
| 属性 | 说明 | 备注|
|
||||
| ---------------| --------------------------| ---|
|
||||
| 是否选择全部变量 | 是否选择全部变量,true时不需要单个变量添加业务属性 | |
|
||||
| 服务地址 | Url ,以分号分割,可设置多个 | opc.tcp://127.0.0.1:49321 |
|
||||
| SubjectName | 证书内容 | |
|
||||
| 安全策略 | 启用后将不接受使用匿名登录的客户端,并且可以写入变量 | |
|
||||
| 自动接受不受信任的证书 | 自动获取客户端证书并接受 | True |
|
||||
|
||||
|
||||
|
||||
## 三、变量业务属性
|
||||
|
||||
### 数据类型
|
||||
|
||||
同变量管理数据类型Enum
|
||||
|
||||
## 四、证书说明
|
||||
|
||||
证书可以在软件目录\OPCUAServerCertificate下查看或者导出/复制
|
||||
|
||||
|
||||
<img src={require("@site/static/img/docs/OpcUaServer1.png").default} />
|
||||
|
||||
|
@@ -1,31 +0,0 @@
|
||||
---
|
||||
id: 400
|
||||
title: 发布
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
## 一、编译解决方案
|
||||
|
||||
<img src={require("@site/static/img/docs/发布.png").default} />
|
||||
|
||||
选择Release , 点击解决方案全编译(或者编译plugin文件夹)
|
||||
|
||||
## 二、发布版本
|
||||
|
||||
<img src={require("@site/static/img/docs/发布1.png").default} />
|
||||
|
||||
按需选择发布版本(图中为linux-64 net6)
|
||||
|
||||
## 三、复制插件文件夹
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
如果你的开发机是**Windows**系统,这一步不再需求进行,发布时通过脚本已经自动复制到发布文件夹
|
||||
|
||||
:::
|
||||
|
||||
<img src={require("@site/static/img/docs/发布2.png").default} />
|
||||
|
@@ -1,37 +0,0 @@
|
||||
---
|
||||
id: 401
|
||||
title: Windows部署
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
如果需要Runtime依赖部署,需要安装ASP.NET Core Runtime,如果是独立发布部署,则不需要安装Runtime
|
||||
|
||||
下载链接:https://dotnet.microsoft.com/zh-cn/download/dotnet
|
||||
|
||||
:::
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
遵循windows service服务安装/启动/停止方式 https://docs.microsoft.com/zh-cn/windows-server/administration/windows-commands/sc-create
|
||||
|
||||
提供懒人bat脚本文件,管理员身份运行**WindowsServiceCreate.bat**
|
||||
|
||||
|
||||
<img src={require("@site/static/img/docs/Windows服务.png").default} />
|
||||
|
||||
运行脚本后可以在windows服务中找到**ThingsGateway**
|
||||
|
||||
<img src={require("@site/static/img/docs/Windows服务1.png").default} />
|
||||
|
||||
如需删除服务,运行**WindowsServiceDelete.bat**
|
||||
|
195
doc/docs/402.mdx
195
doc/docs/402.mdx
@@ -1,195 +0,0 @@
|
||||
---
|
||||
id: 402
|
||||
title: IIS部署
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::caution 注意
|
||||
|
||||
1、必须启用IIS WebSocket协议
|
||||
|
||||
2、禁用IIS回收
|
||||
:::
|
||||
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
如果需要Runtime依赖部署,需要安装ASP.NET Core Runtime,如果是独立发布部署,则不需要安装Runtime
|
||||
|
||||
下载链接:https://dotnet.microsoft.com/zh-cn/download/dotnet
|
||||
|
||||
:::
|
||||
|
||||
|
||||
:::tip 精简发布文件
|
||||
|
||||
如果需要精简发布后的文件,也就是删除不必要的文件夹,可以编辑 Web 项目的 `.csproj` 并添加 `<SatelliteResourceLanguages>en-US</SatelliteResourceLanguages>`,如:
|
||||
|
||||
```cs showLineNumbers {3}
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<SatelliteResourceLanguages>en-US</SatelliteResourceLanguages>
|
||||
</PropertyGroup>
|
||||
```
|
||||
|
||||
若无需生成 `.pdb` 文件,可以继续添加:
|
||||
|
||||
```cs showLineNumbers {2-3}
|
||||
<PropertyGroup>
|
||||
<DebugType>none</DebugType>
|
||||
<DebugSymbols>false</DebugSymbols>
|
||||
</PropertyGroup>
|
||||
```
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 服务器环境配置
|
||||
|
||||
### 第一步
|
||||
|
||||
安装.NET Core 运行时捆绑包:[点击下载](https://dotnet.microsoft.com/permalink/dotnetcore-current-windows-runtime-bundle-installer)
|
||||
|
||||
### 第二步(命令)
|
||||
|
||||
```bash showLineNumbers
|
||||
net stop was /y
|
||||
```
|
||||
|
||||
### 第三步(命令)
|
||||
|
||||
```bash showLineNumbers
|
||||
net start w3svc
|
||||
```
|
||||
|
||||
### 第四步(命令)
|
||||
|
||||
```bash showLineNumbers
|
||||
set ASPNETCORE_ENVIRONMENT=Production
|
||||
```
|
||||
|
||||
## 部署到 IIS
|
||||
|
||||
### 添加新网站
|
||||
|
||||
<img src={require("@site/static/img/furion/ds1.png").default} />
|
||||
|
||||
### 配置网站信息
|
||||
|
||||
<img src={require("@site/static/img/furion/ds2.png").default} />
|
||||
|
||||
### 34.1.3.3 配置应用程序池
|
||||
|
||||
<img src={require("@site/static/img/furion/ds3.png").default} />
|
||||
|
||||
### 34.1.3.4 设置为 `非托管`
|
||||
|
||||
<img src={require("@site/static/img/furion/ds4.png").default} />
|
||||
|
||||
### 34.1.3.5 重启网站
|
||||
|
||||
只需重启网站或应用程序池即可。
|
||||
|
||||
## 34.1.4 常见问题
|
||||
|
||||
### 34.1.4.1 405 状态码,不支持 `PUT,DELETE` 请求
|
||||
|
||||
默认情况下,`IIS`拒绝 `PUT`和 `DELETE` 请求,原因为 `IIS` 默认注册了一个名为 `WebDAVModule` 的自定义 `HttpModule` 导致的。
|
||||
|
||||
解决该问题,只需要在 `web.config` 移除即可:
|
||||
|
||||
```xml {2-6}
|
||||
<configuration>
|
||||
<system.webServer>
|
||||
<modules runAllManagedModulesForAllRequests="true">
|
||||
<remove name="webDAVModule"/>
|
||||
</modules>
|
||||
</system.webServer>
|
||||
</configuration>
|
||||
```
|
||||
|
||||
微软官方文档:[https://docs.microsoft.com/zh-cn/troubleshoot/developer/webapps/iis/health-diagnostic-performance/http-error-405-website](https://docs.microsoft.com/zh-cn/troubleshoot/developer/webapps/iis/health-diagnostic-performance/http-error-405-website)
|
||||
|
||||
<img src={require("@site/static/img/furion/iis5.png").default} />
|
||||
|
||||
### 34.1.4.2 `WebSocket`/ `SignalR` 连接报错
|
||||
|
||||
如果项目部署在 `IIS` 中出现 `WebSoket`/`SignalR` 不能连接或连接失败等问题,请确保 `IIS` 服务中的 `WebSocket 协议` 是勾选状态
|
||||
|
||||
<img src={require("@site/static/img/furion/iis2.png").default} />
|
||||
|
||||
### 34.1.4.3 部署之后缺失 `api-ms-win.xxxx.dll` 问题
|
||||
|
||||
有时候将发布文件发布到服务器后,出现丢失 `api.ms-win.xxxx.dll` 文件,这时只需要重新发布并选择服务器特定的架构即可。
|
||||
|
||||
<img src={require("@site/static/img/furion/iis4.jpg").default} />
|
||||
|
||||
<img src={require("@site/static/img/furion/iis3.png").default} />
|
||||
|
||||
## 34.1.5 `IIS` 回收问题和配置
|
||||
|
||||
通过 `IIS` 部署 `.NET Core` 应用程序,如果启动了系统日志,就会发现经常出现 `Application is shutting down...` 的日志,代表 `IIS` 回收了应用程序池。
|
||||
|
||||
对于一个长期在线的网站来说,这是非常不合理的,所以我们可以通过以下配置让 `IIS` 进行长时间不访问便回收的机制。
|
||||
|
||||
---
|
||||
|
||||
配置步骤如下:
|
||||
|
||||
1. 打开 `IIS` 并点击左侧树根节点(计算机名称)并点击右侧的 `Configuration Editor`(配置编辑器)
|
||||
|
||||
<img src={require("@site/static/img/furion/iis6.png").default} />
|
||||
|
||||
2. 在 `Section`(节)选择 `system.applicationHost/applicationPools` 并设置 `startMode` 为 `AlwaysRunning`,之后点击 `Apply` 保存。
|
||||
|
||||
<img src={require("@site/static/img/furion/iis7.png").default} />
|
||||
|
||||
3. 点击左侧树根节点(计算机名称)下的 `Application Pools` 并点击最右侧的 `Set Appliation Pool Defaults...`(设置应用程序池默认配置...)
|
||||
|
||||
<img src={require("@site/static/img/furion/iis8.png").default} />
|
||||
|
||||
4. 设置 `Idle Time-out (minutes)`(闲置超时(分钟)为 `0`
|
||||
|
||||
<img src={require("@site/static/img/furion/iis9.png").default} />
|
||||
|
||||
这样即可解决 `IIS` 回收问题。
|
||||
|
||||
## 34.1.6 卷影(无占用)复制发布替换
|
||||
|
||||
正常情况下如果我们代码重新发布后替换 `IIS` 中的文件,这时候会出现文件占用无法进行替换,过去运维人员都是先停止站点后替换再启动。但我们也可以配置 `web.config` 文件启用卷影复制模式实现类似**热更新**操作,如:
|
||||
|
||||
```xml showLineNumbers {12-18}
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<configuration>
|
||||
<!-- To customize the asp.net core module uncomment and edit the following section.
|
||||
For more info see https://go.microsoft.com/fwlink/?linkid=838655 -->
|
||||
|
||||
<system.webServer>
|
||||
<handlers>
|
||||
<remove name="aspNetCore"/>
|
||||
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModulev2" resourceType="Unspecified"/>
|
||||
</handlers>
|
||||
<aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout">
|
||||
<handlerSettings>
|
||||
<handlerSetting name="experimentalEnableShadowCopy" value="true" />
|
||||
<handlerSetting name="shadowCopyDirectory" value="../ShadowCopyDirectory/" />
|
||||
<!-- Only enable handler logging if you encounter issues-->
|
||||
<!--<handlerSetting name="debugFile" value=".\logs\aspnetcore-debug.log" />-->
|
||||
<!--<handlerSetting name="debugLevel" value="FILE,TRACE" />-->
|
||||
</handlerSettings>
|
||||
</aspNetCore>
|
||||
</system.webServer>
|
||||
</configuration>
|
||||
```
|
||||
|
||||
关于卷影复制更多知识可查看以下文档:
|
||||
|
||||
- [https://devblogs.microsoft.com/dotnet/asp-net-core-updates-in-net-6-preview-3/#shadow-copying-in-iis](https://devblogs.microsoft.com/dotnet/asp-net-core-updates-in-net-6-preview-3/#shadow-copying-in-iis)
|
||||
- [https://learn.microsoft.com/zh-cn/dotnet/framework/app-domains/shadow-copy-assemblies](https://learn.microsoft.com/zh-cn/dotnet/framework/app-domains/shadow-copy-assemblies)
|
||||
|
||||
|
||||
|
||||
|
122
doc/docs/403.mdx
122
doc/docs/403.mdx
@@ -1,122 +0,0 @@
|
||||
---
|
||||
id: 403
|
||||
title: Docker部署
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
:::important 特别注意
|
||||
|
||||
验证码使用SkiaSharp,如果是在 linux 服务下运行则需要安装 libfontconfig1,如 ubuntu 的安装命令
|
||||
```
|
||||
apt-get update
|
||||
apt-get -y install libfontconfig1
|
||||
```
|
||||
如果是采用 docker 模式运行,则需要在 dockerfile 中添加如下配置,该命令适用于 debian 和 ubuntu 的 docker
|
||||
```
|
||||
RUN apt-get update && apt-get -y install libfontconfig1
|
||||
```
|
||||
:::
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
如果需要Runtime依赖部署,需要安装ASP.NET Core Runtime,如果是独立发布部署,则不需要安装Runtime
|
||||
|
||||
下载链接:https://dotnet.microsoft.com/zh-cn/download/dotnet
|
||||
|
||||
:::
|
||||
|
||||
|
||||
:::tip 精简发布文件
|
||||
|
||||
如果需要精简发布后的文件,也就是删除不必要的文件夹,可以编辑 Web 项目的 `.csproj` 并添加 `<SatelliteResourceLanguages>en-US</SatelliteResourceLanguages>`,如:
|
||||
|
||||
```cs showLineNumbers {3}
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<SatelliteResourceLanguages>en-US</SatelliteResourceLanguages>
|
||||
</PropertyGroup>
|
||||
```
|
||||
|
||||
若无需生成 `.pdb` 文件,可以继续添加:
|
||||
|
||||
```cs showLineNumbers {2-3}
|
||||
<PropertyGroup>
|
||||
<DebugType>none</DebugType>
|
||||
<DebugSymbols>false</DebugSymbols>
|
||||
</PropertyGroup>
|
||||
```
|
||||
|
||||
:::
|
||||
|
||||
|
||||
## 34.2.1 关于 `Docker` 部署
|
||||
|
||||
在 `Docker` 中部署网站有两种方式:
|
||||
|
||||
- `发布后构建`:此方式是先发布网站后在再构建镜像,这样可以减少不必要的构建层,而且还能缩减镜像大小。**(推荐)**
|
||||
- `编译+构建+发布`:也就是说在 `Dockerfile` 中配置网站从构建到发布的完整过程,此方式会速度慢,而且会产生冗余层,增加镜像大小。
|
||||
|
||||
## 34.2.2 两种方式构建
|
||||
|
||||
### 34.2.2.1 发布后构建
|
||||
|
||||
|
||||
- 👉 编写 `Dockerfile`
|
||||
|
||||
```
|
||||
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
|
||||
COPY . /app
|
||||
WORKDIR /app
|
||||
EXPOSE 80
|
||||
#linux安装
|
||||
RUN echo "deb https://mirrors.tuna.tsinghua.edu.cn/debian/ sid main contrib non-free" > /etc/apt/sources.list
|
||||
RUN apt-get update && apt-get -y install libfontconfig1
|
||||
ENTRYPOINT ["dotnet", "ThingsGateway.Web.Server.dll","--urls","http://*:7200"]
|
||||
|
||||
```
|
||||
|
||||
|
||||
|
||||
- 👉 将 `Dockerfile` 文件拷贝到发布根目录
|
||||
|
||||
将编写好的 `Dockerfile` 文件(注意 `D` 大写)拷贝到发布网站的根目录下。
|
||||
|
||||
:::tip `提示`
|
||||
|
||||
git仓库中已经包含 `Dockerfile` 文件
|
||||
|
||||
:::
|
||||
|
||||
- 👉 构建 `Docker` 镜像
|
||||
|
||||
在网站发布后的路径根目录下(必须含 `Dockerfile`)打开 `CMD/PowerShell` 只需构建命令:
|
||||
|
||||
```bash showLineNumbers
|
||||
docker build -t 网站名称:网站版本号 .
|
||||
```
|
||||
|
||||
:::important 特别注意
|
||||
|
||||
后端的 `.` 不能省略
|
||||
|
||||
:::
|
||||
|
||||
- 👉 启动镜像
|
||||
|
||||
```bash showLineNumbers
|
||||
docker run --name 容器名称 -p 5000:80 --restart=always -d 网站名称:网站版本号
|
||||
```
|
||||
|
||||
:::caution `.NET8` 中 `80` 端口问题
|
||||
|
||||
在使用 `.NET8`,默认的端口由原来的 `80` 端口变成了 `8080`。[查看相关说明](https://learn.microsoft.com/zh-cn/dotnet/core/compatibility/containers/8.0/aspnet-port)
|
||||
|
||||
:::
|
||||
|
||||
|
||||
- 👉 在 `Dockerfile` 所在路径构建
|
||||
|
||||
接下来的步骤和上述步骤一致,不再重复编写。
|
@@ -1,55 +0,0 @@
|
||||
---
|
||||
id: 404
|
||||
title: Linux服务部署
|
||||
---
|
||||
|
||||
:::important 特别注意
|
||||
|
||||
验证码使用SkiaSharp,如果是在 linux 服务下运行则需要安装 libfontconfig1,如 ubuntu 的安装命令
|
||||
```
|
||||
apt-get update
|
||||
apt-get -y install libfontconfig1
|
||||
```
|
||||
如果是采用 docker 模式运行,则需要在 dockerfile 中添加如下配置,该命令适用于 debian 和 ubuntu 的 docker
|
||||
```
|
||||
RUN apt-get update && apt-get -y install libfontconfig1
|
||||
```
|
||||
:::
|
||||
|
||||
### (一)PM2守护
|
||||
|
||||
详细安装请自行查找资料
|
||||
|
||||
查阅详细官方文档 https://pm2.keymetrics.io/docs/usage/quick-start/
|
||||
|
||||
下面介绍一下常用指令
|
||||
|
||||
- 安装pm2
|
||||
|
||||
```
|
||||
npm install pm2@latest -g
|
||||
```
|
||||
|
||||
- 启用应用程序
|
||||
|
||||
```
|
||||
pm2 start pm2-linux.json
|
||||
```
|
||||
|
||||
- 停止应用程序
|
||||
|
||||
```
|
||||
pm2 stop pm2-linux.json
|
||||
```
|
||||
|
||||
- 自动启动
|
||||
|
||||
```
|
||||
pm2-startup
|
||||
pm2 save
|
||||
```
|
||||
|
||||
### (二)linux服务
|
||||
|
||||
自行查询相关资料 **NetCore/Linux/Systemd**
|
||||
|
@@ -1,47 +0,0 @@
|
||||
---
|
||||
id: 501
|
||||
title: 常见问题
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
#### 1、Modbus地址可以只写地址0吗,一定要写成类似400001?
|
||||
|
||||
按照PLC Modbus寄存器的格式,以区域号为起始字符,后续加上(寄存器地址+1)
|
||||
所以一定要写成400001
|
||||
|
||||
#### 2、数据如何设置小数位
|
||||
|
||||
网关提供灵活的脚本式配置转换,可以在变量的读取表达式中进行配置转换
|
||||
如果要设置小数位为2,可以填入
|
||||
```
|
||||
Math.Round(raw.ToDecimal(), 2)
|
||||
```
|
||||
|
||||
#### 3、源码打开razor文件时,不出现智能提示,有waring警告(波浪线)
|
||||
|
||||
VS的bug导致的,可以尝试升级vs,把工程目录下的.vs文件夹已经全部的bin OR obj 删除后,重新打开解决方案
|
||||
|
||||
#### 4、报警属性中的报警约束如何定义
|
||||
|
||||
报警约束和变量表达式类似,填入脚本,返回值为true时,报警生效
|
||||
|
||||
|
||||
```csharp
|
||||
|
||||
//新建testInt1,testInt2两个变量
|
||||
|
||||
//在testInt1的高高报警值为1,开启使能
|
||||
//在testInt1的高高报警约束中定义testInt2>10
|
||||
|
||||
|
||||
//testInt1为8,testInt2为11时,产生testInt1报警
|
||||
//testInt1为8,testInt2为10时,不会产生testInt1报警
|
||||
```
|
||||
|
||||
#### 5、启动项目之后,驱动调试页面没有任何信息,设备选择插件时也不出现任何选择项
|
||||
|
||||
网关插件未编译,需要编译解决方案,查看入门指南;或者插件未能成功拷贝到插件目录(Plugins)
|
118
doc/docs/502.mdx
118
doc/docs/502.mdx
@@ -1,118 +0,0 @@
|
||||
---
|
||||
id: 502
|
||||
title: 脚本常见问题
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
## 一、脚本示例
|
||||
|
||||
```
|
||||
|
||||
//变量脚本动态设置传输实体的Demo
|
||||
//只传输变量名称,变量值,变量在线状态,变量值改变时间
|
||||
public class DemoScript:IDynamicModel
|
||||
{
|
||||
public IEnumerable<dynamic> GetList(IEnumerable<object> datas)
|
||||
{
|
||||
List<DemoData> demoDatas = new List<DemoData>();
|
||||
foreach (var v in datas)
|
||||
{
|
||||
var data=(VariableData)v;
|
||||
DemoData demoData = new DemoData();
|
||||
demoData.Value = data.Value;
|
||||
demoData.Name = data.Name;
|
||||
demoData.IsOnline = data.IsOnline;
|
||||
demoData.ChangeTime = data.ChangeTime;
|
||||
demoDatas.Add(demoData);
|
||||
}
|
||||
return demoDatas;
|
||||
}
|
||||
}
|
||||
public class DemoData
|
||||
{
|
||||
public string Name { get; set; }
|
||||
public bool IsOnline { get; set; }
|
||||
public object Value { get; set; }
|
||||
public DateTime ChangeTime { get; set; }
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
|
||||
## 二、适配阿里云物模型脚本
|
||||
|
||||
|
||||
对应文档:[阿里云设备属性上报](https://help.aliyun.com/zh/iot/user-guide/data-formats?spm=a2c4g.11186623.0.i17#section-jrb-lrl-b2b)
|
||||
|
||||
|
||||
|
||||
### 变量脚本
|
||||
```
|
||||
|
||||
//一个适配阿里云IOT的变量脚本demo
|
||||
|
||||
|
||||
public class AliYunIotScript:IDynamicModel
|
||||
{
|
||||
public IEnumerable<dynamic> GetList(IEnumerable<object> datas)
|
||||
{
|
||||
List<AliYunIot> aliYunIots = new();
|
||||
// 对输入列表进行分组,根据 Remark1属性分组
|
||||
var groups = datas.Where(a => !string.IsNullOrEmpty(((VariableData)a).Remark1)).GroupBy(a => ((VariableData)a).Remark1,a=> ((VariableData)a));
|
||||
// 遍历每一个分组
|
||||
foreach (var item in groups)
|
||||
{
|
||||
var requestId = Yitter.IdGenerator.YitIdHelper.NextId();
|
||||
var iotId = item.Key; //Remark1自定义为设备Id
|
||||
var productKey = item.FirstOrDefault(a => !string.IsNullOrEmpty(a.Remark2))?.Remark2;//Remark2自定义为产品Id
|
||||
var deviceName = item.FirstOrDefault(a => !string.IsNullOrEmpty(a.Remark3))?.Remark3;//Remark3自定义为设备名称
|
||||
AliYunIot aliYunIot = new();
|
||||
aliYunIot.iotId = iotId;
|
||||
aliYunIot.requestId = requestId.ToString();
|
||||
aliYunIot.deviceName = deviceName;
|
||||
aliYunIot.productKey = productKey;
|
||||
// 遍历分组内的每一个元素
|
||||
foreach (var varItem in item)
|
||||
{
|
||||
|
||||
// 设置采集时间,并转换为 Unix 时间戳
|
||||
// 设置值
|
||||
var data = new Property() { value = varItem.Value, time = new DateTimeOffset(varItem.CollectTime).ToUnixTimeSeconds() };
|
||||
// 以 变量名称 作为键,将新对象添加到分组的 属性 中
|
||||
aliYunIot.items.Add(varItem.Name, data);
|
||||
|
||||
}
|
||||
aliYunIots.Add(aliYunIot);
|
||||
}
|
||||
return aliYunIots;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
public class AliYunIot
|
||||
{
|
||||
public string iotId { get; set; }
|
||||
public string requestId { get; set; }
|
||||
public string productKey { get; set; }
|
||||
public string deviceName { get; set; }
|
||||
public Dictionary<string, Property> items { get; set; } = new();
|
||||
}
|
||||
|
||||
public class Property
|
||||
{
|
||||
public object value { get; set; }
|
||||
public long time { get; set; }
|
||||
}
|
||||
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
### 传输主题
|
||||
|
||||
变量Topic 填入 `/${productKey}/${deviceName}/thing/event/property/post`
|
@@ -1,38 +0,0 @@
|
||||
---
|
||||
id: 601
|
||||
title: 采集插件开发
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
## 说明
|
||||
|
||||
ThingsGateway封装了丰富的协议解析方法,方便开发多种PLC通讯插件
|
||||
下面我们以Omron FinsTcp/Udp为例,讲解如何基于ThingsGateway开发一个**通用驱动**以及ThingsGateway插件
|
||||
|
||||
## 一、协议解析
|
||||
|
||||
`Fins` 协议是OSI模型第7层上的应用层报文传输协议,我们画一个简单的应用层协议报文解析图
|
||||
|
||||
| Fins over TCP | Fins over UDP |
|
||||
| ---------------| --------------------------|
|
||||
| FinsTCP Header | None |
|
||||
| FinsUDP Header | FinsUDP Header |
|
||||
| Command Data |Command Data |
|
||||
|
||||
|
||||
可以看出,基于Tcp的Fins和基于Udp的Fins协议,差别只是Tcp连接时会加一个FinsTcp报文头。
|
||||
下面我们进行每个部分的说明
|
||||
|
||||
|
||||
### 1、FinsTCP Header
|
||||
|
||||
FinsTcp头部固定为16个字节
|
||||
|
||||
| FinsTCP Header | 说明 |
|
||||
| ---------------| --------------------------|
|
||||
| Magic | 固定0x46494E53,也就是FINS字符串的ASCII码 |
|
||||
| Length | 后续全部字节的长度 |
|
||||
| Command | 0是客户端请求握手,1是服务端返回握手信息,除0,1外是其他方法 |
|
@@ -1,9 +0,0 @@
|
||||
---
|
||||
id: 602
|
||||
title: 业务插件开发
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
@@ -1,80 +0,0 @@
|
||||
---
|
||||
id: upgrade
|
||||
title: 更新日志
|
||||
---
|
||||
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import Tag from "@site/src/components/Tag.js";
|
||||
import Highlight from '@site/src/components/Highlight.js';
|
||||
|
||||
|
||||
|
||||
|
||||
## v5.0.0.1
|
||||
> 2024-1-21
|
||||
|
||||
**更新描述:**
|
||||
|
||||
此版本是大版本更新。可能会产生很多不兼容部分,所以升级之前请做好备份。
|
||||
|
||||
如果需要从5.0前升级,请按以下操作进行
|
||||
|
||||
1、导出旧版本的excel配置文件,包括采集设备、上传设备、变量等
|
||||
|
||||
2、5.0框架中,只建立一个对应插件的设备/变量,这一步是因为插件是按需导出的,需要建立对应插件,才会导出相应的sheet,建好后导出excel
|
||||
|
||||
3、参照5.0版本的excel内容,把旧版本的配置内容移到新版本excel文件中
|
||||
|
||||
4、导入已修改好的5.0版本excel配置文件
|
||||
|
||||
**更新详情:**
|
||||
|
||||
- <Tag>调整</Tag> 重构采集驱动底层,网关缓存
|
||||
- <Tag>调整</Tag> 重构网关权限管理框架
|
||||
- <Tag>调整</Tag> 重构网关线程管理器
|
||||
- <Tag>调整</Tag> 重构网关断线续传功能
|
||||
- <Tag>调整</Tag> 重构脚本支持,方便对应各大云平台的iot格式
|
||||
- <Tag>调整</Tag> 调整网关UI外观风格
|
||||
|
||||
|
||||
|
||||
## v3.0.0.25
|
||||
|
||||
- <Tag>调整</Tag> 删除S7插件中的DstTSAP属性,用插槽号与机架号代替,更直观
|
||||
- <Tag>调整</Tag> OPCUAServer插件 url属性支持多个url,以逗号分割
|
||||
|
||||
## v3.0.0.19
|
||||
|
||||
- <Tag>新增</Tag> 添加TDengineDB时序库上传插件
|
||||
- <Tag>新增</Tag> 添加QuestDB时序库上传插件
|
||||
- <Tag>新增</Tag> 添加DLT645采集插件
|
||||
- <Tag>新增</Tag> 添加调试软件
|
||||
|
||||
|
||||
## v1.7.0
|
||||
|
||||
- <Tag>优化</Tag> OPCUAClient支持动态类型
|
||||
|
||||
|
||||
## v1.2.0
|
||||
|
||||
- <Tag>新增</Tag> 添加OPCUAServer插件
|
||||
|
||||
##
|
||||
|
||||
## v1.1.0
|
||||
|
||||
- <Tag>新增</Tag> 添加OPCDAClient采集插件
|
||||
|
||||
- <Tag>新增</Tag> 添加OPCUAClient采集插件
|
||||
|
||||
- <Tag>新增</Tag> 串口基础框架
|
||||
|
||||
##
|
||||
|
||||
## v1.0.0
|
||||
|
||||
- <Tag>新增</Tag> 初始发布
|
||||
|
||||
|
||||
##
|
@@ -1,165 +0,0 @@
|
||||
|
||||
module.exports = {
|
||||
title: "thingsgateway",
|
||||
tagline: "物联网",
|
||||
url: "https://kimdiego2098.github.io",
|
||||
baseUrl: "/",
|
||||
onBrokenLinks: "throw",
|
||||
onBrokenMarkdownLinks: "throw",
|
||||
favicon: "img/favicon.ico",
|
||||
projectName: "ThingsGateway",
|
||||
scripts: [],
|
||||
themeConfig: {
|
||||
zoom: {
|
||||
selector:
|
||||
".markdown :not(em) > img,.markdown > img, article img[loading]",
|
||||
background: {
|
||||
light: "rgb(255, 255, 255)",
|
||||
dark: "rgb(50, 50, 50)",
|
||||
},
|
||||
// options you can specify via https://github.com/francoischalifour/medium-zoom#usage
|
||||
config: {},
|
||||
},
|
||||
docs: {
|
||||
sidebar: {
|
||||
hideable: true,
|
||||
autoCollapseCategories: true,
|
||||
},
|
||||
},
|
||||
prism: {
|
||||
additionalLanguages: ["powershell", "csharp", "sql"],
|
||||
},
|
||||
navbar: {
|
||||
title: "ThingsGateway",
|
||||
logo: {
|
||||
alt: "ThingsGateway Logo",
|
||||
src: "img/ThingsGatewayLogo.png",
|
||||
},
|
||||
hideOnScroll: true,
|
||||
items: [
|
||||
{
|
||||
label: "更新日志",
|
||||
position: "left",
|
||||
to: "docs/upgrade"
|
||||
},
|
||||
{
|
||||
label: "演示",
|
||||
position: "right",
|
||||
href: "http://47.119.161.158:5000",
|
||||
},
|
||||
{
|
||||
label: "源码",
|
||||
position: "right",
|
||||
items: [
|
||||
{
|
||||
label: "Gitee(主库)",
|
||||
href: "https://gitee.com/diego2098/ThingsGateway",
|
||||
},
|
||||
{
|
||||
label: "GitHub",
|
||||
href: "https://github.com/kimdiego2098/ThingsGateway",
|
||||
},
|
||||
{
|
||||
label: "Nuget",
|
||||
href: "https://www.nuget.org/profiles/kimdiego",
|
||||
},
|
||||
],
|
||||
},
|
||||
// {
|
||||
// label: "博客",
|
||||
// position: "right",
|
||||
// href: "https://www.cnblogs.com/ThingsGateway/collections/1104",
|
||||
// },
|
||||
{
|
||||
label: "视频",
|
||||
position: "right",
|
||||
href: "https://space.bilibili.com/88105259/channel/series",
|
||||
},
|
||||
{
|
||||
label: "社区",
|
||||
position: "right",
|
||||
href: "https://gitee.com/dotnetchina",
|
||||
},
|
||||
],
|
||||
},
|
||||
footer: {
|
||||
style: "dark",
|
||||
links: [
|
||||
{
|
||||
title: "文档",
|
||||
items: [
|
||||
{
|
||||
label: "入门",
|
||||
to: "docs",
|
||||
},
|
||||
{
|
||||
label: "手册",
|
||||
to: "docs",
|
||||
},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "社区",
|
||||
items: [
|
||||
{
|
||||
label: "讨论",
|
||||
href: "https://gitee.com/diego2098/ThingsGateway/issues",
|
||||
},
|
||||
{
|
||||
label: "看板",
|
||||
href: "https://gitee.com/diego2098/ThingsGateway/board",
|
||||
},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "更多",
|
||||
items: [
|
||||
{
|
||||
label: "仓库",
|
||||
href: "https://gitee.com/diego2098/ThingsGateway",
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
copyright: `Copyright © 2020-${new Date().getFullYear()} Diego.`,
|
||||
},
|
||||
},
|
||||
presets: [
|
||||
[
|
||||
"@docusaurus/preset-classic",
|
||||
{
|
||||
docs: {
|
||||
sidebarPath: require.resolve("./sidebars.js"),
|
||||
editUrl:
|
||||
"https://gitee.com/diego2098/ThingsGateway/tree/master/doc/",
|
||||
showLastUpdateTime: true,
|
||||
showLastUpdateAuthor: true,
|
||||
sidebarCollapsible: true,
|
||||
sidebarCollapsed: true,
|
||||
|
||||
// sidebarCollapsible: true,
|
||||
},
|
||||
// blog: {
|
||||
// showReadingTime: true,
|
||||
// editUrl:
|
||||
// "https://gitee.com/diego2098/ThingsGateway/tree/master/doc/",
|
||||
// },
|
||||
theme: {
|
||||
customCss: require.resolve("./src/css/custom.css"),
|
||||
},
|
||||
},
|
||||
],
|
||||
],
|
||||
plugins: [require.resolve("docusaurus-plugin-image-zoom")],
|
||||
themes: [
|
||||
[
|
||||
"@easyops-cn/docusaurus-search-local",
|
||||
{
|
||||
hashed: true,
|
||||
language: ["zh","en"],
|
||||
highlightSearchTermsOnTargetPage: true,
|
||||
explicitSearchResultPath: true,
|
||||
},
|
||||
],
|
||||
],
|
||||
};
|
@@ -1,8 +0,0 @@
|
||||
{
|
||||
"symbol_url": "//at.alicdn.com/t/c/font_3276321_js2bwtaq9jc.js",
|
||||
"use_typescript": false,
|
||||
"save_dir": "./src/components/iconfonts",
|
||||
"trim_icon_prefix": "icon",
|
||||
"unit": "px",
|
||||
"default_icon_size": 18
|
||||
}
|
22684
doc/package-lock.json
generated
22684
doc/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -1,50 +0,0 @@
|
||||
{
|
||||
"name": "thingsgateway",
|
||||
"version": "v6.0",
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"docusaurus": "docusaurus",
|
||||
"start": "docusaurus start",
|
||||
"build": "docusaurus build",
|
||||
"swizzle": "docusaurus swizzle",
|
||||
"deploy": "docusaurus deploy",
|
||||
"clear": "docusaurus clear",
|
||||
"serve": "docusaurus serve",
|
||||
"write-translations": "docusaurus write-translations",
|
||||
"write-heading-ids": "docusaurus write-heading-ids"
|
||||
},
|
||||
"dependencies": {
|
||||
"@docusaurus/core": "^2.4.3",
|
||||
"@docusaurus/preset-classic": "^2.4.3",
|
||||
"@easyops-cn/docusaurus-search-local": "^0.33.5",
|
||||
"@mdx-js/react": "^1.6.22",
|
||||
"@svgr/webpack": "^6.5.1",
|
||||
"animate.css": "^4.1.1",
|
||||
"clsx": "^1.2.1",
|
||||
"docusaurus-plugin-image-zoom": "^0.1.1",
|
||||
"file-loader": "^6.2.0",
|
||||
"prism-react-renderer": "^1.3.5",
|
||||
"react": "^17.0.2",
|
||||
"react-dom": "^17.0.2",
|
||||
"url-loader": "^4.1.1"
|
||||
},
|
||||
"browserslist": {
|
||||
"production": [
|
||||
">0.5%",
|
||||
"not dead",
|
||||
"not op_mini all"
|
||||
],
|
||||
"development": [
|
||||
"last 1 chrome version",
|
||||
"last 1 firefox version",
|
||||
"last 1 safari version"
|
||||
]
|
||||
},
|
||||
"devDependencies": {
|
||||
"@docusaurus/module-type-aliases": "^2.4.3",
|
||||
"react-iconfont-cli": "^2.0.2"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=16.14"
|
||||
}
|
||||
}
|
315
doc/sidebars.js
315
doc/sidebars.js
@@ -1,315 +0,0 @@
|
||||
module.exports = {
|
||||
docs: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "upgrade",
|
||||
label: "更新日志"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "1",
|
||||
label: "版权说明"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "2",
|
||||
label: "产品介绍"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "3",
|
||||
label: "入门指南"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "100",
|
||||
label: "驱动调试"
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "基础手册",
|
||||
items: [
|
||||
{
|
||||
type: "category",
|
||||
label: "网关配置",
|
||||
items: [
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "101",
|
||||
label: "插件管理"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "102",
|
||||
label: "通道管理"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "103",
|
||||
label: "设备"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "104",
|
||||
label: "变量"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "105",
|
||||
label: "网关状态查看"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "106",
|
||||
label: "网关日志"
|
||||
},
|
||||
]
|
||||
},
|
||||
|
||||
{
|
||||
type: "category",
|
||||
label: "采集插件手册",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "200",
|
||||
label: "ModbusMaster"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "202",
|
||||
label: "Dlt645Master"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "203",
|
||||
label: "SiemensS7Master"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "204",
|
||||
label: "OpcDaMaster"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "205",
|
||||
label: "OpcUaMaster"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "206",
|
||||
label: "VariableExpression"
|
||||
}
|
||||
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "业务插件手册",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "201",
|
||||
label: "ModbusSlave"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "301",
|
||||
label: "MqttClient"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "302",
|
||||
label: "MqttServer"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "303",
|
||||
label: "RabbitMQProducer"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "304",
|
||||
label: "KafkaProducer"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "305",
|
||||
label: "TDengineDBProducer"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "306",
|
||||
label: "QuestDBProducer"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "307",
|
||||
label: "SqlDBProducer"
|
||||
},
|
||||
|
||||
{
|
||||
type: "doc",
|
||||
id: "308",
|
||||
label: "SqlHisAlarm"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "309",
|
||||
label: "OpcUaServer"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "Pro插件手册",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "10001",
|
||||
label: "ABCipMatser"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "部署",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "400",
|
||||
label: "编译发布"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "401",
|
||||
label: "windows服务部署"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "402",
|
||||
label: "iis部署"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "403",
|
||||
label: "docker部署"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "404",
|
||||
label: "linux服务部署"
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "常见问题",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "501",
|
||||
label: "常见问题"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "502",
|
||||
label: "脚本常见问题"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "插件开发",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "601",
|
||||
label: "采集插件"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "602",
|
||||
label: "业务插件"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "nuget包文档",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "20001",
|
||||
label: "Modbus"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "20002",
|
||||
label: "SiemensS7"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "20003",
|
||||
label: "OpcDa"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "20004",
|
||||
label: "OpcUa"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "20005",
|
||||
label: "Dlt645"
|
||||
},
|
||||
]
|
||||
},
|
||||
|
||||
{
|
||||
type: "category",
|
||||
label: "协议开发教程",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
label: "基础知识",
|
||||
id: "30001",
|
||||
|
||||
}
|
||||
]
|
||||
},
|
||||
|
||||
{
|
||||
type: "category",
|
||||
label: "技术支持/合作",
|
||||
items: [
|
||||
{
|
||||
type: "doc",
|
||||
id: "1002",
|
||||
label: "联系我们"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "1000",
|
||||
label: "赞助项目"
|
||||
},
|
||||
{
|
||||
type: "doc",
|
||||
id: "1001",
|
||||
label: "Pro版"
|
||||
},
|
||||
]
|
||||
},
|
||||
|
||||
]
|
||||
};
|
||||
|
@@ -1,15 +0,0 @@
|
||||
import React from 'react';
|
||||
|
||||
export default function Highlight({children, color}) {
|
||||
return (
|
||||
<span
|
||||
style={{
|
||||
backgroundColor: color,
|
||||
borderRadius: '2px',
|
||||
color: '#fff',
|
||||
padding: '0.2rem',
|
||||
}}>
|
||||
{children}
|
||||
</span>
|
||||
);
|
||||
}
|
@@ -1,70 +0,0 @@
|
||||
import React from "react";
|
||||
import IconFont from "./iconfonts";
|
||||
import classes from "./Tag.module.css";
|
||||
|
||||
export default function (props) {
|
||||
const { children } = props;
|
||||
const operates = {
|
||||
新增: {
|
||||
icon: "xinzeng",
|
||||
bgColor: "#39b54a",
|
||||
},
|
||||
修复: {
|
||||
icon: "bug",
|
||||
bgColor: "#9c26b0",
|
||||
},
|
||||
文档: {
|
||||
icon: "wendang",
|
||||
bgColor: "rgb(79, 147, 255)",
|
||||
},
|
||||
更新: {
|
||||
icon: "gengxin",
|
||||
bgColor: "#0081ff",
|
||||
},
|
||||
调整: {
|
||||
icon: "tiaozheng",
|
||||
bgColor: "#333",
|
||||
},
|
||||
升级: {
|
||||
icon: "shengji",
|
||||
bgColor: "#e03997",
|
||||
},
|
||||
移除: {
|
||||
icon: "shanchu",
|
||||
bgColor: "red",
|
||||
},
|
||||
答疑: {
|
||||
icon: "dayi",
|
||||
bgColor: "#bbb",
|
||||
},
|
||||
优化: {
|
||||
icon: "youhua",
|
||||
bgColor: "#38e550",
|
||||
},
|
||||
|
||||
推荐: {
|
||||
bgColor: "#38e550",
|
||||
},
|
||||
DEMO: {
|
||||
bgColor: "#38e550",
|
||||
},
|
||||
Pro版: {
|
||||
bgColor: "#23AAF2",
|
||||
}
|
||||
};
|
||||
return (
|
||||
<label
|
||||
className={classes.label}
|
||||
title={children}
|
||||
style={{ backgroundColor: operates[children].bgColor }}
|
||||
>
|
||||
<IconFont
|
||||
name={operates[children].icon}
|
||||
color="white"
|
||||
size={14}
|
||||
className={classes.icon}
|
||||
/>{" "}
|
||||
{children}
|
||||
</label>
|
||||
);
|
||||
}
|
@@ -1,17 +0,0 @@
|
||||
.label {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
color: #fff;
|
||||
padding: 4px 6px;
|
||||
font-size: 12px;
|
||||
color: #fff;
|
||||
border-radius: 3px;
|
||||
line-height: normal;
|
||||
margin-left: -3px;
|
||||
vertical-align: middle;
|
||||
margin-right: 6px;
|
||||
}
|
||||
|
||||
.icon {
|
||||
margin-right: 4px;
|
||||
}
|
12
doc/src/components/iconfonts/IconBug.d.ts
vendored
12
doc/src/components/iconfonts/IconBug.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconBug: FunctionComponent<Props>;
|
||||
|
||||
export default IconBug;
|
@@ -1,31 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconBug = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M940 512H792V412c76.8 0 139-62.2 139-139 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 34.8-28.2 63-63 63H232c-34.8 0-63-28.2-63-63 0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8 0 76.8 62.2 139 139 139v100H84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h148v96c0 6.5 0.2 13 0.7 19.3C164.1 728.6 116 796.7 116 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-44.2 23.9-82.9 59.6-103.7 6 17.2 13.6 33.6 22.7 49 24.3 41.5 59 76.2 100.5 100.5S460.5 960 512 960s99.8-13.9 141.3-38.2c41.5-24.3 76.2-59 100.5-100.5 9.1-15.5 16.7-31.9 22.7-49C812.1 793.1 836 831.8 836 876c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-79.3-48.1-147.4-116.7-176.7 0.4-6.4 0.7-12.8 0.7-19.3v-96h148c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8zM716 680c0 36.8-9.7 72-27.8 102.9-17.7 30.3-43 55.6-73.3 73.3-20.1 11.8-42 20-64.9 24.3V484c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v396.5c-22.9-4.3-44.8-12.5-64.9-24.3-30.3-17.7-55.6-43-73.3-73.3C317.7 752 308 716.8 308 680V412h408v268z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M304 280h56c4.4 0 8-3.6 8-8 0-28.3 5.9-53.2 17.1-73.5 10.6-19.4 26-34.8 45.4-45.4C450.9 142 475.7 136 504 136h16c28.3 0 53.2 5.9 73.5 17.1 19.4 10.6 34.8 26 45.4 45.4C650 218.9 656 243.7 656 272c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8 0-40-8.8-76.7-25.9-108.1-17.2-31.5-42.5-56.8-74-74C596.7 72.8 560 64 520 64h-16c-40 0-76.7 8.8-108.1 25.9-31.5 17.2-56.8 42.5-74 74C304.8 195.3 296 232 296 272c0 4.4 3.6 8 8 8z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconBug.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconBug;
|
12
doc/src/components/iconfonts/IconDayi.d.ts
vendored
12
doc/src/components/iconfonts/IconDayi.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconDayi: FunctionComponent<Props>;
|
||||
|
||||
export default IconDayi;
|
@@ -1,31 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconDayi = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M143.872 768a51.2 51.2 0 0 1-15.36-2.56 51.2 51.2 0 0 1-35.328-51.2V283.136a148.992 148.992 0 0 1 141.824-153.6h450.56a148.992 148.992 0 0 1 141.824 153.6V512a148.992 148.992 0 0 1-141.824 153.6H244.224l-60.928 80.896a51.2 51.2 0 0 1-39.424 21.504zM235.008 180.224a97.792 97.792 0 0 0-90.624 102.4v430.592L218.624 614.4h466.944a97.792 97.792 0 0 0 90.624-102.4V283.136a97.792 97.792 0 0 0-90.624-102.4z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M880.128 875.52a51.2 51.2 0 0 1-39.424-20.48l-60.928-80.896h-243.2a25.6 25.6 0 0 1 0-51.2h268.8l76.288 102.4v-295.936a25.6 25.6 0 0 1 25.6-25.6 25.6 25.6 0 0 1 25.6 25.6v293.888a51.2 51.2 0 0 1-51.2 51.2z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconDayi.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconDayi;
|
12
doc/src/components/iconfonts/IconDown.d.ts
vendored
12
doc/src/components/iconfonts/IconDown.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconDown: FunctionComponent<Props>;
|
||||
|
||||
export default IconDown;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconDown = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M942.4615936 284.62787926c-14.30911886-14.12709945-37.31996786-14.05468217-51.48229632 0.21920654L517.97142983 661.27810333 139.75544149 286.45003606c-14.30911886-14.16232846-37.31996786-14.05468217-51.51948344 0.21920654-14.16232846 14.30911886-14.05468217 37.35519687 0.21920654 51.51948345l401.99014627 398.34974663c0.61847666 0.61847666 1.41897273 0.76526706 2.03940637 1.34655658 0.14483342 0.14483342 0.18201941 0.32685283 0.32685283 0.47364324 7.09877874 7.02636259 16.38375538 10.55911595 25.63154489 10.55911595 9.35739278 0 18.75001458-3.60516949 25.85075143-10.77636551l398.34974663-401.99014628C956.84312974 321.8382427 956.73548345 298.7921647 942.4615936 284.62787926z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconDown.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconDown;
|
12
doc/src/components/iconfonts/IconFuwu.d.ts
vendored
12
doc/src/components/iconfonts/IconFuwu.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconFuwu: FunctionComponent<Props>;
|
||||
|
||||
export default IconFuwu;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconFuwu = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M384 896h-64v-70.4c0-15.2-10.4-28-24.8-31.2C159.2 768 64 644.8 64 496v-32h64v32c0 118.4 73.6 215.2 179.2 236 44.8 8.8 76.8 48 76.8 94.4v69.6zM704 896h-64v-70.4c0-45.6 32-85.6 76.8-94.4C822.4 711.2 896 614.4 896 496v-32h64v32c0 148.8-95.2 272-231.2 298.4-14.4 3.2-24.8 16-24.8 31.2v70.4zM512.8 640l-41.6-37.6c-147.2-133.6-244-208-244-316.8 0-88 68.8-156.8 156.8-156.8 49.6 0 97.6 23.2 128.8 60C544 152 592 128.8 641.6 128.8c88 0 156.8 68.8 156.8 156.8 0 108-96.8 183.2-244 316.8L512.8 640z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconFuwu.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconFuwu;
|
12
doc/src/components/iconfonts/IconGengxin.d.ts
vendored
12
doc/src/components/iconfonts/IconGengxin.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconGengxin: FunctionComponent<Props>;
|
||||
|
||||
export default IconGengxin;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconGengxin = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1172 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M870.0416 250.4704a38.4 38.4 0 0 0-8.96 53.5552c13.056 18.2784 24.4224 37.8368 33.7408 58.112a38.4512 38.4512 0 0 0 50.944 18.8928 38.4512 38.4512 0 0 0 18.8416-50.944 436.0192 436.0192 0 0 0-40.96-70.6048 38.3488 38.3488 0 0 0-53.6064-9.0112zM181.4528 566.016a35.9936 35.9936 0 0 0 25.5488-10.5984L351.7952 410.624a36.096 36.096 0 1 0-51.0976-51.0976L217.6 442.5728C250.0096 278.1184 395.264 153.6 569.1392 153.6c50.7904 0 99.8912 10.3936 145.92 30.9248a38.4 38.4 0 1 0 31.232-70.0928 431.36 431.36 0 0 0-177.152-37.632c-214.6816 0-393.1136 156.416-428.4416 361.216L62.1568 359.4752a36.1984 36.1984 0 0 0-51.0976 51.0976l144.8448 144.7936a36.0448 36.0448 0 0 0 25.5488 10.6496zM978.5344 463.104a36.1984 36.1984 0 0 0-51.0976 0l-144.8448 144.7936a36.096 36.096 0 1 0 51.0976 51.0976l88.6272-88.576C894.3104 740.2496 746.8032 870.4 569.1392 870.4a357.7856 357.7856 0 0 1-325.2736-207.7184 38.4 38.4 0 1 0-69.7344 32.3072 434.3808 434.3808 0 0 0 394.9568 252.2112c215.1936 0 393.984-157.184 428.6464-362.7008l74.496 74.496a35.9936 35.9936 0 0 0 51.0976 0 36.096 36.096 0 0 0 0-51.0976l-144.7936-144.7936z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconGengxin.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconGengxin;
|
12
doc/src/components/iconfonts/IconShanchu.d.ts
vendored
12
doc/src/components/iconfonts/IconShanchu.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconShanchu: FunctionComponent<Props>;
|
||||
|
||||
export default IconShanchu;
|
@@ -1,31 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconShanchu = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M512 883.2A371.2 371.2 0 1 0 140.8 512 371.2 371.2 0 0 0 512 883.2z m0 64a435.2 435.2 0 1 1 435.2-435.2 435.2 435.2 0 0 1-435.2 435.2z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M557.056 512l122.368 122.368a31.744 31.744 0 1 1-45.056 45.056L512 557.056l-122.368 122.368a31.744 31.744 0 1 1-45.056-45.056L466.944 512 344.576 389.632a31.744 31.744 0 1 1 45.056-45.056L512 466.944l122.368-122.368a31.744 31.744 0 1 1 45.056 45.056z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconShanchu.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconShanchu;
|
12
doc/src/components/iconfonts/IconShengji.d.ts
vendored
12
doc/src/components/iconfonts/IconShengji.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconShengji: FunctionComponent<Props>;
|
||||
|
||||
export default IconShengji;
|
@@ -1,35 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconShengji = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M223.425605 449.2744l161.632237 0 0 253.65714c0 16.954137 13.745049 30.699186 30.699186 30.699186 16.95516 0 30.699186-13.745049 30.699186-30.699186l0-284.356326c0-16.95516-13.744026-30.699186-30.699186-30.699186L291.035446 387.876028l217.23665-248.51605L733.039255 387.580293 607.104031 387.580293c-16.954137 0-30.699186 13.745049-30.699186 30.699186l0 284.652062c0 16.954137 13.745049 30.699186 30.699186 30.699186s30.699186-13.745049 30.699186-30.699186L637.803217 448.978664l164.448376 0c12.140505 0 23.140023-7.154957 28.063149-18.251689 4.922103-11.097756 2.841721-24.053835-5.307889-33.05279L530.62315 72.570829c-5.881964-6.495948-14.273075-10.134825-23.024389-10.091846-8.763594 0.076748-17.076934 3.895727-22.844288 10.494005L200.312188 398.371056c-7.92653 9.067516-9.818623 21.931498-4.839215 32.896224S211.383338 449.2744 223.425605 449.2744z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M222.354204 829.113381l581.732178 0c16.954137 0 30.699186-13.745049 30.699186-30.699186s-13.745049-30.699186-30.699186-30.699186L222.354204 767.715009c-16.954137 0-30.699186 13.745049-30.699186 30.699186S205.400067 829.113381 222.354204 829.113381z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M804.086381 896.729361 222.354204 896.729361c-16.954137 0-30.699186 13.745049-30.699186 30.699186s13.745049 30.699186 30.699186 30.699186l581.732178 0c16.954137 0 30.699186-13.745049 30.699186-30.699186S821.041542 896.729361 804.086381 896.729361z"
|
||||
fill={getIconColor(color, 2, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconShengji.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconShengji;
|
12
doc/src/components/iconfonts/IconTiaozheng.d.ts
vendored
12
doc/src/components/iconfonts/IconTiaozheng.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconTiaozheng: FunctionComponent<Props>;
|
||||
|
||||
export default IconTiaozheng;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconTiaozheng = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M380.15463648 874.54223633c0 18.12744166-14.83154297 32.95898463-32.95898463 32.95898463s-32.95898463-14.83154297-32.95898462-32.95898463V228.9152832L172.71078883 370.86962865a33.04467773 33.04467773 0 0 1-46.60400416 0 33.04467773 33.04467773 0 0 1 0-46.6040034l197.55615234-198.14941406A32.76782227 32.76782227 0 0 1 347.0967749 116.52514674c0.03295924 0 0.06591772-0.03295924 0.09887695-0.03295924 1.54907201 0 2.90039088 0.69213867 4.41650366 0.88989258 2.66967773 0.39550781 5.40527318 0.59326172 7.94311548 1.61499049 12.03002904 4.94384766 20.59936549 16.71020508 20.59936549 30.45410156v725.0910642z m320.15698192 23.34155248a32.85351537 32.85351537 0 0 1-23.43383789 9.59106445c-0.03295924 0-0.06591772 0.03295924-0.09887696 0.03295924-1.54907201 0-2.90039088-0.69213867-4.41650365-0.92285182-2.70263697-0.36254857-5.40527318-0.56030248-7.94311549-1.61498972-12.03002904-4.91088842-20.59936549-16.67724584-20.59936473-30.42114309V149.45776367c0-18.12744166 14.83154297-32.95898463 32.95898387-32.95898463s32.95898463 14.83154297 32.95898463 32.95898463v645.60058619l141.52587916-141.92138697c12.81445313-12.82104467 33.81591797-12.82104467 46.63037109 0 12.78808619 12.81445313 12.78808619 33.77636719 0 46.60400416L700.3116184 897.88378881z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconTiaozheng.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconTiaozheng;
|
12
doc/src/components/iconfonts/IconUp.d.ts
vendored
12
doc/src/components/iconfonts/IconUp.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconUp: FunctionComponent<Props>;
|
||||
|
||||
export default IconUp;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconUp = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M81.5384064 739.37212074c14.30911886 14.12709945 37.31996786 14.05468217 51.48229632-0.21920654L506.02857017 362.72189667 884.24455851 737.54996394c14.30911886 14.16232846 37.31996786 14.05468217 51.51948344-0.21920654 14.16232846-14.30911886 14.05468217-37.35519687-0.21920654-51.51948345l-401.99014627-398.34974663c-0.61847666-0.61847666-1.41897273-0.76526706-2.03940637-1.34655658-0.14483342-0.14483342-0.18201941-0.32685283-0.32685282-0.47364324-7.09877874-7.02636259-16.38375538-10.55911595-25.6315449-10.55911595-9.35739278 0-18.75001458 3.60516949-25.85075143 10.77636551l-398.34974663 401.99014628C67.15687026 702.1617573 67.26451655 725.2078353 81.5384064 739.37212074z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconUp.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconUp;
|
12
doc/src/components/iconfonts/IconWendang.d.ts
vendored
12
doc/src/components/iconfonts/IconWendang.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconWendang: FunctionComponent<Props>;
|
||||
|
||||
export default IconWendang;
|
@@ -1,35 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconWendang = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M302 332a30 30 0 1 1 0-60h420a30 30 0 0 1 0 60H302zM302 542a30 30 0 0 1 0-60h420a30 30 0 0 1 0 60H302zM302 752a30 30 0 0 1 0-60h120a30 30 0 0 1 0 60H302z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M789.47 784.1a30 30 0 0 1 39.36 45.3l-144.24 125.25a30 30 0 0 1-19.68 7.35H214.85C163.4 962 122 919.46 122 867.38V156.62C122 104.54 163.4 62 214.85 62h594.3C860.6 62 902 104.54 902 156.62v529.05a30 30 0 1 1-60 0V156.62C842 137.3 827.09 122 809.15 122H214.85C196.91 122 182 137.3 182 156.62v710.76C182 886.7 196.91 902 214.85 902h438.84l135.78-117.9z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M692 931.19a30 30 0 1 1-60 0v-174.6C632 704.57 673.4 662 724.85 662h147.78a30 30 0 0 1 0 60h-147.78c-17.94 0-32.85 15.3-32.85 34.62v174.6z"
|
||||
fill={getIconColor(color, 2, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconWendang.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconWendang;
|
12
doc/src/components/iconfonts/IconXinzeng.d.ts
vendored
12
doc/src/components/iconfonts/IconXinzeng.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconXinzeng: FunctionComponent<Props>;
|
||||
|
||||
export default IconXinzeng;
|
@@ -1,31 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconXinzeng = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M512 71.68c-242.688 0-440.32 197.632-440.32 440.32s197.632 440.32 440.32 440.32 440.32-197.632 440.32-440.32-197.632-440.32-440.32-440.32z m0 819.2c-208.896 0-378.88-169.984-378.88-378.88s169.984-378.88 378.88-378.88 378.88 169.984 378.88 378.88-169.984 378.88-378.88 378.88z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
<path
|
||||
d="M542.72 261.12H481.28v220.16H261.12v61.44h220.16v220.16h61.44v-220.16h220.16V481.28h-220.16z"
|
||||
fill={getIconColor(color, 1, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconXinzeng.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconXinzeng;
|
12
doc/src/components/iconfonts/IconYouhua.d.ts
vendored
12
doc/src/components/iconfonts/IconYouhua.d.ts
vendored
@@ -1,12 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconYouhua: FunctionComponent<Props>;
|
||||
|
||||
export default IconYouhua;
|
@@ -1,27 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import { getIconColor } from './helper';
|
||||
|
||||
const DEFAULT_STYLE = {
|
||||
display: 'block',
|
||||
};
|
||||
|
||||
const IconYouhua = ({ size, color, style: _style, ...rest }) => {
|
||||
const style = _style ? { ...DEFAULT_STYLE, ..._style } : DEFAULT_STYLE;
|
||||
|
||||
return (
|
||||
<svg viewBox="0 0 1024 1024" width={size + 'px'} height={size + 'px'} style={style} {...rest}>
|
||||
<path
|
||||
d="M856.4 292.8c-63.3-63.6-126.6-127.1-190.2-190.3-15.3-15.2-32.7-16.1-48.1-0.8-64.3 63.6-128.1 127.6-191.8 191.9-14 14.2-16.3 31.6-1.7 46 14.8 14.7 31.5 10.6 46.1-2.7 5.1-4.6 9.8-9.7 14.7-14.7 39.2-39.7 78.5-79.5 122.8-124.4 0 170 3 332.2-1.1 494-2.4 96.4-91.2 174.6-187.4 176.6-110.6 2.3-198.6-84.4-199-197.4-0.6-136.3-0.2-272.6-0.1-408.9 0-21.8-7.9-37.4-31.2-39.9-18.9-2-33.2 13.2-33.1 37.5 0 145.8-3.4 291.7 2.4 437.2 6 152.1 160.4 263.5 309.5 230.5C591.8 900 672.8 797.2 673.6 664.6c0.8-144 0.2-288.1 0.2-432.1v-33.3c11.2 10.2 17.6 15.4 23.3 21.3 38.5 38.4 76.7 77 115.3 115.2 14.8 14.6 32.2 19.2 47.8 2.9 13.8-14.8 10.3-31.7-3.8-45.8z"
|
||||
fill={getIconColor(color, 0, '#333333')}
|
||||
/>
|
||||
</svg>
|
||||
);
|
||||
};
|
||||
|
||||
IconYouhua.defaultProps = {
|
||||
size: 18,
|
||||
};
|
||||
|
||||
export default IconYouhua;
|
3
doc/src/components/iconfonts/helper.d.ts
vendored
3
doc/src/components/iconfonts/helper.d.ts
vendored
@@ -1,3 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
export declare const getIconColor: (color: string | string[] | undefined, index: number, defaultColor: string) => string;
|
@@ -1,17 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
/**
|
||||
* @param {string | string[] | undefined} color
|
||||
* @param {number} index
|
||||
* @param {string} defaultColor
|
||||
* @return {string}
|
||||
*/
|
||||
export const getIconColor = (color, index, defaultColor) => {
|
||||
return color
|
||||
? (
|
||||
typeof color === 'string'
|
||||
? color
|
||||
: color[index] || defaultColor
|
||||
)
|
||||
: defaultColor;
|
||||
};
|
25
doc/src/components/iconfonts/index.d.ts
vendored
25
doc/src/components/iconfonts/index.d.ts
vendored
@@ -1,25 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import { SVGAttributes, FunctionComponent } from 'react';
|
||||
export { default as IconYouhua } from './IconYouhua';
|
||||
export { default as IconDayi } from './IconDayi';
|
||||
export { default as IconShengji } from './IconShengji';
|
||||
export { default as IconTiaozheng } from './IconTiaozheng';
|
||||
export { default as IconGengxin } from './IconGengxin';
|
||||
export { default as IconWendang } from './IconWendang';
|
||||
export { default as IconShanchu } from './IconShanchu';
|
||||
export { default as IconBug } from './IconBug';
|
||||
export { default as IconXinzeng } from './IconXinzeng';
|
||||
export { default as IconFuwu } from './IconFuwu';
|
||||
export { default as IconDown } from './IconDown';
|
||||
export { default as IconUp } from './IconUp';
|
||||
|
||||
interface Props extends Omit<SVGAttributes<SVGElement>, 'color'> {
|
||||
name: 'youhua' | 'dayi' | 'shengji' | 'tiaozheng' | 'gengxin' | 'wendang' | 'shanchu' | 'bug' | 'xinzeng' | 'fuwu' | 'down' | 'up';
|
||||
size?: number;
|
||||
color?: string | string[];
|
||||
}
|
||||
|
||||
declare const IconFont: FunctionComponent<Props>;
|
||||
|
||||
export default IconFont;
|
@@ -1,61 +0,0 @@
|
||||
/* eslint-disable */
|
||||
|
||||
import React from 'react';
|
||||
import IconYouhua from './IconYouhua';
|
||||
import IconDayi from './IconDayi';
|
||||
import IconShengji from './IconShengji';
|
||||
import IconTiaozheng from './IconTiaozheng';
|
||||
import IconGengxin from './IconGengxin';
|
||||
import IconWendang from './IconWendang';
|
||||
import IconShanchu from './IconShanchu';
|
||||
import IconBug from './IconBug';
|
||||
import IconXinzeng from './IconXinzeng';
|
||||
import IconFuwu from './IconFuwu';
|
||||
import IconDown from './IconDown';
|
||||
import IconUp from './IconUp';
|
||||
export { default as IconYouhua } from './IconYouhua';
|
||||
export { default as IconDayi } from './IconDayi';
|
||||
export { default as IconShengji } from './IconShengji';
|
||||
export { default as IconTiaozheng } from './IconTiaozheng';
|
||||
export { default as IconGengxin } from './IconGengxin';
|
||||
export { default as IconWendang } from './IconWendang';
|
||||
export { default as IconShanchu } from './IconShanchu';
|
||||
export { default as IconBug } from './IconBug';
|
||||
export { default as IconXinzeng } from './IconXinzeng';
|
||||
export { default as IconFuwu } from './IconFuwu';
|
||||
export { default as IconDown } from './IconDown';
|
||||
export { default as IconUp } from './IconUp';
|
||||
|
||||
const IconFont = ({ name, ...rest }) => {
|
||||
switch (name) {
|
||||
case 'youhua':
|
||||
return <IconYouhua {...rest} />;
|
||||
case 'dayi':
|
||||
return <IconDayi {...rest} />;
|
||||
case 'shengji':
|
||||
return <IconShengji {...rest} />;
|
||||
case 'tiaozheng':
|
||||
return <IconTiaozheng {...rest} />;
|
||||
case 'gengxin':
|
||||
return <IconGengxin {...rest} />;
|
||||
case 'wendang':
|
||||
return <IconWendang {...rest} />;
|
||||
case 'shanchu':
|
||||
return <IconShanchu {...rest} />;
|
||||
case 'bug':
|
||||
return <IconBug {...rest} />;
|
||||
case 'xinzeng':
|
||||
return <IconXinzeng {...rest} />;
|
||||
case 'fuwu':
|
||||
return <IconFuwu {...rest} />;
|
||||
case 'down':
|
||||
return <IconDown {...rest} />;
|
||||
case 'up':
|
||||
return <IconUp {...rest} />;
|
||||
|
||||
}
|
||||
|
||||
return null;
|
||||
};
|
||||
|
||||
export default IconFont;
|
@@ -1,25 +0,0 @@
|
||||
/* stylelint-disable docusaurus/copyright-header */
|
||||
/**
|
||||
* Any CSS included here will be global. The classic template
|
||||
* bundles Infima by default. Infima is a CSS framework designed to
|
||||
* work well for content-centric websites.
|
||||
*/
|
||||
|
||||
/* You can override the default Infima variables here. */
|
||||
:root {
|
||||
--ifm-color-primary: #25c2a0;
|
||||
--ifm-color-primary-dark: rgb(33, 175, 144);
|
||||
--ifm-color-primary-darker: rgb(31, 165, 136);
|
||||
--ifm-color-primary-darkest: rgb(26, 136, 112);
|
||||
--ifm-color-primary-light: rgb(70, 203, 174);
|
||||
--ifm-color-primary-lighter: rgb(102, 212, 189);
|
||||
--ifm-color-primary-lightest: rgb(146, 224, 208);
|
||||
--ifm-code-font-size: 95%;
|
||||
}
|
||||
|
||||
.docusaurus-highlight-code-line {
|
||||
background-color: rgb(72, 77, 91);
|
||||
display: block;
|
||||
margin: 0 calc(-1 * var(--ifm-pre-padding));
|
||||
padding: 0 var(--ifm-pre-padding);
|
||||
}
|
@@ -1 +0,0 @@
|
||||
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1673488195730" class="icon" viewBox="0 0 1026 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2727" xmlns:xlink="http://www.w3.org/1999/xlink" width="200.390625" height="200"><path d="M2.438 0h975.238v975.238H2.438z" fill="#2FC2B0" fill-opacity="0" p-id="2728"></path><path d="M266.386 774.095c0 20.675 18.725 37.547 41.594 37.547h41.643V943.25c0 31.208 27.843 56.369 62.415 56.369 34.524 0 62.415-25.21 62.415-56.369V811.69h83.188v131.56c0 31.208 27.892 56.369 62.415 56.369 34.524 0 62.416-25.21 62.416-56.369V811.69h41.594c22.918 0 41.593-16.92 41.593-37.546V398.19H266.386v375.856zM162.377 398.238c-34.523 0-62.415 25.21-62.415 56.37v263.118c0 31.208 27.892 56.37 62.415 56.37 34.524 0 62.415-25.162 62.415-56.37V454.607c0-31.207-27.891-56.369-62.415-56.369z m707.292 0c-34.524 0-62.416 25.21-62.416 56.37v263.118c0 31.208 27.892 56.37 62.416 56.37 34.523 0 62.415-25.162 62.415-56.37V454.607c0-31.207-27.892-56.369-62.415-56.369z m-206.75-219.477l54.271-49.054a17.457 17.457 0 0 0 0-26.478 22.333 22.333 0 0 0-29.306 0l-61.586 55.393a269.897 269.897 0 0 0-110.25-23.454c-39.986 0-77.386 8.63-110.885 23.65l-61.782-55.784a22.333 22.333 0 0 0-29.354 0 17.457 17.457 0 0 0 0 26.478l54.515 49.25c-61.78 41.154-102.156 107.275-102.156 181.881h499.322c0-74.752-40.618-140.922-102.79-181.882zM432.81 285.501h-41.594v-37.547h41.594v37.547z m208.018 0h-41.594v-37.547h41.594v37.547z" fill="#2FC2B0" p-id="2729"></path></svg>
|
Before Width: | Height: | Size: 1.5 KiB |
@@ -1 +0,0 @@
|
||||
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1611298937091" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="862" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M944.9 471.640625a141.946875 141.946875 0 0 0-105.046875-9.50625 139.640625 139.640625 0 0 0-56.784375-88.959375l-11.25-8.859375-9.534375 10.6875a117.675 117.675 0 0 0-22.21875 84.65625 108.590625 108.590625 0 0 0 21.20625 56.86875 164.925 164.925 0 0 1-30.54375 13.44375A204.271875 204.271875 0 0 1 667.75625 540.125H73.925l-1.265625 13.303125a248.428125 248.428125 0 0 0 20.896875 129.375l8.128125 16.115625 0.928125 1.51875c55.828125 92.19375 167.203125 139.95 274.05 139.95 206.8875 0 364.190625-98.746875 442.575-288.478125 52.36875 2.671875 105.946875-12.403125 131.56875-61.003125l6.525-12.403125-12.43125-6.975zM246.978125 711.6875a46.434375 46.434375 0 1 1 47.8125-46.434375 47.165625 47.165625 0 0 1-47.8125 46.434375z" fill="#1296db" p-id="863"></path><path d="M246.978125 640.7a24.440625 24.440625 0 1 0 25.14375 24.46875 24.80625 24.80625 0 0 0-25.14375-24.46875M118.25 427.625h84.375v84.375H118.25z m112.5 0h84.375v84.375h-84.375z m0-112.5h84.375v84.375h-84.375z m112.5 0h84.375v84.375h-84.375z m0 112.5h84.375v84.375h-84.375z m112.5 0h84.375v84.375h-84.375z m112.5 0h84.375v84.375h-84.375zM455.75 315.125h84.375v84.375h-84.375z m0-112.5h84.375v84.375h-84.375z" fill="#1296db" p-id="864"></path></svg>
|
Before Width: | Height: | Size: 1.6 KiB |
@@ -1,588 +0,0 @@
|
||||
.ThingsGateway-banner {
|
||||
padding: 4rem 2rem;
|
||||
align-items: center;
|
||||
background-color: #211b50;
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-container {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
max-width: 1140px;
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-item {
|
||||
flex: 1;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-project {
|
||||
font-size: 1.5em;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-description {
|
||||
margin: 24px 0;
|
||||
font-size: 2.5em;
|
||||
font-weight: 700;
|
||||
line-height: 1.25;
|
||||
background-image: linear-gradient(81deg, #8759ff, #3fc4fe, #42ffac);
|
||||
-webkit-background-clip: text;
|
||||
background-clip: text;
|
||||
-webkit-text-fill-color: transparent;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-spec {
|
||||
padding: 0;
|
||||
opacity: 0.7;
|
||||
font-family: Muli;
|
||||
font-size: 1em;
|
||||
font-weight: 500;
|
||||
line-height: 1.33;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-spec li {
|
||||
list-style: none;
|
||||
position: relative;
|
||||
padding-left: 1em;
|
||||
margin-bottom: 1em;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-spec li::before {
|
||||
content: "";
|
||||
position: absolute;
|
||||
top: 0.5em;
|
||||
left: 0;
|
||||
width: 4px;
|
||||
height: 4px;
|
||||
background-color: rgb(135, 89, 255);
|
||||
}
|
||||
|
||||
.ThingsGateway-support-platform {
|
||||
font-size: 0.85em;
|
||||
line-height: 2;
|
||||
margin-top: 3em;
|
||||
font-weight: 500;
|
||||
opacity: 0.6;
|
||||
color: white;
|
||||
font-family: Muli;
|
||||
}
|
||||
|
||||
.ThingsGateway-support-icons {
|
||||
display: flex;
|
||||
margin-top: 12px;
|
||||
}
|
||||
|
||||
.ThingsGateway-support-icons span {
|
||||
margin-right: 20px;
|
||||
}
|
||||
|
||||
.ThingsGateway-get-start,
|
||||
.ThingsGateway-try-demo {
|
||||
margin-top: 4em;
|
||||
border-radius: 2em;
|
||||
min-width: 145px;
|
||||
color: #fff;
|
||||
background: #8759ff;
|
||||
position: relative;
|
||||
line-height: 1.5;
|
||||
text-align: center;
|
||||
padding: 8px 32px;
|
||||
text-decoration: none;
|
||||
display: inline-block;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.ThingsGateway-try-demo {
|
||||
background-color: rgb(33, 176, 145);
|
||||
margin-left: 20px;
|
||||
}
|
||||
|
||||
.ThingsGateway-get-start:hover {
|
||||
background: rgba(135, 89, 255, 0.9);
|
||||
}
|
||||
|
||||
.ThingsGateway-try-demo:hover {
|
||||
opacity: 0.9;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-item .system-window {
|
||||
width: 34rem;
|
||||
}
|
||||
|
||||
.ThingsGateway-get-start:hover,
|
||||
.ThingsGateway-try-demo:hover {
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.system-top-bar {
|
||||
background-image: linear-gradient(to right,
|
||||
rgba(136, 89, 255, 0.2),
|
||||
rgba(63, 196, 254, 0.2) 90%,
|
||||
rgba(66, 255, 172, 0.2));
|
||||
padding: 0.25em 1em;
|
||||
}
|
||||
|
||||
.system-top-bar-circle {
|
||||
display: inline-block;
|
||||
width: 0.5em;
|
||||
height: 0.5em;
|
||||
margin-left: 0.3em;
|
||||
border-radius: 50%;
|
||||
filter: brightness(100%);
|
||||
}
|
||||
|
||||
.system-window {
|
||||
--ifm-leading: 0;
|
||||
width: 95%;
|
||||
padding: 0;
|
||||
border-radius: 1em;
|
||||
overflow: hidden;
|
||||
background: rgb(33, 27, 80);
|
||||
}
|
||||
|
||||
.system-window iframe {
|
||||
border-radius: unset;
|
||||
}
|
||||
|
||||
.system-window pre {
|
||||
margin-bottom: 0 !important;
|
||||
}
|
||||
|
||||
.blue-accent {
|
||||
--uni-border-color: #3fbbfe;
|
||||
--uni-box-shadow-color: rgba(63, 187, 254, 0.1);
|
||||
--ifm-menu-color-active: #3fbbfe;
|
||||
}
|
||||
|
||||
.preview-border {
|
||||
box-shadow: 0 6px 58px 0 rgba(63, 187, 254, 0.1);
|
||||
border: solid 1px #3fbbfe;
|
||||
}
|
||||
|
||||
.ThingsGateway-content {
|
||||
margin-top: 4em;
|
||||
margin-bottom: 4em;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-small-title {
|
||||
color: #412a94;
|
||||
font-family: Muli;
|
||||
font-size: 1em;
|
||||
font-weight: 600;
|
||||
letter-spacing: 1px;
|
||||
opacity: 0.6;
|
||||
}
|
||||
|
||||
.ThingsGateway-small-title.dark {
|
||||
color: #f5f6f7;
|
||||
}
|
||||
|
||||
.ThingsGateway-big-title {
|
||||
color: #412a94;
|
||||
font-family: Poppins;
|
||||
font-size: 2em;
|
||||
font-weight: 700;
|
||||
line-height: 1.31;
|
||||
margin-bottom: 2em;
|
||||
}
|
||||
|
||||
.ThingsGateway-big-title.dark {
|
||||
color: #f5f6f7;
|
||||
}
|
||||
|
||||
.ThingsGateway-gitee-log {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
flex-wrap: nowrap;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-item {
|
||||
width: 260px;
|
||||
height: 173px;
|
||||
box-sizing: border-box;
|
||||
margin-right: 65px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-jiao {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
background: #fff;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
top: -6px;
|
||||
right: -6px;
|
||||
border-top: 1px dashed #a795e8;
|
||||
border-right: 1px dashed #a795e8;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-jiao.dark {
|
||||
background: #18191a;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-item:last-child {
|
||||
margin-right: 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-number {
|
||||
position: relative;
|
||||
z-index: 2;
|
||||
height: 100%;
|
||||
display: flex;
|
||||
width: 100%;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-number div {
|
||||
font-size: 3em;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-number span {
|
||||
font-family: Poppins, sans-serif;
|
||||
font-stretch: normal;
|
||||
font-style: normal;
|
||||
letter-spacing: normal;
|
||||
line-height: normal;
|
||||
color: #1c1e21;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-number span.dark {
|
||||
color: #f5f6f7;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-item {
|
||||
margin: 2em;
|
||||
max-width: 320px;
|
||||
height: 100%;
|
||||
padding: 4em 2em;
|
||||
border-style: solid;
|
||||
border-width: 6px;
|
||||
border-image-source: linear-gradient(var(--uni-border-gradient-degrees),
|
||||
#8759ff,
|
||||
#3fc4fe 51%,
|
||||
#42ffac);
|
||||
border-image-slice: 1;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-item:first-child {
|
||||
border-top: 0;
|
||||
border-right: 0;
|
||||
--uni-border-gradient-degrees: 41deg;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-item:nth-child(2) {
|
||||
--uni-border-gradient-degrees: 100deg;
|
||||
border-right: 0;
|
||||
border-left: 0;
|
||||
border-top: 0;
|
||||
border-bottom: 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-item:last-child {
|
||||
--uni-border-gradient-degrees: 221deg;
|
||||
border-bottom: 0;
|
||||
border-left: 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-p {
|
||||
height: 150px;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-p h1 {
|
||||
font-size: 24px;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-p p {
|
||||
color: rgb(71, 71, 71);
|
||||
font-family: Muli;
|
||||
font-size: 1em;
|
||||
line-height: 1.75;
|
||||
opacity: 0.8;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-p p.dark {
|
||||
color: #f5f6f7;
|
||||
}
|
||||
|
||||
.ThingsGateway-whouse {
|
||||
align-items: center;
|
||||
background-color: #412a94 !important;
|
||||
color: #fff;
|
||||
display: flex;
|
||||
padding: 5rem 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-who-custom {
|
||||
background-color: #fff;
|
||||
min-height: 500px;
|
||||
width: 60%;
|
||||
box-sizing: border-box;
|
||||
padding: 6rem;
|
||||
justify-content: flex-end;
|
||||
align-items: center;
|
||||
color: #723cff;
|
||||
text-align: right;
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.ThingsGateway-custom-img {
|
||||
text-decoration: none;
|
||||
color: transparent;
|
||||
margin-left: 3em;
|
||||
}
|
||||
|
||||
.ThingsGateway-who-des {
|
||||
padding: 0 5rem;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
.ThingsGateway-who-des p {
|
||||
color: #fff;
|
||||
font-family: Muli;
|
||||
font-size: 1em;
|
||||
line-height: 1.75;
|
||||
margin-bottom: 0.8em;
|
||||
opacity: 0.8;
|
||||
}
|
||||
|
||||
.footer {
|
||||
background-color: #211b50 !important;
|
||||
}
|
||||
|
||||
.ThingsGateway-links {
|
||||
margin: 4em;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-links-content a {
|
||||
display: inline-block;
|
||||
margin: 0 1em;
|
||||
font-size: 20px;
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.ThingsGateway-proccesson {
|
||||
margin: 4em 0;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#dotnet-china {
|
||||
height: 100px;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributors {
|
||||
margin: 4em 0;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item {
|
||||
display: inline-block;
|
||||
margin: 10px 5px;
|
||||
text-align: center;
|
||||
background-color: #f3f3f3;
|
||||
color: #333;
|
||||
padding: 10px;
|
||||
width: 130px;
|
||||
overflow: hidden;
|
||||
border-radius: 4px;
|
||||
height: 170px;
|
||||
box-shadow: 4px 3px 16px -3px #0009;
|
||||
box-sizing: border-box;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-extra {
|
||||
position: absolute;
|
||||
top: -9px;
|
||||
right: 0;
|
||||
padding: 2px 5px;
|
||||
background-color: #412a94;
|
||||
color: #fff;
|
||||
font-size: 12px;
|
||||
border-radius: 4px;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item a {
|
||||
text-decoration: none;
|
||||
color: #333;
|
||||
font-weight: bold;
|
||||
display: block;
|
||||
font-size: 10pt;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item div {
|
||||
margin-top: 10px;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item img {
|
||||
display: block;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item.dark {
|
||||
background: #333;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributor-item.dark a {
|
||||
color: #f5f6f7;
|
||||
}
|
||||
|
||||
.ThingsGateway-get-start-btn {
|
||||
position: relative;
|
||||
display: flex;
|
||||
}
|
||||
|
||||
.ThingsGateway-version {
|
||||
position: absolute;
|
||||
z-index: 10;
|
||||
right: 0;
|
||||
top: -10px;
|
||||
color: yellow;
|
||||
font-size: 16px;
|
||||
}
|
||||
|
||||
@media screen and (max-width: 1024px) {
|
||||
.ThingsGateway-banner-container {
|
||||
justify-content: unset;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.ThingsGateway-get-start-btn {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#dotnet-china {
|
||||
height: 45px;
|
||||
}
|
||||
|
||||
.ThingsGateway-banner-item .system-window {
|
||||
width: 100%;
|
||||
margin-top: 3rem;
|
||||
}
|
||||
|
||||
.ThingsGateway-gitee-log {
|
||||
justify-content: center;
|
||||
flex-wrap: unset;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
padding: 20px;
|
||||
}
|
||||
|
||||
.ThingsGateway-log-item {
|
||||
width: 100%;
|
||||
height: 173px;
|
||||
margin-right: 0;
|
||||
margin-top: 25px;
|
||||
}
|
||||
|
||||
.ThingsGateway-big-title {
|
||||
margin-bottom: 1em;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark {
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.ThingsGateway-whouse {
|
||||
flex-direction: column;
|
||||
padding-bottom: 1em;
|
||||
}
|
||||
|
||||
.ThingsGateway-who-des {
|
||||
padding-top: 1em;
|
||||
padding-bottom: 2em;
|
||||
}
|
||||
|
||||
.ThingsGateway-remark-item {
|
||||
border: none;
|
||||
margin: 0;
|
||||
width: 100%;
|
||||
max-width: unset;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-custom-img {
|
||||
margin-left: 0;
|
||||
margin-bottom: 2em;
|
||||
}
|
||||
|
||||
.ThingsGateway-custom-img img {
|
||||
max-width: unset;
|
||||
}
|
||||
|
||||
.ThingsGateway-who-custom {
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-contributors {
|
||||
margin: 4em 0;
|
||||
}
|
||||
}
|
||||
|
||||
.ThingsGateway-bifa {
|
||||
background-position: center center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: cover;
|
||||
color: #fff;
|
||||
display: flex;
|
||||
flex-direction: row-reverse;
|
||||
justify-content: center;
|
||||
padding: 100px 0;
|
||||
}
|
||||
|
||||
.ThingsGateway-wzi {
|
||||
border-left: 1px solid rgba(137, 147, 180, 0.5);
|
||||
writing-mode: vertical-lr;
|
||||
font-size: 20px;
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
letter-spacing: 10px;
|
||||
padding: 25px;
|
||||
height: 320px;
|
||||
}
|
||||
|
||||
.ThingsGateway-wzi span {
|
||||
color: rgb(68, 188, 254);
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.ThingsGateway-wzi-title {
|
||||
width: 84px;
|
||||
height: 320px;
|
||||
writing-mode: vertical-lr;
|
||||
background: rgb(68, 114, 196);
|
||||
background-image: linear-gradient(rgb(91, 128, 212) 1px, transparent 0),
|
||||
linear-gradient(90deg, rgb(91, 128, 212) 1px, transparent 0);
|
||||
background-size: 8px 8px;
|
||||
margin-left: 40px;
|
||||
font-size: 22px;
|
||||
font-weight: 500;
|
||||
letter-spacing: 12px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.ThingsGateway-wzi-title b {
|
||||
font-size: 20px;
|
||||
writing-mode: horizontal-tb;
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
margin: 20px 0;
|
||||
letter-spacing: 2px;
|
||||
}
|
@@ -1,194 +0,0 @@
|
||||
import Link from "@docusaurus/Link";
|
||||
import { useColorMode } from "@docusaurus/theme-common";
|
||||
import useBaseUrl from "@docusaurus/useBaseUrl";
|
||||
import useDocusaurusContext from "@docusaurus/useDocusaurusContext";
|
||||
import Layout from "@theme/Layout";
|
||||
import components from "@theme/MDXComponents";
|
||||
import React from "react";
|
||||
import AndroidIcon from "./android.svg";
|
||||
import DockerIcon from "./docker.svg";
|
||||
import "./index.css";
|
||||
import "./index.own.css";
|
||||
import KubernetesIcon from "./kubernetes.svg";
|
||||
import LinuxIcon from "./linux.svg";
|
||||
import MacOSIcon from "./macos.svg";
|
||||
import WindowIcon from "./windows.svg";
|
||||
|
||||
function Home() {
|
||||
const context = useDocusaurusContext();
|
||||
const { siteConfig = {} } = context;
|
||||
|
||||
React.useEffect(() => { }, []);
|
||||
|
||||
return (
|
||||
<Layout
|
||||
title={`ThingsGateway说明文档。 ${siteConfig.title}`}
|
||||
description="ThingsGateway说明文档"
|
||||
>
|
||||
<Banner />
|
||||
<Gitee />
|
||||
</Layout>
|
||||
);
|
||||
}
|
||||
|
||||
function Banner() {
|
||||
|
||||
const { colorMode, setLightTheme, setDarkTheme } = useColorMode();
|
||||
const isDarkTheme = colorMode === "dark";
|
||||
|
||||
return (
|
||||
<div className={"ThingsGateway-banner" + (isDarkTheme ? " dark" : "")}>
|
||||
<div className="ThingsGateway-banner-container">
|
||||
<div className="ThingsGateway-banner-item">
|
||||
<div className="ThingsGateway-banner-project">
|
||||
<span style={{ fontSize: 20, fontWeight: "Blod", color: "#FFFFFF" }}>
|
||||
ThingsGateway
|
||||
</span>
|
||||
</div>
|
||||
<div style={{ color: "#82aaff", position: "relative", fontSize: 14 }}>
|
||||
基于NetCore的跨平台物联网关。
|
||||
</div>
|
||||
<div className={"ThingsGateway-banner-description"+ (isDarkTheme ? " dark" : "")}>
|
||||
不只是心血来潮,更是持之以恒
|
||||
</div>
|
||||
<ul className="ThingsGateway-banner-spec">
|
||||
<li> Apache-2.0 宽松开源协议,商业免费授权</li>
|
||||
<li>
|
||||
底层驱动库 支持 .NET Framework 4.5及以上,.NET Standard2.0及以上
|
||||
</li>
|
||||
<li>网关 支持 .NET 6/7/8</li>
|
||||
<li>极速上手,极简使用</li>
|
||||
</ul>
|
||||
<div className="ThingsGateway-support-platform">受支持平台:</div>
|
||||
<div className="ThingsGateway-support-icons">
|
||||
<span>
|
||||
<WindowIcon height="39" width="39" />
|
||||
</span>
|
||||
<span>
|
||||
<LinuxIcon height="39" width="39" />
|
||||
</span>
|
||||
<span>
|
||||
<AndroidIcon height="39" width="39" />
|
||||
</span>
|
||||
<span>
|
||||
<MacOSIcon height="39" width="39" />
|
||||
</span>
|
||||
<span>
|
||||
<DockerIcon height="39" width="39" />
|
||||
</span>
|
||||
<span>
|
||||
<KubernetesIcon height="39" width="39" />
|
||||
</span>
|
||||
</div>
|
||||
<div className="ThingsGateway-get-start-btn">
|
||||
<Link className="ThingsGateway-get-start" to={useBaseUrl("docs/")}>
|
||||
入门指南
|
||||
<span className="ThingsGateway-version">v6.0</span>
|
||||
</Link>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
function Gitee() {
|
||||
const { colorMode, setLightTheme, setDarkTheme } = useColorMode();
|
||||
const isDarkTheme = colorMode === "dark";
|
||||
|
||||
return (
|
||||
<div className="ThingsGateway-content">
|
||||
<p className={"ThingsGateway-small-title" + (isDarkTheme ? " dark" : "")}>
|
||||
开源免费/商业免费授权
|
||||
</p>
|
||||
<h1 className={"ThingsGateway-big-title" + (isDarkTheme ? " dark" : "")}>
|
||||
⭐️ Apache-2.0 开源协议,代码在 Gitee/Github 平台托管 ⭐️
|
||||
</h1>
|
||||
<div className="ThingsGateway-gitee-log">
|
||||
<div
|
||||
className="ThingsGateway-log-item"
|
||||
style={{ border: "6px solid #723cff" }}
|
||||
>
|
||||
<div
|
||||
className={"ThingsGateway-log-jiao" + (isDarkTheme ? " dark" : "")}
|
||||
></div>
|
||||
<div className="ThingsGateway-log-number">
|
||||
<div style={{ color: "#723cff" }}>750 +</div>
|
||||
<span className={isDarkTheme ? " dark" : ""}>Stars</span>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
className="ThingsGateway-log-item"
|
||||
style={{ border: "6px solid #3fbbfe" }}
|
||||
>
|
||||
<div
|
||||
className={"ThingsGateway-log-jiao" + (isDarkTheme ? " dark" : "")}
|
||||
></div>
|
||||
<div className="ThingsGateway-log-number">
|
||||
<div style={{ color: "#3fbbfe" }}>200 +</div>
|
||||
<span className={isDarkTheme ? " dark" : ""}>Forks</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
function CodeSection(props) {
|
||||
let { language, replace, section, source } = props;
|
||||
|
||||
source = source.replace(/\/\/ <.*?\n/g, "");
|
||||
|
||||
if (replace) {
|
||||
for (const [pattern, value] of Object.entries(replace)) {
|
||||
source = source.replace(new RegExp(pattern, "gs"), value);
|
||||
}
|
||||
}
|
||||
|
||||
source = source.trim();
|
||||
if (!source.includes("\n")) {
|
||||
source += "\n";
|
||||
}
|
||||
|
||||
return (
|
||||
<components.pre>
|
||||
<components.code
|
||||
children={source}
|
||||
className={`language-${language}`}
|
||||
mdxType="code"
|
||||
originalType="code"
|
||||
parentName="pre"
|
||||
/>
|
||||
</components.pre>
|
||||
);
|
||||
}
|
||||
|
||||
function SystemWindow(systemWindowProps) {
|
||||
const { children, className, ...props } = systemWindowProps;
|
||||
return (
|
||||
<div
|
||||
{...props}
|
||||
className={"system-window blue-accent preview-border " + className}
|
||||
>
|
||||
<div className="system-top-bar">
|
||||
<span
|
||||
className="system-top-bar-circle"
|
||||
style={{ backgroundColor: "#8759ff" }}
|
||||
/>
|
||||
<span
|
||||
className="system-top-bar-circle"
|
||||
style={{ backgroundColor: "#3fc4fe" }}
|
||||
/>
|
||||
<span
|
||||
className="system-top-bar-circle"
|
||||
style={{ backgroundColor: "#42ffac" }}
|
||||
/>
|
||||
</div>
|
||||
{children}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
export default Home;
|
@@ -1,25 +0,0 @@
|
||||
.navbar {
|
||||
background-color: #211b50;
|
||||
}
|
||||
|
||||
.navbar__brand {
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.navbar__link {
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.navbar__link:hover,
|
||||
.navbar__link--active {
|
||||
color: yellow;
|
||||
}
|
||||
|
||||
.navbar__items {
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.menu__list-item .navbar__link--active,
|
||||
.menu__list-item .navbar__link:hover {
|
||||
color: #743dff;
|
||||
}
|
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 7.4 KiB |
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 19 KiB |
@@ -1 +0,0 @@
|
||||
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1611298499508" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1165" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M878.3 721.7c-1.35 3.6-18.9 65.25-62.1 128.25-37.8 54.9-76.5 109.8-137.7 110.7-60.3 0.9-79.65-36-148.5-36s-90.45 35.1-147.6 36.9c-58.95 2.25-104.4-59.85-142.2-114.3C163.25 736.55 103.85 531.8 183.5 395c39.15-68.4 109.8-112.05 186.3-113.4 57.6-0.9 112.95 39.15 148.05 39.15 36 0 102.6-48.6 172.8-41.4 29.25 1.35 111.6 12.15 164.25 89.1-4.05 2.7-98.1 58.5-97.2 171.45 0.9 136.35 119.25 181.35 120.6 181.8m-234-515.25c31.5-38.7 52.65-91.8 46.8-144.45-45 1.8-100.35 30.15-132.75 68.4-28.8 33.3-54.45 87.3-47.25 139.5 49.95 2.7 101.7-26.55 133.2-63.45" fill="#ffffff" p-id="1166"></path></svg>
|
Before Width: | Height: | Size: 965 B |
@@ -1 +0,0 @@
|
||||
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1611298487411" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1027" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css"></style></defs><path d="M459.5 485.75V182.09375l-314.90625 67.5V485.75H459.5zM512 485.75h367.3125V92.1875l-367.3125 78.75V485.75zM459.5 538.25H144.6875v236.15625l314.90625 67.5V538.25zM512 538.25v314.90625l367.3125 78.75V538.25H512z" fill="#00adef" p-id="1028"></path></svg>
|
Before Width: | Height: | Size: 627 B |
@@ -1,69 +0,0 @@
|
||||
import React from 'react';
|
||||
import clsx from 'clsx';
|
||||
import { ThemeClassNames } from '@docusaurus/theme-common';
|
||||
import { useDoc } from '@docusaurus/theme-common/internal';
|
||||
import LastUpdated from '@theme/LastUpdated';
|
||||
import EditThisPage from '@theme/EditThisPage';
|
||||
import TagsListInline from '@theme/TagsListInline';
|
||||
import styles from './styles.module.css';
|
||||
function TagsRow(props) {
|
||||
return (
|
||||
<div
|
||||
className={clsx(
|
||||
ThemeClassNames.docs.docFooterTagsRow,
|
||||
'row margin-bottom--sm',
|
||||
)}>
|
||||
<div className="col">
|
||||
<TagsListInline {...props} />
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
function EditMetaRow({
|
||||
editUrl,
|
||||
lastUpdatedAt,
|
||||
lastUpdatedBy,
|
||||
formattedLastUpdatedAt,
|
||||
}) {
|
||||
return (
|
||||
<div className={clsx(ThemeClassNames.docs.docFooterEditMetaRow, 'row')}>
|
||||
<div className="col">{editUrl && <EditThisPage editUrl={editUrl} />}</div>
|
||||
<script src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
|
||||
<div className={clsx('col', styles.lastUpdated)}>
|
||||
📖<span id="busuanzi_value_page_pv"></span><br/>
|
||||
{(lastUpdatedAt || lastUpdatedBy) && (
|
||||
<LastUpdated
|
||||
lastUpdatedAt={lastUpdatedAt}
|
||||
formattedLastUpdatedAt={formattedLastUpdatedAt}
|
||||
lastUpdatedBy={lastUpdatedBy}
|
||||
/>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
export default function DocItemFooter() {
|
||||
const { metadata } = useDoc();
|
||||
const { editUrl, lastUpdatedAt, formattedLastUpdatedAt, lastUpdatedBy, tags } =
|
||||
metadata;
|
||||
const canDisplayTagsRow = tags.length > 0;
|
||||
const canDisplayEditMetaRow = !!(editUrl || lastUpdatedAt || lastUpdatedBy);
|
||||
const canDisplayFooter = canDisplayTagsRow || canDisplayEditMetaRow;
|
||||
if (!canDisplayFooter) {
|
||||
return null;
|
||||
}
|
||||
return (
|
||||
<footer
|
||||
className={clsx(ThemeClassNames.docs.docFooter, 'docusaurus-mt-lg')}>
|
||||
{canDisplayTagsRow && <TagsRow tags={tags} />}
|
||||
{canDisplayEditMetaRow && (
|
||||
<EditMetaRow
|
||||
editUrl={editUrl}
|
||||
lastUpdatedAt={lastUpdatedAt}
|
||||
lastUpdatedBy={lastUpdatedBy}
|
||||
formattedLastUpdatedAt={formattedLastUpdatedAt}
|
||||
/>
|
||||
)}
|
||||
</footer>
|
||||
);
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user