Compare commits
2435 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
a82dff5c79 | ||
![]() |
112baad65f | ||
![]() |
978ceaadb6 | ||
![]() |
770b07179f | ||
![]() |
6d15167ad9 | ||
![]() |
39cba6bc74 | ||
![]() |
9558e66abf | ||
![]() |
ff7908955e | ||
![]() |
26b095b835 | ||
![]() |
feba2a32f9 | ||
![]() |
5090ece9b6 | ||
![]() |
221b19586e | ||
![]() |
3346c14255 | ||
![]() |
6e97e023c9 | ||
![]() |
b26e2ecf2e | ||
![]() |
d896238f23 | ||
![]() |
d2c8f5a75c | ||
![]() |
ce430d238c | ||
![]() |
ee397441ed | ||
![]() |
ba82d986c1 | ||
![]() |
2361cb521e | ||
![]() |
05f8d95281 | ||
![]() |
6c60b1c263 | ||
![]() |
0c32a0693c | ||
![]() |
807faa3c93 | ||
![]() |
fb53e37f7a | ||
![]() |
4ffdf98e16 | ||
![]() |
b8da721e39 | ||
![]() |
db8b98ca16 | ||
![]() |
01b8c600fe | ||
![]() |
69bd5549a2 | ||
![]() |
bc631e3931 | ||
![]() |
8ca4bc5a33 | ||
![]() |
58a569afb0 | ||
![]() |
db718d6fc3 | ||
![]() |
ca9cb8b07b | ||
![]() |
ef14586412 | ||
![]() |
09335fcd79 | ||
![]() |
15f1fca6fe | ||
![]() |
a570b8eb7a | ||
![]() |
02e2735b7a | ||
![]() |
54fa347142 | ||
![]() |
0c752beace | ||
![]() |
c14f808d29 | ||
![]() |
ad71173671 | ||
![]() |
204325ef44 | ||
![]() |
7ce6117659 | ||
![]() |
823a2c8b73 | ||
![]() |
741866e742 | ||
![]() |
41622678b0 | ||
![]() |
449b953401 | ||
![]() |
551548400f | ||
![]() |
6345ce5195 | ||
![]() |
95651f6163 | ||
![]() |
b02c1545b7 | ||
![]() |
2deaab9b24 | ||
![]() |
f0d4853533 | ||
![]() |
af81ae812f | ||
![]() |
bae76064e5 | ||
![]() |
07d9198cc8 | ||
![]() |
a2e07ea2f7 | ||
![]() |
864c762fe2 | ||
![]() |
167bb4e8a0 | ||
![]() |
4cf64ede74 | ||
![]() |
bb309fea6f | ||
![]() |
90a7b4c1c0 | ||
![]() |
1133362028 | ||
![]() |
eb9226bd4a | ||
![]() |
a9abdcc37e | ||
![]() |
6ace93bdbf | ||
![]() |
b89197939a | ||
![]() |
da788106af | ||
![]() |
49e92e6f1d | ||
![]() |
a6c3276104 | ||
![]() |
6388bfc714 | ||
![]() |
bebc3b181d | ||
![]() |
5a6d561c1a | ||
![]() |
5ba575fdfd | ||
![]() |
dcf8bbd804 | ||
![]() |
ff93ffd0b1 | ||
![]() |
395c09df92 | ||
![]() |
4c903cd08b | ||
![]() |
64cb98717c | ||
![]() |
b0e4ce54fb | ||
![]() |
d67a37002f | ||
![]() |
965ff8bc3f | ||
![]() |
400a495ad2 | ||
![]() |
09d0822a8d | ||
![]() |
7016c20ccc | ||
![]() |
df54895805 | ||
![]() |
62d5e6fe51 | ||
![]() |
4615a0b7ea | ||
![]() |
280d603b14 | ||
![]() |
36271f0749 | ||
![]() |
579638f932 | ||
![]() |
48871c82a6 | ||
![]() |
14056c42ef | ||
![]() |
90fe1576de | ||
![]() |
d61cf13985 | ||
![]() |
dfe6dfd0c6 | ||
![]() |
c138c7d0e9 | ||
![]() |
d542be947e | ||
![]() |
c76366e72e | ||
![]() |
75abfda783 | ||
![]() |
f3d8d7d4ad | ||
![]() |
7255eccb22 | ||
![]() |
a0decb70cc | ||
![]() |
532f562495 | ||
![]() |
27e58ae925 | ||
![]() |
abf30dfc1a | ||
![]() |
218b8ce86e | ||
![]() |
4867ffcb4b | ||
![]() |
e34c3b411d | ||
![]() |
c91b8be1a6 | ||
![]() |
9cb41644a1 | ||
![]() |
8c01cea147 | ||
![]() |
58eb55e90a | ||
![]() |
bb05e82e15 | ||
![]() |
5ab95ea175 | ||
![]() |
a25c4f1d1e | ||
![]() |
15287de8af | ||
![]() |
49b4d6b511 | ||
![]() |
d5b4a5d4ac | ||
![]() |
de480b491c | ||
![]() |
a949fda1fc | ||
![]() |
3e28af670c | ||
![]() |
b5310afb90 | ||
![]() |
da81ecf915 | ||
![]() |
f597066d16 | ||
![]() |
ec30606b24 | ||
![]() |
20dce14f17 | ||
![]() |
821742de85 | ||
![]() |
74dc108f62 | ||
![]() |
a05fe856bb | ||
![]() |
d13f51a32d | ||
![]() |
3dbe599cb3 | ||
![]() |
cf966dd83c | ||
![]() |
4e62f3654f | ||
![]() |
970d926563 | ||
![]() |
ff49c747ba | ||
![]() |
c46b8a5f4f | ||
![]() |
485324e204 | ||
![]() |
4696a03db1 | ||
![]() |
7885de36a9 | ||
![]() |
fac4339207 | ||
![]() |
9c70519021 | ||
![]() |
9ae77ecd5d | ||
![]() |
1c8e6f278d | ||
![]() |
c0a190a9f2 | ||
![]() |
e29e2a62f0 | ||
![]() |
1580640a35 | ||
![]() |
33c84b7fcc | ||
![]() |
9773ce75b0 | ||
![]() |
c310e8d152 | ||
![]() |
af251c7b81 | ||
![]() |
122483de0c | ||
![]() |
42c2131144 | ||
![]() |
71bc7a62c2 | ||
![]() |
87bfff07db | ||
![]() |
1cb5b780d2 | ||
![]() |
2f6acd4d6e | ||
![]() |
c2e2351505 | ||
![]() |
d847b5480b | ||
![]() |
32749ee58e | ||
![]() |
a531b8b5fe | ||
![]() |
148a0c5bb0 | ||
![]() |
39f9a58200 | ||
![]() |
edd113d344 | ||
![]() |
c641e8729b | ||
![]() |
2c4b13e4b5 | ||
![]() |
48fcf4dda7 | ||
![]() |
acfd980d4f | ||
![]() |
db9bfab812 | ||
![]() |
d32820ee09 | ||
![]() |
0f823fd19e | ||
![]() |
4308ed5850 | ||
![]() |
b9cd7c3983 | ||
![]() |
fa607aa961 | ||
![]() |
6900b71841 | ||
![]() |
bb230d67e8 | ||
![]() |
4f076ec3e3 | ||
![]() |
96a6cbfb95 | ||
![]() |
5bdc5aed72 | ||
![]() |
d38b0f088b | ||
![]() |
892710f705 | ||
![]() |
fbf898be64 | ||
![]() |
e3e2ecc1e1 | ||
![]() |
b59807d221 | ||
![]() |
163ad52285 | ||
![]() |
4023a6d1cc | ||
![]() |
ec827e5dc0 | ||
![]() |
a8f4fb7c22 | ||
![]() |
bc195ed452 | ||
![]() |
41568904ab | ||
![]() |
79050af391 | ||
![]() |
2e5b44c424 | ||
![]() |
7a437660d1 | ||
![]() |
47510e24d5 | ||
![]() |
91c9ef3068 | ||
![]() |
240854e4ac | ||
![]() |
0e4fc7efbc | ||
![]() |
b47e859225 | ||
![]() |
62a1072682 | ||
![]() |
c6f2a97591 | ||
![]() |
d66be231b3 | ||
![]() |
f73ffc8711 | ||
![]() |
e4c17c1bc7 | ||
![]() |
997e729535 | ||
![]() |
e0e313b8d1 | ||
![]() |
f0bd763e72 | ||
![]() |
6a7a90536b | ||
![]() |
ac8ddedfb5 | ||
![]() |
6fcd126ff8 | ||
![]() |
55d0966d48 | ||
![]() |
2583e08f7a | ||
![]() |
de72e62470 | ||
![]() |
91993dbb07 | ||
![]() |
d87ee4daa3 | ||
![]() |
6791e002ff | ||
![]() |
4ca84aa515 | ||
![]() |
8189cbc171 | ||
![]() |
73edb45ff7 | ||
![]() |
0bbe362660 | ||
![]() |
a76bee51fc | ||
![]() |
6e42b52414 | ||
![]() |
aed61209fa | ||
![]() |
f5d796ea77 | ||
![]() |
ecb04b4ba9 | ||
![]() |
dabb01e237 | ||
![]() |
c2d27d0fd4 | ||
![]() |
e62bd75fdf | ||
![]() |
2e917bd62b | ||
![]() |
e0492c4264 | ||
![]() |
7db68e2f96 | ||
![]() |
e9b05a37d1 | ||
![]() |
5613259536 | ||
![]() |
3209ff16ac | ||
![]() |
a49c8602d1 | ||
![]() |
7caa055e00 | ||
![]() |
0d62bc6c78 | ||
![]() |
bc0861fd9e | ||
![]() |
f280052d93 | ||
![]() |
21da49f79d | ||
![]() |
19a5ccf942 | ||
![]() |
0234b4ad81 | ||
![]() |
59ee9c21f3 | ||
![]() |
00317fed24 | ||
![]() |
42f6311ca8 | ||
![]() |
0f77a1ec03 | ||
![]() |
8268cd4d09 | ||
![]() |
c868070337 | ||
![]() |
2981fa5946 | ||
![]() |
623ec66a79 | ||
![]() |
b51bae14ec | ||
![]() |
05a3016557 | ||
![]() |
9250456e7b | ||
![]() |
163d6a7a28 | ||
![]() |
4ce9976dbc | ||
![]() |
f6490990de | ||
![]() |
f24ff606ac | ||
![]() |
3ff53744b5 | ||
![]() |
0b33c10ed8 | ||
![]() |
3fa87701ed | ||
![]() |
e5e0c6fa2a | ||
![]() |
0b38a0b6af | ||
![]() |
44b228777a | ||
![]() |
dd4f658d14 | ||
![]() |
9c66f47bca | ||
![]() |
138a34d6a4 | ||
![]() |
8f2af2e863 | ||
![]() |
c732fe16b3 | ||
![]() |
9be75e56e7 | ||
![]() |
e7d1f26034 | ||
![]() |
c554fff048 | ||
![]() |
0268521aaa | ||
![]() |
89b1cb9353 | ||
![]() |
8a17c5eaab | ||
![]() |
f4a1ad6c8c | ||
![]() |
93d76d8d79 | ||
![]() |
0b956a71b9 | ||
![]() |
26be72f76d | ||
![]() |
737391c721 | ||
![]() |
9c1d21fd1b | ||
![]() |
ef4a4c8611 | ||
![]() |
13c0a8ceaa | ||
![]() |
c2976080f6 | ||
![]() |
0a1b6931af | ||
![]() |
5009319f91 | ||
![]() |
4db8683bd6 | ||
![]() |
d35cf8d31e | ||
![]() |
5fef16131a | ||
![]() |
8b2235ee26 | ||
![]() |
2d8faf849e | ||
![]() |
c9de9fa185 | ||
![]() |
0618877d58 | ||
![]() |
f6b4e7eef8 | ||
![]() |
7abe44da19 | ||
![]() |
9006a0c25f | ||
![]() |
f8389ff8ab | ||
![]() |
894afe8f92 | ||
![]() |
115394ac8c | ||
![]() |
de42eda65f | ||
![]() |
0b7591edce | ||
![]() |
a043a044ca | ||
![]() |
b1f2727beb | ||
![]() |
d6e78a48a0 | ||
![]() |
589fe0f5f3 | ||
![]() |
244eeeb816 | ||
![]() |
4d5fc50f1a | ||
![]() |
dc0273148c | ||
![]() |
5e6f4bfb88 | ||
![]() |
bc0e18d074 | ||
![]() |
24d09fda4c | ||
![]() |
5e20ac07d1 | ||
![]() |
37c78e6bbd | ||
![]() |
7dcfb1081b | ||
![]() |
01407cf040 | ||
![]() |
eb814c2fb0 | ||
![]() |
d3caadf4af | ||
![]() |
5769c82fca | ||
![]() |
3754783ce2 | ||
![]() |
55ebe2cc0b | ||
![]() |
23c1a42163 | ||
![]() |
c879ffa768 | ||
![]() |
32f7bbfbab | ||
![]() |
84d5b3b158 | ||
![]() |
c8dae9ea9a | ||
![]() |
cbfb5dd8a6 | ||
![]() |
09b2b7350c | ||
![]() |
e146793d32 | ||
![]() |
0bad2ead10 | ||
![]() |
25176884e7 | ||
![]() |
266d4cddb0 | ||
![]() |
6e529a4205 | ||
![]() |
d2cce278bd | ||
![]() |
b774a62f8c | ||
![]() |
66c12e1a92 | ||
![]() |
184d748890 | ||
![]() |
8cc732c8d1 | ||
![]() |
c688d67e4b | ||
![]() |
3408be2840 | ||
![]() |
e126066132 | ||
![]() |
cfec447d8a | ||
![]() |
805d1fdd52 | ||
![]() |
9299948072 | ||
![]() |
b02960a5ec | ||
![]() |
8134b6db6a | ||
![]() |
cd16a3cc15 | ||
![]() |
074e7828f3 | ||
![]() |
5f7d1f9219 | ||
![]() |
b29c6105a1 | ||
![]() |
1297f5d43c | ||
![]() |
f94a5385d7 | ||
![]() |
8ef2000e45 | ||
![]() |
30d496076b | ||
![]() |
5de06d4482 | ||
![]() |
97fa983305 | ||
![]() |
dccc3c5bc1 | ||
![]() |
ed12465975 | ||
![]() |
b78be222d7 | ||
![]() |
342990e1bf | ||
![]() |
2e5dfdbb0d | ||
![]() |
1790ef0ee6 | ||
![]() |
712a5756e2 | ||
![]() |
bf6ff6b0f7 | ||
![]() |
c6003b6695 | ||
![]() |
8352540fcb | ||
![]() |
22299868fa | ||
![]() |
0d126a8e2b | ||
![]() |
776d027dfa | ||
![]() |
fa9b6d1006 | ||
![]() |
89aa7ffc73 | ||
![]() |
fd971449ca | ||
![]() |
f7cd57e549 | ||
![]() |
34aadbfb09 | ||
![]() |
167195a01c | ||
![]() |
b0abf94191 | ||
![]() |
1009c71e72 | ||
![]() |
29b1695159 | ||
![]() |
44f782221f | ||
![]() |
bab25c51d9 | ||
![]() |
89277e1665 | ||
![]() |
1e9c5a1682 | ||
![]() |
0c75486c7a | ||
![]() |
8c39739880 | ||
![]() |
ace1f84094 | ||
![]() |
2cfd6739ca | ||
![]() |
e0d6f0d653 | ||
![]() |
a4d3b387d0 | ||
![]() |
7394aca02d | ||
![]() |
e812725182 | ||
![]() |
bb76bfcd8b | ||
![]() |
6ff6d0a7dc | ||
![]() |
ddc9867058 | ||
![]() |
ba0d46c6cd | ||
![]() |
369f04fdbc | ||
![]() |
09dd8abe23 | ||
![]() |
8c692758ae | ||
![]() |
32d39b88bd | ||
![]() |
8bd66da511 | ||
![]() |
f86799e494 | ||
![]() |
8d10f26f56 | ||
![]() |
297543f9dd | ||
![]() |
0c53ee8460 | ||
![]() |
862842e3e1 | ||
![]() |
a4fad360df | ||
![]() |
3ba4c8b3bf | ||
![]() |
2992236be4 | ||
![]() |
82161f028e | ||
![]() |
1bcaec144b | ||
![]() |
852d4bba0a | ||
![]() |
af56fa2830 | ||
![]() |
813646e392 | ||
![]() |
1ce31eefc6 | ||
![]() |
fdf53844e1 | ||
![]() |
be57a82302 | ||
![]() |
fb82e863e0 | ||
![]() |
101483409f | ||
![]() |
6fe863eec1 | ||
![]() |
fbb6526aac | ||
![]() |
5556aea913 | ||
![]() |
95dc5fb849 | ||
![]() |
062199d0e3 | ||
![]() |
53ce327516 | ||
![]() |
61a1ce57c2 | ||
![]() |
687295f772 | ||
![]() |
e5366534ed | ||
![]() |
66fe84e126 | ||
![]() |
0b6c28422c | ||
![]() |
ea667bb6a9 | ||
![]() |
c9ba219de1 | ||
![]() |
9df1b29d70 | ||
![]() |
3e34359fa9 | ||
![]() |
1818930d2f | ||
![]() |
c03e674001 | ||
![]() |
10a25b82e0 | ||
![]() |
3b2489d738 | ||
![]() |
5c4ca3c84f | ||
![]() |
06c4b7ed2e | ||
![]() |
5591f6ccc9 | ||
![]() |
63dfb6947e | ||
![]() |
b089069b8e | ||
![]() |
e76a99fd68 | ||
![]() |
a4ea6c1fad | ||
![]() |
64ebdce1b2 | ||
![]() |
2709491d59 | ||
![]() |
81beedede6 | ||
![]() |
33a2386d74 | ||
![]() |
0df5e5283e | ||
![]() |
560407b972 | ||
![]() |
f8c25ae508 | ||
![]() |
c524277665 | ||
![]() |
a70fb009c7 | ||
![]() |
11e67f2ea3 | ||
![]() |
e7118ffe15 | ||
![]() |
79e9455244 | ||
![]() |
6ca8e8958a | ||
![]() |
d3dc207166 | ||
![]() |
51e200533b | ||
![]() |
b8a25b87d8 | ||
![]() |
f4fe0a0d4f | ||
![]() |
1d4f829d29 | ||
![]() |
4afa79fca4 | ||
![]() |
ec22184087 | ||
![]() |
413f3db5b4 | ||
![]() |
8ddfcce787 | ||
![]() |
562341adfe | ||
![]() |
9519ec53ef | ||
![]() |
35bada360d | ||
![]() |
1f39765efe | ||
![]() |
cce5b3b533 | ||
![]() |
e77a03b855 | ||
![]() |
7a54ff212e | ||
![]() |
01340f4597 | ||
![]() |
af6fa80d20 | ||
![]() |
e7474dcb9e | ||
![]() |
0eb906d5df | ||
![]() |
c7babf227c | ||
![]() |
d5c81c14f5 | ||
![]() |
59278378e5 | ||
![]() |
990e69143d | ||
![]() |
c413ae06dc | ||
![]() |
456f8a30cc | ||
![]() |
19c4561feb | ||
![]() |
1392fed023 | ||
![]() |
ca81e14d63 | ||
![]() |
8e7a8a02ec | ||
![]() |
e45dfa94ed | ||
![]() |
a153787ae6 | ||
![]() |
cf37c43bc7 | ||
![]() |
d0aa2bca69 | ||
![]() |
7b3811e6ee | ||
![]() |
4054f551d4 | ||
![]() |
4eeda10f3f | ||
![]() |
4231784ed2 | ||
![]() |
61ff6986d3 | ||
![]() |
09bc0bba1e | ||
![]() |
b2bda8479e | ||
![]() |
09b255f99e | ||
![]() |
0800642a2a | ||
![]() |
48b2b006c0 | ||
![]() |
af4c1f08ec | ||
![]() |
87b26b6342 | ||
![]() |
706fb8d82f | ||
![]() |
f7ca59bd5f | ||
![]() |
6540d0ea53 | ||
![]() |
5995038e21 | ||
![]() |
337ba6ea87 | ||
![]() |
04c6183752 | ||
![]() |
0b63922f46 | ||
![]() |
81c39d7d93 | ||
![]() |
164d31dfbc | ||
![]() |
1a833aad52 | ||
![]() |
77246c1fde | ||
![]() |
56c08a3587 | ||
![]() |
ce6214dc0f | ||
![]() |
22002d50ac | ||
![]() |
ab4e94695d | ||
![]() |
47a01cec7e | ||
![]() |
0cf9bc1a32 | ||
![]() |
6552ebcd3c | ||
![]() |
5af1d94fc0 | ||
![]() |
a4ec7b3047 | ||
![]() |
66f5003d91 | ||
![]() |
0c754e4b4b | ||
![]() |
e008087c4a | ||
![]() |
53f63996bd | ||
![]() |
4fedf77991 | ||
![]() |
34331d8763 | ||
![]() |
2c21b7762c | ||
![]() |
7f9c2b687f | ||
![]() |
b452ed648c | ||
![]() |
98e4b843ea | ||
![]() |
da2884d53c | ||
![]() |
7f2937400a | ||
![]() |
a3a4a8e431 | ||
![]() |
3249c954d3 | ||
![]() |
7395d2a74e | ||
![]() |
2060b7b49d | ||
![]() |
d263726c19 | ||
![]() |
7e3325e959 | ||
![]() |
ec075f05c5 | ||
![]() |
200e483574 | ||
![]() |
6c11bfe93d | ||
![]() |
b4cc7f4d81 | ||
![]() |
26fc63c52c | ||
![]() |
116bf59b68 | ||
![]() |
566f9dd5cc | ||
![]() |
ec740c07fa | ||
![]() |
7506bf186b | ||
![]() |
27c36b644d | ||
![]() |
ed2b1029f6 | ||
![]() |
530a920517 | ||
![]() |
42f8e635ed | ||
![]() |
7ace67f906 | ||
![]() |
1b437778dc | ||
![]() |
43b0c65aab | ||
![]() |
3f6a319ebe | ||
![]() |
4cbd342e17 | ||
![]() |
273f04128c | ||
![]() |
9a5cef08d6 | ||
![]() |
bbecfdb718 | ||
![]() |
cbed79fbf1 | ||
![]() |
c4cbc024e6 | ||
![]() |
2db8dbd5a3 | ||
![]() |
13b995c9f2 | ||
![]() |
a0944193b6 | ||
![]() |
c7f343020a | ||
![]() |
7a48ccc4f4 | ||
![]() |
cc1218b7a3 | ||
![]() |
385e640a92 | ||
![]() |
b40a59cbef | ||
![]() |
1a45ce5ea4 | ||
![]() |
ab05048409 | ||
![]() |
47aabbe9c5 | ||
![]() |
58cd2c522e | ||
![]() |
1fe0cd9f84 | ||
![]() |
eeee1ba1a3 | ||
![]() |
3cb8880c5c | ||
![]() |
80cec86225 | ||
![]() |
cc65ed8fb0 | ||
![]() |
0c3f1f4a5d | ||
![]() |
76375941ca | ||
![]() |
d2a0415def | ||
![]() |
815c0834b2 | ||
![]() |
7e1e1e2524 | ||
![]() |
957d2793cb | ||
![]() |
6ab86b7574 | ||
![]() |
1c75b7226d | ||
![]() |
db22d8e2c9 | ||
![]() |
7838b9609c | ||
![]() |
2a1a0421b6 | ||
![]() |
125ea0457e | ||
![]() |
c1f5f0632b | ||
![]() |
8c84ab29c6 | ||
![]() |
2767af11b2 | ||
![]() |
59bbc4c182 | ||
![]() |
a755ee8dc1 | ||
![]() |
4b1e66add3 | ||
![]() |
4f6727810b | ||
![]() |
60fdfc2b48 | ||
![]() |
268d8c8b7d | ||
![]() |
49d4071928 | ||
![]() |
c99b9dbe0a | ||
![]() |
09d3a06b27 | ||
![]() |
0d49bc003f | ||
![]() |
86a5569bf7 | ||
![]() |
ad9fe7dec6 | ||
![]() |
24bf07e068 | ||
![]() |
bae234827f | ||
![]() |
81c698f45b | ||
![]() |
c9fecec575 | ||
![]() |
2f42dfdc51 | ||
![]() |
5bac68b0de | ||
![]() |
5afd500c26 | ||
![]() |
03f3e5f6ab | ||
![]() |
50d91405a9 | ||
![]() |
69eed65c9b | ||
![]() |
f1355cd0ab | ||
![]() |
cc1a924c8b | ||
![]() |
02005a3f09 | ||
![]() |
d9219a5a48 | ||
![]() |
dffbdf544c | ||
![]() |
e2dbf1a215 | ||
![]() |
66f9cb8d25 | ||
![]() |
c1396b97f0 | ||
![]() |
920a711c00 | ||
![]() |
02a872a376 | ||
![]() |
be4493710f | ||
![]() |
52c0c5e0c5 | ||
![]() |
4c639f170e | ||
![]() |
509a414151 | ||
![]() |
8f3c793a69 | ||
![]() |
a2dd9cf1b8 | ||
![]() |
42285a5879 | ||
![]() |
5d63fce6f0 | ||
![]() |
46a4c8faec | ||
![]() |
ba14481151 | ||
![]() |
bdd8da98c4 | ||
![]() |
5a4207414d | ||
![]() |
730fdd32b1 | ||
![]() |
aa7f6694fc | ||
![]() |
8fba6704df | ||
![]() |
37d02eba02 | ||
![]() |
75a87cf070 | ||
![]() |
8acdc5853d | ||
![]() |
1aa1f441b3 | ||
![]() |
0e26032ac3 | ||
![]() |
871f25c6d9 | ||
![]() |
d8199e7ba7 | ||
![]() |
52b938eabe | ||
![]() |
94fddf3d9b | ||
![]() |
02c98c1ece | ||
![]() |
6ba77667e9 | ||
![]() |
e201a5b806 | ||
![]() |
adac68c407 | ||
![]() |
d051275e54 | ||
![]() |
2afc00364a | ||
![]() |
0a1461231b | ||
![]() |
129327f40d | ||
![]() |
58819aad94 | ||
![]() |
949a2543f5 | ||
![]() |
0f9d732667 | ||
![]() |
b7df175950 | ||
![]() |
4f7ce9874f | ||
![]() |
f63cc80383 | ||
![]() |
dd0a1328e8 | ||
![]() |
27610c002c | ||
![]() |
46ec9b5229 | ||
![]() |
778559d537 | ||
![]() |
1e64b8a903 | ||
![]() |
0e000693d6 | ||
![]() |
cf9e09ea7a | ||
![]() |
eac2f729a5 | ||
![]() |
9578cd27dd | ||
![]() |
9304ffffc9 | ||
![]() |
3fd628cb05 | ||
![]() |
fe68b70bd9 | ||
![]() |
ec2863d218 | ||
![]() |
dc56e7f883 | ||
![]() |
2f1f537e00 | ||
![]() |
b7b3a3025b | ||
![]() |
edb9526538 | ||
![]() |
62117ece06 | ||
![]() |
913a2a0ac1 | ||
![]() |
92ec3d07a3 | ||
![]() |
67ee7899fd | ||
![]() |
b0ceb3fe7e | ||
![]() |
ba6b4c6854 | ||
![]() |
61e90aed60 | ||
![]() |
45b7a399f2 | ||
![]() |
673ed25598 | ||
![]() |
14fc460174 | ||
![]() |
211b4537f9 | ||
![]() |
a683e059aa | ||
![]() |
d2d2cea567 | ||
![]() |
e5bda65a35 | ||
![]() |
6aaef9df4b | ||
![]() |
7fba4d72b0 | ||
![]() |
a6dc2ed4ba | ||
![]() |
20a40eb2f6 | ||
![]() |
ec4ac9d075 | ||
![]() |
b2c14f4226 | ||
![]() |
099dfbd0b0 | ||
![]() |
a9f5736c12 | ||
![]() |
2bd4dd3ab0 | ||
![]() |
186850c256 | ||
![]() |
9922033d33 | ||
![]() |
3c3e6e4144 | ||
![]() |
0e4ac3b7f3 | ||
![]() |
c9813e0316 | ||
![]() |
577c0cfab9 | ||
![]() |
0966f9d715 | ||
![]() |
3f5df118a0 | ||
![]() |
e05c1b26f1 | ||
![]() |
725b38c697 | ||
![]() |
402a0fdf3b | ||
![]() |
078364ffa1 | ||
![]() |
f64d5ec4fc | ||
![]() |
0666174501 | ||
![]() |
12194a50e1 | ||
![]() |
82ee592699 | ||
![]() |
1b4fb2ce6e | ||
![]() |
ebea8d12d1 | ||
![]() |
f842dd77df | ||
![]() |
a6ec7a6c99 | ||
![]() |
369c72282c | ||
![]() |
6f30c1a509 | ||
![]() |
abfd1116c7 | ||
![]() |
017854955d | ||
![]() |
1405cddea1 | ||
![]() |
00dd3164c9 | ||
![]() |
d5cbc0f611 | ||
![]() |
5d2e9ccc67 | ||
![]() |
017a881494 | ||
![]() |
52994970e6 | ||
![]() |
ebae629e5c | ||
![]() |
0dea5150a0 | ||
![]() |
c99e8d270d | ||
![]() |
4d79220b0c | ||
![]() |
96fba7fbb8 | ||
![]() |
e0d610071d | ||
![]() |
ab0966c005 | ||
![]() |
751eb41e72 | ||
![]() |
f08dc25711 | ||
![]() |
737eb31776 | ||
![]() |
d6abf283bc | ||
![]() |
bac4ab5aa4 | ||
![]() |
b5839390fd | ||
![]() |
d19271dae1 | ||
![]() |
ef5a09314e | ||
![]() |
ba52e298eb | ||
![]() |
b3c3998189 | ||
![]() |
782f9b5c04 | ||
![]() |
3079d8c605 | ||
![]() |
c5202d7b3e | ||
![]() |
fbae83f4de | ||
![]() |
5b7b8c934f | ||
![]() |
b70223e824 | ||
![]() |
9900bbbc8d | ||
![]() |
fc7f1ddd69 | ||
![]() |
991b2f4bf7 | ||
![]() |
bb251b16a9 | ||
![]() |
1b34a48a61 | ||
![]() |
8c83b715fe | ||
![]() |
c122708b0b | ||
![]() |
258d920ff2 | ||
![]() |
6e5c0cc0c7 | ||
![]() |
9dc82290b5 | ||
![]() |
bb73f90374 | ||
![]() |
8a0720b0e3 | ||
![]() |
88468c4f89 | ||
![]() |
d19a45592f | ||
![]() |
21a921d25d | ||
![]() |
3b2946aac5 | ||
![]() |
196d555e8c | ||
![]() |
28f39b5c7e | ||
![]() |
ec8ac17f4a | ||
![]() |
c45573349a | ||
![]() |
d36c9d43f6 | ||
![]() |
b06c744392 | ||
![]() |
9548c93b4c | ||
![]() |
4144944ab2 | ||
![]() |
46b85519c1 | ||
![]() |
5a83fc33ec | ||
![]() |
c80791267f | ||
![]() |
b30f97db3e | ||
![]() |
717c81fa2b | ||
![]() |
ae188bc563 | ||
![]() |
fc4561221d | ||
![]() |
5aeb4f8809 | ||
![]() |
c6c900bc39 | ||
![]() |
c18ab67a25 | ||
![]() |
55ae1470d0 | ||
![]() |
a1136fdfb2 | ||
![]() |
dfe56d3aa2 | ||
![]() |
3da5e13ecd | ||
![]() |
40d0fe0db6 | ||
![]() |
029fd2d0b0 | ||
![]() |
12905ad733 | ||
![]() |
d257f59a3e | ||
![]() |
1dc9646894 | ||
![]() |
c9281b4605 | ||
![]() |
e9d2ae5d67 | ||
![]() |
0f8e05610b | ||
![]() |
9ea2196e51 | ||
![]() |
97327a9033 | ||
![]() |
8bf11ba7d1 | ||
![]() |
523833b015 | ||
![]() |
e25a651d26 | ||
![]() |
92a8c1483d | ||
![]() |
8da3448e9c | ||
![]() |
f2385d8916 | ||
![]() |
17a8daa526 | ||
![]() |
51e254f127 | ||
![]() |
feccf571cd | ||
![]() |
9f8ce44c1b | ||
![]() |
a7cfe7f23b | ||
![]() |
8eaf775ef2 | ||
![]() |
7b4179a87f | ||
![]() |
43281bcbfe | ||
![]() |
8a35d47caf | ||
![]() |
759e8b6c42 | ||
![]() |
a8b01244af | ||
![]() |
6ffb16ac67 | ||
![]() |
5b66cc6c8b | ||
![]() |
9a96258265 | ||
![]() |
a6cc1566c7 | ||
![]() |
d8d6227125 | ||
![]() |
fbfa67e471 | ||
![]() |
ab897ada5a | ||
![]() |
3bcd3f3cb7 | ||
![]() |
acbede8631 | ||
![]() |
fa8c7571d7 | ||
![]() |
a58575c5a1 | ||
![]() |
51f7009a80 | ||
![]() |
ba24c77f06 | ||
![]() |
6b712c9a90 | ||
![]() |
033b15a158 | ||
![]() |
e398bb84d4 | ||
![]() |
05e902ab0c | ||
![]() |
36eee61cb5 | ||
![]() |
2409ce6fce | ||
![]() |
999d61e520 | ||
![]() |
08d2418190 | ||
![]() |
6c07faeaaf | ||
![]() |
3f5cfbf5a2 | ||
![]() |
28f7707c75 | ||
![]() |
dc8358f6ce | ||
![]() |
ffcda04677 | ||
![]() |
64ef655abb | ||
![]() |
67887b1220 | ||
![]() |
07803d1263 | ||
![]() |
f5ff7f7e13 | ||
![]() |
641d062b82 | ||
![]() |
bb28a06ee9 | ||
![]() |
81338c60f2 | ||
![]() |
f47fa5d272 | ||
![]() |
29e9e012a5 | ||
![]() |
f89ddb5847 | ||
![]() |
c721f063ef | ||
![]() |
a709565336 | ||
![]() |
91e484aef1 | ||
![]() |
6ba94dcc8e | ||
![]() |
788530be45 | ||
![]() |
7ed392e854 | ||
![]() |
3932e554da | ||
![]() |
1a21624618 | ||
![]() |
9f292ff018 | ||
![]() |
dbb24b3a9b | ||
![]() |
35b2639837 | ||
![]() |
35951199cd | ||
![]() |
79af909c51 | ||
![]() |
3482aa7b76 | ||
![]() |
5dbc1f59ef | ||
![]() |
2166a3220e | ||
![]() |
24a7d1ef10 | ||
![]() |
18ffbb7317 | ||
![]() |
363874de6a | ||
![]() |
68d1719b11 | ||
![]() |
1a75d81268 | ||
![]() |
2163be4227 | ||
![]() |
b54afcd922 | ||
![]() |
0a86641a0f | ||
![]() |
18464c746a | ||
![]() |
ba92cddae1 | ||
![]() |
2a4f8ed45f | ||
![]() |
135a0028be | ||
![]() |
4da6e8372f | ||
![]() |
6a7cdf2570 | ||
![]() |
73c929f25e | ||
![]() |
754c2d41c2 | ||
![]() |
7201e48111 | ||
![]() |
e4292815cd | ||
![]() |
ab37250d5d | ||
![]() |
e5be8d3ba7 | ||
![]() |
96a421fa22 | ||
![]() |
12f72401b1 | ||
![]() |
7391a9eddc | ||
![]() |
30dee27f72 | ||
![]() |
51a9939034 | ||
![]() |
e03c6e0ca4 | ||
![]() |
bece5c6488 | ||
![]() |
d49bb4c52d | ||
![]() |
73d0eec30c | ||
![]() |
5c756b16ca | ||
![]() |
f482c2422c | ||
![]() |
2e564c863f | ||
![]() |
d9917a81bb | ||
![]() |
61dc431f92 | ||
![]() |
7d2fb8d9d7 | ||
![]() |
608b79b66f | ||
![]() |
009754c18b | ||
![]() |
5df07c289e | ||
![]() |
a36d10870b | ||
![]() |
b549ba3e39 | ||
![]() |
897c96361f | ||
![]() |
e7693d8aa6 | ||
![]() |
1fe755f836 | ||
![]() |
ea1a63f7dd | ||
![]() |
85134722a5 | ||
![]() |
5c9d3ed134 | ||
![]() |
17fb935ea0 | ||
![]() |
196642a1cf | ||
![]() |
009cf63d8c | ||
![]() |
da399aacd6 | ||
![]() |
3632ee77e5 | ||
![]() |
2901f337cc | ||
![]() |
f0bd2f335b | ||
![]() |
acdd026448 | ||
![]() |
fb0a328ab0 | ||
![]() |
d2a7889fc9 | ||
![]() |
88c50e014d | ||
![]() |
f0ef12f904 | ||
![]() |
1827f5413f | ||
![]() |
0609f30e25 | ||
![]() |
d4e4d95b6d | ||
![]() |
d74af4931e | ||
![]() |
bee043d10d | ||
![]() |
a65e48b98a | ||
![]() |
ee26b54d54 | ||
![]() |
855ec53dc2 | ||
![]() |
3e3e48110d | ||
![]() |
fc04a357c8 | ||
![]() |
c8147370de | ||
![]() |
999426be89 | ||
![]() |
91458f91ef | ||
![]() |
4b9ed29cc0 | ||
![]() |
e3bcb673fb | ||
![]() |
bf4776ca4f | ||
![]() |
9f7f30a92a | ||
![]() |
5c29fff55e | ||
![]() |
a0160c2573 | ||
![]() |
87d3ca287d | ||
![]() |
526e093689 | ||
![]() |
0930c9d8d6 | ||
![]() |
ec680a713d | ||
![]() |
583f90d1e9 | ||
![]() |
8ba95381bc | ||
![]() |
ec6d634b99 | ||
![]() |
bc082acbe7 | ||
![]() |
e474ba02cb | ||
![]() |
ea922aaf10 | ||
![]() |
766e6e20d8 | ||
![]() |
8e646c244e | ||
![]() |
26f31a5899 | ||
![]() |
5c79e374dd | ||
![]() |
7c1473ea95 | ||
![]() |
1fe4cc3258 | ||
![]() |
042ad4cea1 | ||
![]() |
e4c998dbce | ||
![]() |
83c8cacdac | ||
![]() |
f75d5d906e | ||
![]() |
85b3856564 | ||
![]() |
75cb2569b5 | ||
![]() |
0a4ac1cece | ||
![]() |
a873fd14bd | ||
![]() |
85b4cd4998 | ||
![]() |
e9bc9b1aa8 | ||
![]() |
e3bf599bf6 | ||
![]() |
01ae96840e | ||
![]() |
186160ebf4 | ||
![]() |
70f5e45c1f | ||
![]() |
6dc54ecabc | ||
![]() |
d21888c047 | ||
![]() |
33f7a90042 | ||
![]() |
a00d3a2c5e | ||
![]() |
abc64d769c | ||
![]() |
88754ac569 | ||
![]() |
e3ee05d47d | ||
![]() |
3b004e7483 | ||
![]() |
9aa48c20e4 | ||
![]() |
1b5d3beeca | ||
![]() |
00115d313e | ||
![]() |
190f1a205f | ||
![]() |
8ab6f0c3fe | ||
![]() |
13eea263c0 | ||
![]() |
b52b40962e | ||
![]() |
7d1fa2e40c | ||
![]() |
93b2098829 | ||
![]() |
a2acdc6b12 | ||
![]() |
38b2c1e30f | ||
![]() |
e07f579f3c | ||
![]() |
df3297b6ca | ||
![]() |
fc4eeed764 | ||
![]() |
3596d13be1 | ||
![]() |
104d49ea1c | ||
![]() |
7057317446 | ||
![]() |
280575df88 | ||
![]() |
d2cb434b7b | ||
![]() |
2ecb802a2e | ||
![]() |
46e706c415 | ||
![]() |
3a57349d8a | ||
![]() |
565db852e0 | ||
![]() |
754c3269ec | ||
![]() |
a079842408 | ||
![]() |
7664b58553 | ||
![]() |
de77488f7e | ||
![]() |
d808afd21b | ||
![]() |
b68aff76a1 | ||
![]() |
6da7fe158f | ||
![]() |
4dbc7fdc7d | ||
![]() |
ad1e1f7eca | ||
![]() |
9c3f7a3823 | ||
![]() |
86f4cb7701 | ||
![]() |
359a90245d | ||
![]() |
d8d7d86359 | ||
![]() |
7189b629c0 | ||
![]() |
55c9b5566c | ||
![]() |
ab671ccbf7 | ||
![]() |
316bda8c3f | ||
![]() |
76f77e8a4c | ||
![]() |
4a99d5eab7 | ||
![]() |
473d287c6d | ||
![]() |
bddd9896e4 | ||
![]() |
95eb115965 | ||
![]() |
9a63b213b0 | ||
![]() |
90b00d88f1 | ||
![]() |
ec87c7f21c | ||
![]() |
452f45cac6 | ||
![]() |
c644b3d384 | ||
![]() |
68160c20e8 | ||
![]() |
ad144206dd | ||
![]() |
f3d20ab769 | ||
![]() |
9767ca7116 | ||
![]() |
73a5b8553f | ||
![]() |
5c684cd499 | ||
![]() |
479f3e3172 | ||
![]() |
6a1350fd00 | ||
![]() |
563784da1c | ||
![]() |
347f0ed3a5 | ||
![]() |
1db9f5b2c2 | ||
![]() |
f2a3e26188 | ||
![]() |
1c0897bfb6 | ||
![]() |
f0793992a6 | ||
![]() |
393205ba2f | ||
![]() |
ab49535b6c | ||
![]() |
8191b48548 | ||
![]() |
925dd06432 | ||
![]() |
0d525e056a | ||
![]() |
3aa86eebf2 | ||
![]() |
d7a93abec0 | ||
![]() |
6448d28a18 | ||
![]() |
449976483c | ||
![]() |
e468b762ef | ||
![]() |
b578e73cc4 | ||
![]() |
e381f95b95 | ||
![]() |
5685afae63 | ||
![]() |
53a473422b | ||
![]() |
3f9f17f584 | ||
![]() |
2c410bf318 | ||
![]() |
40934a2c77 | ||
![]() |
ecc9379d7e | ||
![]() |
f8d27342dc | ||
![]() |
17bd2bf2ba | ||
![]() |
d984a3f275 | ||
![]() |
64049bd546 | ||
![]() |
9218091c33 | ||
![]() |
75df7d6413 | ||
![]() |
29341f81e1 | ||
![]() |
68c5a3dca7 | ||
![]() |
b1e2e370c8 | ||
![]() |
ba9d3afc88 | ||
![]() |
9a0434be32 | ||
![]() |
d6923a2ff0 | ||
![]() |
8f7f6dc19e | ||
![]() |
70b8817643 | ||
![]() |
87c25cbbfe | ||
![]() |
082e905014 | ||
![]() |
e3e598b208 | ||
![]() |
6cf92d4ea6 | ||
![]() |
89ad685f3a | ||
![]() |
1e868dc802 | ||
![]() |
58fcfd9a34 | ||
![]() |
c849afbc11 | ||
![]() |
2ebe71ddd0 | ||
![]() |
7a8e8c1f3e | ||
![]() |
5e897ad1c2 | ||
![]() |
ce07907f85 | ||
![]() |
1e38aa7b53 | ||
![]() |
3bc0c23e5a | ||
![]() |
f07b6d105a | ||
![]() |
46491269e3 | ||
![]() |
8d9c43af6a | ||
![]() |
c3568354aa | ||
![]() |
e68696ccd4 | ||
![]() |
35d8b2e790 | ||
![]() |
1f83573206 | ||
![]() |
2887e76514 | ||
![]() |
63b9943203 | ||
![]() |
bd5aedd83f | ||
![]() |
c9ff6d7bb9 | ||
![]() |
5835def5d0 | ||
![]() |
6a2694ce3b | ||
![]() |
65ae7bce79 | ||
![]() |
57ce8da0ee | ||
![]() |
7484bf7403 | ||
![]() |
f6b2312c49 | ||
![]() |
6027cb7cb0 | ||
![]() |
c1740aae6c | ||
![]() |
22ce29e86c | ||
![]() |
251d1b5b2e | ||
![]() |
ea64708c69 | ||
![]() |
209ec27a29 | ||
![]() |
ceee495525 | ||
![]() |
751a2347aa | ||
![]() |
efd96d5fdf | ||
![]() |
2ee5af8bfb | ||
![]() |
a4c0edf493 | ||
![]() |
28c8be97b6 | ||
![]() |
f320a44d45 | ||
![]() |
c0cc6cc176 | ||
![]() |
be62c09d06 | ||
![]() |
5fe3546d2a | ||
![]() |
c4b2ea125c | ||
![]() |
3301b038fe | ||
![]() |
6a58d1e3da | ||
![]() |
e5670d820d | ||
![]() |
1870aead73 | ||
![]() |
95db6cca2c | ||
![]() |
79a792ac62 | ||
![]() |
6406f9eb86 | ||
![]() |
8f8ec496f8 | ||
![]() |
3d6847a3a2 | ||
![]() |
613abaec1b | ||
![]() |
b51ae9ac38 | ||
![]() |
c4fd03542b | ||
![]() |
e40d6c5ef0 | ||
![]() |
9f7dee3baa | ||
![]() |
d3da62c04a | ||
![]() |
aa7bb3f8c9 | ||
![]() |
3a9dfe339a | ||
![]() |
08830003a3 | ||
![]() |
efeeb6cb02 | ||
![]() |
ac59ce2deb | ||
![]() |
3ff89a03ac | ||
![]() |
25e231cd7c | ||
![]() |
f4d8d909b0 | ||
![]() |
35ea18a117 | ||
![]() |
ee9433261b | ||
![]() |
1cb48c7760 | ||
![]() |
172bf4bd51 | ||
![]() |
fe1039cfbc | ||
![]() |
a9de79546b | ||
![]() |
145172f486 | ||
![]() |
7afdf43872 | ||
![]() |
bfc7d5d0dd | ||
![]() |
690832052a | ||
![]() |
f7c1a47d52 | ||
![]() |
930843d065 | ||
![]() |
a9ee609502 | ||
![]() |
9fd2125923 | ||
![]() |
ede8703f9d | ||
![]() |
6d85623d9b | ||
![]() |
6236ee8f6d | ||
![]() |
92665d80d6 | ||
![]() |
70ae0bc77e | ||
![]() |
e28c757352 | ||
![]() |
7cdcf7ebab | ||
![]() |
7c368af5ed | ||
![]() |
df2fbbabc6 | ||
![]() |
48141eb199 | ||
![]() |
343fbb282c | ||
![]() |
cea9ed056b | ||
![]() |
73bd90c555 | ||
![]() |
917de46c45 | ||
![]() |
b592092923 | ||
![]() |
760bc1c22a | ||
![]() |
1f8b81ee78 | ||
![]() |
70af7d05e3 | ||
![]() |
14c04ee4ac | ||
![]() |
83815d3caa | ||
![]() |
487c621fa5 | ||
![]() |
304eab801c | ||
![]() |
dfe3add1cc | ||
![]() |
a32bf5539e | ||
![]() |
e944333e5f | ||
![]() |
dad23a52b0 | ||
![]() |
53606c306d | ||
![]() |
53b03f8231 | ||
![]() |
ac5f6dc024 | ||
![]() |
2c15e0dd32 | ||
![]() |
007334fef0 | ||
![]() |
b3ae2d2748 | ||
![]() |
7149c766d0 | ||
![]() |
5dca0191d2 | ||
![]() |
356668a68d | ||
![]() |
63c9442126 | ||
![]() |
0031d7911d | ||
![]() |
31c92b43b4 | ||
![]() |
2667548041 | ||
![]() |
54282ba7e0 | ||
![]() |
7f324abd44 | ||
![]() |
65a0c3b40a | ||
![]() |
2449baac5b | ||
![]() |
0ab03e1856 | ||
![]() |
9a3f85106c | ||
![]() |
42c495d8ab | ||
![]() |
58def585f1 | ||
![]() |
047034d831 | ||
![]() |
bdb2f24a81 | ||
![]() |
636870a075 | ||
![]() |
8981174302 | ||
![]() |
dd5f05334b | ||
![]() |
929b626b51 | ||
![]() |
7d5b2ec81e | ||
![]() |
f0e2d36c34 | ||
![]() |
94f171d757 | ||
![]() |
04e06db430 | ||
![]() |
d74b215169 | ||
![]() |
404ea94dd2 | ||
![]() |
4afe7c6b46 | ||
![]() |
60b20c4d01 | ||
![]() |
58658c6b1a | ||
![]() |
ec444317b3 | ||
![]() |
8b4aee1afa | ||
![]() |
51abd74304 | ||
![]() |
b93b465f09 | ||
![]() |
5aad68ec62 | ||
![]() |
74fbc937a1 | ||
![]() |
7e35f544eb | ||
![]() |
ed1c3cffc1 | ||
![]() |
c4983a9f9b | ||
![]() |
5b43262e7a | ||
![]() |
dad4408679 | ||
![]() |
a78c4d12b4 | ||
![]() |
74664a9df8 | ||
![]() |
fce5281a03 | ||
![]() |
de0bd2f486 | ||
![]() |
079fb5d108 | ||
![]() |
1c7435a32b | ||
![]() |
1afd374cf6 | ||
![]() |
3adf549915 | ||
![]() |
e94d669eca | ||
![]() |
5fac0b4689 | ||
![]() |
832d323a6e | ||
![]() |
03f1dbd5b2 | ||
![]() |
c0a216f109 | ||
![]() |
ad67b13270 | ||
![]() |
5d420c08c6 | ||
![]() |
3d8235c670 | ||
![]() |
5a209f81d1 | ||
![]() |
d17d8e2805 | ||
![]() |
ca7636e7bc | ||
![]() |
532cfc10d0 | ||
![]() |
72d68c4377 | ||
![]() |
00f5964aa4 | ||
![]() |
bd1ad5fa56 | ||
![]() |
f2e22e7445 | ||
![]() |
fcf345abab | ||
![]() |
24ad43d3e4 | ||
![]() |
9a7cdf42e1 | ||
![]() |
c36b652d5b | ||
![]() |
553070fc23 | ||
![]() |
5d69f7e24f | ||
![]() |
bc0e2bada0 | ||
![]() |
80b6cc1d94 | ||
![]() |
bce3273e64 | ||
![]() |
3abf61152a | ||
![]() |
14923d4cd6 | ||
![]() |
6fdc4bf900 | ||
![]() |
d21e1f75b5 | ||
![]() |
84a0b37fcc | ||
![]() |
f135a0f09e | ||
![]() |
0f24c99456 | ||
![]() |
9eae0ab947 | ||
![]() |
3bf1f79c79 | ||
![]() |
b21074c871 | ||
![]() |
d7893d9a32 | ||
![]() |
9cbdda330c | ||
![]() |
42a9bfd099 | ||
![]() |
eb15bd01ca | ||
![]() |
9e98aebeb3 | ||
![]() |
1361cbc826 | ||
![]() |
679d0808a9 | ||
![]() |
6fe9a548ad | ||
![]() |
2d6d2430d2 | ||
![]() |
a445538e81 | ||
![]() |
50d38ffbd8 | ||
![]() |
93bcdfd9c9 | ||
![]() |
5be3b101a5 | ||
![]() |
024c7476c7 | ||
![]() |
30a7ffe93d | ||
![]() |
e2d803ebf7 | ||
![]() |
be7e67c940 | ||
![]() |
ead4b13ba5 | ||
![]() |
e02c42ee18 | ||
![]() |
d39886fdf8 | ||
![]() |
11a425f1de | ||
![]() |
f0e194e584 | ||
![]() |
d4b9331cf2 | ||
![]() |
37e1acc5f1 | ||
![]() |
ffaf6a577d | ||
![]() |
afdaf6ba39 | ||
![]() |
4c49367910 | ||
![]() |
a506c4411d | ||
![]() |
1859c9854e | ||
![]() |
6ff29b9ae6 | ||
![]() |
3578f6b849 | ||
![]() |
0347864fde | ||
![]() |
5f9786a2c7 | ||
![]() |
75aeff1898 | ||
![]() |
0afcdce6d3 | ||
![]() |
a591d0ea87 | ||
![]() |
0e111a3532 | ||
![]() |
b599466ffa | ||
![]() |
69727e78df | ||
![]() |
02ae67b147 | ||
![]() |
a769f78801 | ||
![]() |
d583e42428 | ||
![]() |
da732becb6 | ||
![]() |
b89a4d58d9 | ||
![]() |
09854147d1 | ||
![]() |
3648c2bfe3 | ||
![]() |
3f3ee032f6 | ||
![]() |
68e5d54331 | ||
![]() |
824c434b0b | ||
![]() |
9f0e0ca656 | ||
![]() |
95f89ba03e | ||
![]() |
697f72ecf4 | ||
![]() |
4f03f2ab51 | ||
![]() |
c81531cb7a | ||
![]() |
7b6e4aa153 | ||
![]() |
f21039d19d | ||
![]() |
8c936a91be | ||
![]() |
24451892ff | ||
![]() |
6bba2c82fe | ||
![]() |
3320dc6bc4 | ||
![]() |
9d42fd9293 | ||
![]() |
e6b806616f | ||
![]() |
6ec5872391 | ||
![]() |
a26cf932a1 | ||
![]() |
38a3e3ab9f | ||
![]() |
32b17c1418 | ||
![]() |
44aa6a1579 | ||
![]() |
2369aacd2a | ||
![]() |
7dafc6364b | ||
![]() |
3d25fa0aeb | ||
![]() |
e2c5d843df | ||
![]() |
557ea55ddf | ||
![]() |
1591a4edd2 | ||
![]() |
b30b5024a8 | ||
![]() |
8ef2bd3b8d | ||
![]() |
0297b0f296 | ||
![]() |
4c7d09c3d8 | ||
![]() |
48a74826e8 | ||
![]() |
ef34068ac4 | ||
![]() |
3987a8db77 | ||
![]() |
c413ab030b | ||
![]() |
0f39007f92 | ||
![]() |
ab811daba7 | ||
![]() |
1428bf8ffa | ||
![]() |
53f7f38e23 | ||
![]() |
ce6ad9e0d3 | ||
![]() |
17a0c6123a | ||
![]() |
10edc5a8ad | ||
![]() |
bdf07d6bd5 | ||
![]() |
10ff65e71a | ||
![]() |
9395097fda | ||
![]() |
47eb0e00e3 | ||
![]() |
57d5f34ac5 | ||
![]() |
06b040412a | ||
![]() |
cab040c74a | ||
![]() |
21706a7d15 | ||
![]() |
22e4b8aaeb | ||
![]() |
bd43a6021a | ||
![]() |
a90b58b6db | ||
![]() |
92a9b096ec | ||
![]() |
7a6aa99840 | ||
![]() |
5657f0d793 | ||
![]() |
798529007e | ||
![]() |
953c5a5b5b | ||
![]() |
4313265c00 | ||
![]() |
9405f267ba | ||
![]() |
1d29238199 | ||
![]() |
c5bf66f462 | ||
![]() |
e6180bdfaa | ||
![]() |
55c391afc8 | ||
![]() |
782fa67320 | ||
![]() |
1e3ab75bb7 | ||
![]() |
5f6dd12a73 | ||
![]() |
d18c06d2c4 | ||
![]() |
baf99a9cfe | ||
![]() |
159931a6ea | ||
![]() |
7831f2925b | ||
![]() |
8fcb7840de | ||
![]() |
9ece9461dc | ||
![]() |
b304acaaba | ||
![]() |
5a1960609a | ||
![]() |
476aa6e3aa | ||
![]() |
aa76007fd0 | ||
![]() |
17a8813c4b | ||
![]() |
fe79fc9003 | ||
![]() |
ac8649ac18 | ||
![]() |
817db026b1 | ||
![]() |
01ef97949b | ||
![]() |
9e151051a8 | ||
![]() |
0feab23eb6 | ||
![]() |
8957f83939 | ||
![]() |
3bf2bc94f3 | ||
![]() |
8c3d5f1f4b | ||
![]() |
124e6e0811 | ||
![]() |
54d9d17d14 | ||
![]() |
62bdb7fb6d | ||
![]() |
af6574fdf1 | ||
![]() |
115a993cd2 | ||
![]() |
188b6c2fe5 | ||
![]() |
99adb2ceda | ||
![]() |
6344a3bcef | ||
![]() |
f62c17de0b | ||
![]() |
9d269b8111 | ||
![]() |
49b26a9640 | ||
![]() |
dddb79eeb2 | ||
![]() |
b0909ecb98 | ||
![]() |
ec63ce0532 | ||
![]() |
1eb03e3afb | ||
![]() |
26d906f1b7 | ||
![]() |
af9ceac0b4 | ||
![]() |
911159a14f | ||
![]() |
6a639e4ac9 | ||
![]() |
c4a6c86a69 | ||
![]() |
d2bac9d8d1 | ||
![]() |
758aa50550 | ||
![]() |
1af887cee7 | ||
![]() |
34b115c694 | ||
![]() |
8e4935409f | ||
![]() |
ca32d221c4 | ||
![]() |
e2de1fe038 | ||
![]() |
80179062db | ||
![]() |
7143620d25 | ||
![]() |
a0e51e2a7e | ||
![]() |
53dbd01cb1 | ||
![]() |
3607c16fd1 | ||
![]() |
4dfdd01295 | ||
![]() |
8983a3c581 | ||
![]() |
9cddef9108 | ||
![]() |
3dbea953a7 | ||
![]() |
962bbc04b5 | ||
![]() |
0804026d74 | ||
![]() |
879aa1f9f8 | ||
![]() |
9ffe2c14df | ||
![]() |
f0d2f07193 | ||
![]() |
ccf5928262 | ||
![]() |
b2f8634008 | ||
![]() |
43dba351c3 | ||
![]() |
b95478b635 | ||
![]() |
523f8a8951 | ||
![]() |
0f71924d06 | ||
![]() |
6d1bfc0be0 | ||
![]() |
b0f53268f6 | ||
![]() |
75f5db23df | ||
![]() |
85141812d9 | ||
![]() |
8819ddefa7 | ||
![]() |
b693c12500 | ||
![]() |
cbe3db8187 | ||
![]() |
7bccbc9471 | ||
![]() |
a452520f1a | ||
![]() |
a331b34b49 | ||
![]() |
8d6f0f8e9e | ||
![]() |
47dd5a1949 | ||
![]() |
387f8fd44c | ||
![]() |
b69b1f6f67 | ||
![]() |
d1427ffd54 | ||
![]() |
00c876dd93 | ||
![]() |
9d1aa9e59a | ||
![]() |
aceebba99a | ||
![]() |
7d6a8c4607 | ||
![]() |
5fd90355ae | ||
![]() |
9b01a2a4da | ||
![]() |
a2986d70a0 | ||
![]() |
5dfa38ca99 | ||
![]() |
157c6812cc | ||
![]() |
215ff4b74a | ||
![]() |
ca7b8b865a | ||
![]() |
fd0b12f6a1 | ||
![]() |
2f3b739f9e | ||
![]() |
3255ddca63 | ||
![]() |
b5460712e6 | ||
![]() |
6f7dcc2b6e | ||
![]() |
70d4800cb1 | ||
![]() |
a8b85cdb0d | ||
![]() |
fe10523972 | ||
![]() |
c975a56245 | ||
![]() |
d070e976b0 | ||
![]() |
0caf6bfabb | ||
![]() |
b842d7938f | ||
![]() |
cebbf84375 | ||
![]() |
8608431490 | ||
![]() |
78ba18b176 | ||
![]() |
f8c30c8526 | ||
![]() |
693c9b85a5 | ||
![]() |
70bb7defd1 | ||
![]() |
160377ca31 | ||
![]() |
2c0ce77a4e | ||
![]() |
77fbb0c9da | ||
![]() |
5971425d23 | ||
![]() |
aefff5c861 | ||
![]() |
a296b5e645 | ||
![]() |
eb486a3a07 | ||
![]() |
062b8521ba | ||
![]() |
1b07f3195a | ||
![]() |
dfa7d4cb8d | ||
![]() |
a14dd9666c | ||
![]() |
b07bd4374f | ||
![]() |
b4e12b0ea8 | ||
![]() |
ee5c17bb85 | ||
![]() |
16c9d3400c | ||
![]() |
4dd994348d | ||
![]() |
f0cbfafc24 | ||
![]() |
d3f38f5488 | ||
![]() |
737090a67a | ||
![]() |
4f66a4d090 | ||
![]() |
df54f909c1 | ||
![]() |
772b195eca | ||
![]() |
87866e34ed | ||
![]() |
c98ac05097 | ||
![]() |
36f991b6f9 | ||
![]() |
a81c5164fc | ||
![]() |
5942482690 | ||
![]() |
4f538ca2fc | ||
![]() |
9f2281a3e2 | ||
![]() |
b0d2f28c78 | ||
![]() |
d4380a4426 | ||
![]() |
ae2738d4cc | ||
![]() |
aa5ae028b2 | ||
![]() |
7ab8c76aa0 | ||
![]() |
8075b65e14 | ||
![]() |
073ce3bf1b | ||
![]() |
80fcbfe01b | ||
![]() |
dba0041e5f | ||
![]() |
b8a44afd25 | ||
![]() |
e2445bf585 | ||
![]() |
50706c524e | ||
![]() |
11e0cb9398 | ||
![]() |
1e82e40802 | ||
![]() |
ff00644e62 | ||
![]() |
97bcd3792b | ||
![]() |
5738a09771 | ||
![]() |
c461cc4878 | ||
![]() |
878fab347a | ||
![]() |
354b331b08 | ||
![]() |
3b9aadb90f | ||
![]() |
7193d018ce | ||
![]() |
d5cea034ac | ||
![]() |
a2760c10b3 | ||
![]() |
5492fae213 | ||
![]() |
490a23ae0a | ||
![]() |
3593cf3808 | ||
![]() |
6ea7400ff4 | ||
![]() |
1a4ba35ef4 | ||
![]() |
2d52cab693 | ||
![]() |
e1fac78aba | ||
![]() |
e79fc9cae4 | ||
![]() |
9200e1011b | ||
![]() |
373d29eeab | ||
![]() |
bc337c588a | ||
![]() |
112b05f7ad | ||
![]() |
9f84af95f6 | ||
![]() |
0873cfa997 | ||
![]() |
94d7162782 | ||
![]() |
5db62679fa | ||
![]() |
a4a0102679 | ||
![]() |
2afcfbb4bc | ||
![]() |
f0e8f070a8 | ||
![]() |
c42374e031 | ||
![]() |
be610c7fa9 | ||
![]() |
4ff824663b | ||
![]() |
1581b5ac0a | ||
![]() |
5fb48ed54b | ||
![]() |
903e9e6093 | ||
![]() |
d30e491817 | ||
![]() |
aa727e3260 | ||
![]() |
1cad3a7149 | ||
![]() |
3b7f6740bb | ||
![]() |
2febc5efad | ||
![]() |
903616bef6 | ||
![]() |
c944193fb4 | ||
![]() |
4f2155ea63 | ||
![]() |
4bda1edda7 | ||
![]() |
1a55cc8604 | ||
![]() |
bf7ab475ee | ||
![]() |
2f39efb935 | ||
![]() |
9f8eb985e4 | ||
![]() |
3549fef71c | ||
![]() |
2cfa64c2a3 | ||
![]() |
7245a0a599 | ||
![]() |
0633da3244 | ||
![]() |
96341976f5 | ||
![]() |
9abfaec4d5 | ||
![]() |
945c52dd6b | ||
![]() |
6567d24760 | ||
![]() |
ffaf9b6e0c | ||
![]() |
463e6908b1 | ||
![]() |
e185ceb385 | ||
![]() |
1b21bbe5b7 | ||
![]() |
14b7053ed8 | ||
![]() |
2760526def | ||
![]() |
d851db22d0 | ||
![]() |
2fa360e400 | ||
![]() |
e4eb146169 | ||
![]() |
86611453b5 | ||
![]() |
65f9d1b6b9 | ||
![]() |
2fceaf2cf4 | ||
![]() |
d82b50fcdb | ||
![]() |
ab6e49bf4f | ||
![]() |
ee90422f56 | ||
![]() |
627184f124 | ||
![]() |
fa02edfefc | ||
![]() |
61afebc827 | ||
![]() |
a4c22799e7 | ||
![]() |
870a110a75 | ||
![]() |
8c859f9408 | ||
![]() |
0a36101da1 | ||
![]() |
c1bf063b12 | ||
![]() |
0da56a800d | ||
![]() |
4d2172d153 | ||
![]() |
d0fab0e1f1 | ||
![]() |
4cedbdbc60 | ||
![]() |
a82d34cbce | ||
![]() |
16d0c243c7 | ||
![]() |
855901bd9e | ||
![]() |
6be8a581d2 | ||
![]() |
655deb12c8 | ||
![]() |
31b1b9457b | ||
![]() |
c4394228f2 | ||
![]() |
98e6dbe141 | ||
![]() |
4fac1ef7c4 | ||
![]() |
034bc6a79e | ||
![]() |
94e64676af | ||
![]() |
3a638220af | ||
![]() |
0772308bf5 | ||
![]() |
9f5ea80731 | ||
![]() |
fb1f520096 | ||
![]() |
dd36609443 | ||
![]() |
4eace3fb7e | ||
![]() |
f13e93e2ce | ||
![]() |
da4f8ab529 | ||
![]() |
b6ff4ec992 | ||
![]() |
25f6cac69a | ||
![]() |
172a8934e3 | ||
![]() |
aead014bcf | ||
![]() |
59770c80db | ||
![]() |
6d6b77148d | ||
![]() |
c1e8f5765f | ||
![]() |
76e442940b | ||
![]() |
b2205097da | ||
![]() |
14886d42e8 | ||
![]() |
2f35403078 | ||
![]() |
961d55a1c6 | ||
![]() |
0fca0ef734 | ||
![]() |
cc3acd81bc | ||
![]() |
69a691c19e | ||
![]() |
e0a4f5c9c9 | ||
![]() |
cabf9b8fb8 | ||
![]() |
61e24da07d | ||
![]() |
648511dfad | ||
![]() |
dfc9efc31a | ||
![]() |
b58a22addc | ||
![]() |
e07a9eeda2 | ||
![]() |
f0de42fa63 | ||
![]() |
0121661ad0 | ||
![]() |
fb6e46bd69 | ||
![]() |
9bd041799b | ||
![]() |
9e191c4ed9 | ||
![]() |
794b4cf26a | ||
![]() |
2d8421943f | ||
![]() |
48dc2312d9 | ||
![]() |
cdf7a1adc4 | ||
![]() |
99ebd12081 | ||
![]() |
859337b5c1 | ||
![]() |
1e601559a0 | ||
![]() |
9314cba724 | ||
![]() |
25224f0308 | ||
![]() |
9a981d5373 | ||
![]() |
c7116361ab | ||
![]() |
1f17236c4f | ||
![]() |
67f415de35 | ||
![]() |
b890150817 | ||
![]() |
4de1fc49df | ||
![]() |
fb80d5d70d | ||
![]() |
eaa25e412a | ||
![]() |
706142f98e | ||
![]() |
36a72d0a32 | ||
![]() |
1d44d387ac | ||
![]() |
f93c41f2d8 | ||
![]() |
5b13f880c8 | ||
![]() |
c4af873036 | ||
![]() |
fe820fb4fe | ||
![]() |
82ad0735d2 | ||
![]() |
8b0a421924 | ||
![]() |
d44cb3d92e | ||
![]() |
5f335ef5b3 | ||
![]() |
5831bf9653 | ||
![]() |
2480dfbb6d | ||
![]() |
162b352ea5 | ||
![]() |
9f30d7d7ba | ||
![]() |
27c296bb89 | ||
![]() |
ef67908451 | ||
![]() |
3dedc3bfc7 | ||
![]() |
65d509c97f | ||
![]() |
11f38c4d3a | ||
![]() |
3bca6497f7 | ||
![]() |
23d79b9265 | ||
![]() |
12c53a3d4d | ||
![]() |
1dfe58ec02 | ||
![]() |
7615e62bbc | ||
![]() |
53189a6487 | ||
![]() |
027b11c3fb | ||
![]() |
453ab7de66 | ||
![]() |
58f8ded161 | ||
![]() |
497ce2e84f | ||
![]() |
3794c6f508 | ||
![]() |
ee6c9fa5d4 | ||
![]() |
1369bb095f | ||
![]() |
c786d7549a | ||
![]() |
b59840cb77 | ||
![]() |
265d57d8b7 | ||
![]() |
5eed84f9e5 | ||
![]() |
0a334dff1d | ||
![]() |
5fff9bdc02 | ||
![]() |
a9fd261bab | ||
![]() |
ef087be4f0 | ||
![]() |
2099978b8f | ||
![]() |
712bee297a | ||
![]() |
57bba90091 | ||
![]() |
d877f5c764 | ||
![]() |
4c66cc1e33 | ||
![]() |
27a3edeb93 | ||
![]() |
f79fc29203 | ||
![]() |
174240a220 | ||
![]() |
60d8af5c16 | ||
![]() |
627a5892f1 | ||
![]() |
7767f6d9cc | ||
![]() |
9729fd6b15 | ||
![]() |
17916f29f6 | ||
![]() |
584b9323ec | ||
![]() |
82c1aadfa9 | ||
![]() |
bd497af89b | ||
![]() |
1683c5630a | ||
![]() |
b5df1a026a | ||
![]() |
b290c32aeb | ||
![]() |
a29b3c6db4 | ||
![]() |
ffb2f4f5db | ||
![]() |
24c95f4801 | ||
![]() |
1aaec2d555 | ||
![]() |
fedb198ae7 | ||
![]() |
add654ccac | ||
![]() |
5a578643a6 | ||
![]() |
f0712bd213 | ||
![]() |
f490632722 | ||
![]() |
2610b96762 | ||
![]() |
8d90cb834d | ||
![]() |
9d92509796 | ||
![]() |
04a78ee0ba | ||
![]() |
3703390268 | ||
![]() |
4ab6415f49 | ||
![]() |
9228722147 | ||
![]() |
0e5529b4ca | ||
![]() |
4d454ec932 | ||
![]() |
a9282ad118 | ||
![]() |
0e959641af | ||
![]() |
13263eea76 | ||
![]() |
1a3418de58 | ||
![]() |
4402995132 | ||
![]() |
4e33f9875b | ||
![]() |
ed2893e37f | ||
![]() |
c35be241ca | ||
![]() |
aad0b4ddfe | ||
![]() |
52f5c7ddb5 | ||
![]() |
a04b933161 | ||
![]() |
c77e12edbb | ||
![]() |
108bd04cf8 | ||
![]() |
a95b500e42 | ||
![]() |
c2744c5569 | ||
![]() |
a1dfd87bbe | ||
![]() |
221aa8687f | ||
![]() |
fa8ac0a8ba | ||
![]() |
cc1f9873cb | ||
![]() |
3cae9ee5d2 | ||
![]() |
f764914adb | ||
![]() |
991250c73f | ||
![]() |
af46cf5ce8 | ||
![]() |
dbb1c42c47 | ||
![]() |
991f593b2e | ||
![]() |
e43c083d50 | ||
![]() |
3cd9bdc1d4 | ||
![]() |
c0b8e6178d | ||
![]() |
410f9d0af5 | ||
![]() |
b1fedf28dc | ||
![]() |
b0df03dcd2 | ||
![]() |
2794e50a19 | ||
![]() |
365ae656f2 | ||
![]() |
98649dcba6 | ||
![]() |
213c8096d2 | ||
![]() |
398938f27e | ||
![]() |
6378e62645 | ||
![]() |
251885d4be | ||
![]() |
f53909355f | ||
![]() |
242b68889a | ||
![]() |
6a66b65f2a | ||
![]() |
f30ead6bcb | ||
![]() |
237ee72ca6 | ||
![]() |
3590d84ad6 | ||
![]() |
2dae8c162d | ||
![]() |
9a192b708e | ||
![]() |
c193f9334f | ||
![]() |
6e682dc752 | ||
![]() |
da86fe56bd | ||
![]() |
45865d701a | ||
![]() |
a66a31b474 | ||
![]() |
2661e7102f | ||
![]() |
224965b91e | ||
![]() |
a9c7375534 | ||
![]() |
e77f7ee0bf | ||
![]() |
ae5dd0cad6 | ||
![]() |
a128907a4e | ||
![]() |
d6453a8ed0 | ||
![]() |
dd1e8240b8 | ||
![]() |
b12f39916f | ||
![]() |
aae88fe1ad | ||
![]() |
83bb400df1 | ||
![]() |
8ea8067788 | ||
![]() |
9fbc9d59f5 | ||
![]() |
b96ba69a72 | ||
![]() |
c4ccab6a5d | ||
![]() |
f84f27bb56 | ||
![]() |
416cc0ffa9 | ||
![]() |
1fd5ec4db6 | ||
![]() |
4795c35c68 | ||
![]() |
25ce63b86d | ||
![]() |
5271033d34 | ||
![]() |
6ba8f33399 | ||
![]() |
7ab79bd815 | ||
![]() |
04a0a847c7 | ||
![]() |
436fa9af69 | ||
![]() |
ca0bbb0f08 | ||
![]() |
88996144a5 | ||
![]() |
44d5eee99e | ||
![]() |
0d1ff6074f | ||
![]() |
d63757634a | ||
![]() |
fd61cf3388 | ||
![]() |
a6a6b63e5a | ||
![]() |
c02c2def29 | ||
![]() |
ff66548462 | ||
![]() |
c9f292e252 | ||
![]() |
18cef5f3bd | ||
![]() |
e19340f1e0 | ||
![]() |
feb613cb6d | ||
![]() |
afa6bdfa44 | ||
![]() |
200e6d9905 | ||
![]() |
70772c49bd | ||
![]() |
762ea97e8b | ||
![]() |
8156b8b356 | ||
![]() |
3a2cbae0a0 | ||
![]() |
0ad8da097b | ||
![]() |
e2dcdd2811 | ||
![]() |
8074f9146b | ||
![]() |
df24bac913 | ||
![]() |
4d4091adcc | ||
![]() |
cac54c41a1 | ||
![]() |
130931d7af | ||
![]() |
d35b08b35e | ||
![]() |
82031da6a6 | ||
![]() |
9df5ee7b11 | ||
![]() |
2ed1a57cd9 | ||
![]() |
101450cba6 | ||
![]() |
6bab5b3f7c | ||
![]() |
ca3c0e00a7 | ||
![]() |
6d64daf324 | ||
![]() |
9ae4578e19 | ||
![]() |
e06b7ab87a | ||
![]() |
1e2adedcbf | ||
![]() |
adf763c1b0 | ||
![]() |
36ee0df256 | ||
![]() |
823d85b24a | ||
![]() |
a3b3038709 | ||
![]() |
ddeb18f626 | ||
![]() |
90cd11bd38 | ||
![]() |
e9ba37b8de | ||
![]() |
d5e4a1b1ad | ||
![]() |
129e6d60e5 | ||
![]() |
4b77f2f590 | ||
![]() |
a909966562 | ||
![]() |
fd184239d6 | ||
![]() |
52bc49dc6a | ||
![]() |
b9352ccc06 | ||
![]() |
525b2baf06 | ||
![]() |
a8edeb2459 | ||
![]() |
e3830d64e0 | ||
![]() |
91f3e2c2b4 | ||
![]() |
77b4408416 | ||
![]() |
cede96f018 | ||
![]() |
8e0a28d238 | ||
![]() |
da5d594428 | ||
![]() |
9f9ee0bb58 | ||
![]() |
163aca6179 | ||
![]() |
cb06d3b0ae | ||
![]() |
dbe18dd100 | ||
![]() |
217970667a | ||
![]() |
dace794167 | ||
![]() |
590780a539 | ||
![]() |
cbd1f47e87 | ||
![]() |
f89cff4e4a | ||
![]() |
cb08e0bf9f | ||
![]() |
3b54b29a99 | ||
![]() |
25983e046c | ||
![]() |
a6a124d2e6 | ||
![]() |
c7e1d30553 | ||
![]() |
6cc8c45634 | ||
![]() |
ee9a9114b7 | ||
![]() |
11f00f866c | ||
![]() |
03ea61ba81 | ||
![]() |
f6c500c998 | ||
![]() |
b590f0f98f | ||
![]() |
ef9359b208 | ||
![]() |
efd243a340 | ||
![]() |
bafb8b86db | ||
![]() |
84b701747f | ||
![]() |
ec42446daa | ||
![]() |
5046c4c911 | ||
![]() |
ce8c9906cb | ||
![]() |
6fb5482bba | ||
![]() |
58189963f5 | ||
![]() |
f488a71304 | ||
![]() |
4b706e004d | ||
![]() |
40e10cc270 | ||
![]() |
41db227eb3 | ||
![]() |
43eea965c5 | ||
![]() |
8101c9f0bc | ||
![]() |
b4cda90338 | ||
![]() |
7ca37c412e | ||
![]() |
e4e3356dc9 | ||
![]() |
0deaa03218 | ||
![]() |
a7104c41a2 | ||
![]() |
5176b8c322 | ||
![]() |
c37c70446d | ||
![]() |
63abc8a2c8 | ||
![]() |
ba5c038e3b | ||
![]() |
a6669415f5 | ||
![]() |
4086fad867 | ||
![]() |
8a71c13078 | ||
![]() |
5d77f64e76 | ||
![]() |
0d092b977f | ||
![]() |
69582ff83d | ||
![]() |
a5c7da331a | ||
![]() |
8e842296b7 | ||
![]() |
7db14d1df7 | ||
![]() |
067ec2eb9c | ||
![]() |
2d332b32d9 | ||
![]() |
1d9ad2ba86 | ||
![]() |
a28e2177f7 | ||
![]() |
18fe0df691 | ||
![]() |
8e21a06d99 | ||
![]() |
2daf5473bb | ||
![]() |
928ff53adf | ||
![]() |
a71e95e6e5 | ||
![]() |
cb4a54b5cc | ||
![]() |
37e4524156 | ||
![]() |
9ac24ee051 | ||
![]() |
f28ccd559a | ||
![]() |
8e84a93d8e | ||
![]() |
d871dec1b7 | ||
![]() |
b133e1a197 | ||
![]() |
9346a037b9 | ||
![]() |
89facbcddd | ||
![]() |
53fef35638 | ||
![]() |
bfe496a09b | ||
![]() |
ff774c2e8e | ||
![]() |
08a6d1078c | ||
![]() |
e9bcc919bf | ||
![]() |
04f4693c85 | ||
![]() |
2a58a0a4c4 | ||
![]() |
d911843648 | ||
![]() |
c80d178410 | ||
![]() |
9fb4dca39b | ||
![]() |
0dd444d50b | ||
![]() |
f3bf418997 | ||
![]() |
676027245f | ||
![]() |
6c5039f1ba | ||
![]() |
807be59f25 | ||
![]() |
8e9896ec2e | ||
![]() |
110c2dbac8 | ||
![]() |
f55ec4bd8a | ||
![]() |
06c9bf420e | ||
![]() |
3c9bc53a79 | ||
![]() |
de7a35dfe9 | ||
![]() |
92638c2e97 | ||
![]() |
63251e6a9a | ||
![]() |
59844c33fd | ||
![]() |
d36dd2ece1 | ||
![]() |
1fdb94739b | ||
![]() |
8a18f4c44f | ||
![]() |
c9c47c5519 | ||
![]() |
6be8b55daa | ||
![]() |
f2dc2f5530 | ||
![]() |
42842e7aec | ||
![]() |
49d9f77d1b | ||
![]() |
d06a89564f | ||
![]() |
58a8510d49 | ||
![]() |
8055d6555e | ||
![]() |
39620d3510 | ||
![]() |
6d19711926 | ||
![]() |
0b362dd435 | ||
![]() |
9485731e7d | ||
![]() |
1449fb0f84 | ||
![]() |
e548dd49ca | ||
![]() |
337d22bbf4 | ||
![]() |
35863ee6e9 | ||
![]() |
0784a2d4d0 | ||
![]() |
75d5c0e356 | ||
![]() |
a2dd6d76a8 | ||
![]() |
bdc6b59857 | ||
![]() |
34e95f1e89 | ||
![]() |
6a92cfc573 | ||
![]() |
9f759d70b6 | ||
![]() |
43e957e8d3 | ||
![]() |
ae316f60e4 | ||
![]() |
1ac423ba56 | ||
![]() |
b43490dd76 | ||
![]() |
f586e81dd1 | ||
![]() |
8a6d8a7d8c | ||
![]() |
45d607f1a0 | ||
![]() |
d84abaa229 | ||
![]() |
3fd1d4d9b3 | ||
![]() |
078b8efb56 | ||
![]() |
5066995f72 | ||
![]() |
577fe3dba8 | ||
![]() |
d96f4999bc | ||
![]() |
6e80ff4eb6 | ||
![]() |
3f8f022d48 | ||
![]() |
93a2e2151e | ||
![]() |
663a1ed9d4 | ||
![]() |
4f46c55c85 | ||
![]() |
9701c98af9 | ||
![]() |
aabf2a1c79 | ||
![]() |
29539b090e | ||
![]() |
1c80677ac3 | ||
![]() |
ad419855e9 | ||
![]() |
30b75943f3 | ||
![]() |
41a67b402d | ||
![]() |
caa104b1cc | ||
![]() |
94085f2bc8 | ||
![]() |
d39c962314 | ||
![]() |
706fb0f063 | ||
![]() |
b9d89b040f | ||
![]() |
41421b849a | ||
![]() |
324375da93 | ||
![]() |
536446faf6 | ||
![]() |
d026ac09f3 | ||
![]() |
88c93ac992 | ||
![]() |
d540322d8b | ||
![]() |
ad4db5e936 | ||
![]() |
25cb4d90f3 | ||
![]() |
6c14a353ef | ||
![]() |
74d7d1aa98 | ||
![]() |
43b0d9ed29 | ||
![]() |
3572e6f65a | ||
![]() |
d23d5d2da0 | ||
![]() |
183b9b0d88 | ||
![]() |
7a1af268ae | ||
![]() |
f879b3c5b0 | ||
![]() |
40be72cf65 | ||
![]() |
a8886571d1 | ||
![]() |
1fcd51ea26 | ||
![]() |
89752138be | ||
![]() |
f29ccace2a | ||
![]() |
0c8343e76f | ||
![]() |
9776c9f5a4 | ||
![]() |
a5dbac9817 | ||
![]() |
bad5e0b855 | ||
![]() |
8e4ca55560 | ||
![]() |
f52afc1fe0 | ||
![]() |
815e64302e | ||
![]() |
07b2b18a4e | ||
![]() |
69eca33de7 | ||
![]() |
ec76a480d0 | ||
![]() |
a8823c3ed0 | ||
![]() |
1f1b3a341c | ||
![]() |
8c164a3852 | ||
![]() |
dcf526d810 | ||
![]() |
2fc6d680a0 | ||
![]() |
f414972f33 | ||
![]() |
69d192d989 | ||
![]() |
6c8769e598 | ||
![]() |
c12703422c | ||
![]() |
c0171e1cd1 | ||
![]() |
920a983146 | ||
![]() |
7ec86bfef1 | ||
![]() |
d8bc318688 | ||
![]() |
600ea1848f | ||
![]() |
a3ce9c7662 | ||
![]() |
44ce7577c6 | ||
![]() |
8c3e42f7eb | ||
![]() |
b8887c506c | ||
![]() |
6c4228b7b8 | ||
![]() |
9b1da98386 | ||
![]() |
1615169a3d | ||
![]() |
df83aa4d15 | ||
![]() |
142b96beb0 | ||
![]() |
18d07dd3b9 | ||
![]() |
270039d211 | ||
![]() |
fcf3a480be | ||
![]() |
80ee974973 | ||
![]() |
48c6a38205 | ||
![]() |
c9536e58cb | ||
![]() |
a16d783302 | ||
![]() |
b837aecb27 | ||
![]() |
532405048f | ||
![]() |
6cd0427ff8 | ||
![]() |
d2163f180e | ||
![]() |
d1344457dd | ||
![]() |
596be24d92 | ||
![]() |
4e182b49f9 | ||
![]() |
51ac37f1de | ||
![]() |
b578e88d46 | ||
![]() |
9cb4607f69 | ||
![]() |
2c4d602028 | ||
![]() |
a0feb7f309 | ||
![]() |
77e29050c8 | ||
![]() |
df55f746ca | ||
![]() |
2739d2297f | ||
![]() |
dc734b04d8 | ||
![]() |
d4c542168c | ||
![]() |
94a3b66130 | ||
![]() |
c8baf9b0d7 | ||
![]() |
c4dc0509c2 | ||
![]() |
3bfc428dfe | ||
![]() |
026b7da6f8 | ||
![]() |
58352b9f33 | ||
![]() |
59faf593be | ||
![]() |
4aa41773c4 | ||
![]() |
20c5d6aee1 | ||
![]() |
d503dbc103 | ||
![]() |
53624a6379 | ||
![]() |
5b881db19f | ||
![]() |
dece070d28 | ||
![]() |
8be2ed0034 | ||
![]() |
37c6b57a48 | ||
![]() |
8a0b5c24a5 | ||
![]() |
20431da757 | ||
![]() |
f219c87a9e | ||
![]() |
5d2134db56 | ||
![]() |
1dc46dd31c | ||
![]() |
96250ce9a0 | ||
![]() |
691682e09c | ||
![]() |
814c504951 | ||
![]() |
5c2b96a812 | ||
![]() |
3dc1ca8adb | ||
![]() |
a6850f1bc0 | ||
![]() |
5ba6cb9135 | ||
![]() |
500283af6f | ||
![]() |
43184dccda | ||
![]() |
4296a3b5df | ||
![]() |
14ba50f061 | ||
![]() |
9ad7de56a3 | ||
![]() |
5570687957 | ||
![]() |
1406bf3e10 | ||
![]() |
287f299b94 | ||
![]() |
f88f05cd46 | ||
![]() |
c6fb42e2f3 | ||
![]() |
c64ca9d9b7 | ||
![]() |
7d47793afb | ||
![]() |
2840fce856 | ||
![]() |
2791dca412 | ||
![]() |
3e268bf66b | ||
![]() |
f44422a77e | ||
![]() |
4931cbcc34 | ||
![]() |
59e495f7d3 | ||
![]() |
93866d7bc2 | ||
![]() |
ba1cdeaeeb | ||
![]() |
234b27e555 | ||
![]() |
5acfd09819 | ||
![]() |
9923b15ecd | ||
![]() |
def5a6d9d0 | ||
![]() |
17c8a405f5 | ||
![]() |
ff874bfb48 | ||
![]() |
4cbb37b996 | ||
![]() |
f57e35c6b8 | ||
![]() |
312e786e33 | ||
![]() |
e2c75a2daf | ||
![]() |
fce20263ea | ||
![]() |
d841f9cb62 | ||
![]() |
4945240ec2 | ||
![]() |
f1cdc7e422 | ||
![]() |
372cdb10d6 | ||
![]() |
fd24dbee21 | ||
![]() |
7066f7ea76 | ||
![]() |
5ae53c79b6 | ||
![]() |
f3a8ab289f | ||
![]() |
a99609e3da | ||
![]() |
a271189448 | ||
![]() |
251bc28526 | ||
![]() |
05505704e4 | ||
![]() |
4aadcb021e | ||
![]() |
ae9da1b354 | ||
![]() |
a594029541 | ||
![]() |
ddcb894932 | ||
![]() |
708cdbe545 | ||
![]() |
1cbf96dff1 | ||
![]() |
bd55b37d5f | ||
![]() |
7c3a0effee | ||
![]() |
fe3048aab0 | ||
![]() |
9a5a3e879d | ||
![]() |
269902db94 | ||
![]() |
4ba67ea863 | ||
![]() |
3534712478 | ||
![]() |
62b9a8071a | ||
![]() |
cf83c27ca0 | ||
![]() |
8035f81f97 | ||
![]() |
d2375fdc54 | ||
![]() |
f07d9dd813 | ||
![]() |
b5524b18cf | ||
![]() |
310497a5bf | ||
![]() |
47a738d5e6 | ||
![]() |
6ad13c1da0 | ||
![]() |
99454fdc4b | ||
![]() |
799f0ead6c | ||
![]() |
d16d709b72 | ||
![]() |
8e1087b818 | ||
![]() |
139dcb521e | ||
![]() |
b17e431473 | ||
![]() |
b1ee3ef8ba | ||
![]() |
75bbd16b0c | ||
![]() |
71a7943d01 | ||
![]() |
d34785b5b0 | ||
![]() |
af58ef7244 | ||
![]() |
6d3bec8518 | ||
![]() |
0346b157c5 | ||
![]() |
e25aab742b | ||
![]() |
6f2ca00263 | ||
![]() |
e1d26325f3 | ||
![]() |
4202f963c3 | ||
![]() |
d3ef45db1b | ||
![]() |
dec55709a3 | ||
![]() |
b5ed984f05 | ||
![]() |
66d7baa126 | ||
![]() |
a2809a14c5 | ||
![]() |
040ad9edb0 | ||
![]() |
46dbe009f2 | ||
![]() |
3598d43938 | ||
![]() |
f1358c7ad1 | ||
![]() |
40862fcd01 | ||
![]() |
189432c228 | ||
![]() |
280d16f3d9 | ||
![]() |
722c39590f | ||
![]() |
b1138dbf05 | ||
![]() |
08918282a7 | ||
![]() |
5007b0bf1a | ||
![]() |
0a5912eb8e | ||
![]() |
8acd7b03ed | ||
![]() |
ed87df212f | ||
![]() |
56243aa076 | ||
![]() |
41e9f32e1b | ||
![]() |
f7753aa1b4 | ||
![]() |
aebfcc38dd | ||
![]() |
3e0149c058 | ||
![]() |
1e62e09825 | ||
![]() |
956b15a2eb | ||
![]() |
572b457b43 | ||
![]() |
7d40ae009f | ||
![]() |
aec9595dea | ||
![]() |
cc90f19a46 | ||
![]() |
ab486c8ed1 | ||
![]() |
bfb1e817ec | ||
![]() |
ebc7c22388 | ||
![]() |
10b4066c82 | ||
![]() |
42dd67954d | ||
![]() |
d45fdf605f | ||
![]() |
caef9bb8b5 | ||
![]() |
c888934601 | ||
![]() |
95613b595e | ||
![]() |
9247bd9d9e | ||
![]() |
ee3d2489e6 | ||
![]() |
7764c4fbcb | ||
![]() |
a18b524859 | ||
![]() |
9b8ec9b85e | ||
![]() |
7b3f070973 | ||
![]() |
ba27fc12e8 | ||
![]() |
db55912f78 | ||
![]() |
4c4bd267d4 | ||
![]() |
dc1002659b | ||
![]() |
97da370301 | ||
![]() |
571901f333 | ||
![]() |
4d90df9d9a | ||
![]() |
2c18667ffd | ||
![]() |
89157cd606 | ||
![]() |
37e0091ef0 | ||
![]() |
ae3512fecf | ||
![]() |
8b81391e2f | ||
![]() |
54e68f6252 | ||
![]() |
92d1ed65ff | ||
![]() |
8098a7ee5d | ||
![]() |
c24297630c | ||
![]() |
a9d5212602 | ||
![]() |
c81db8ae19 | ||
![]() |
ecd356d42b | ||
![]() |
e67adf87b2 | ||
![]() |
1669708041 | ||
![]() |
12e34013f8 | ||
![]() |
bd2ad1d7a1 | ||
![]() |
934cdb8237 | ||
![]() |
2f6ea8830e | ||
![]() |
b77d08ebbf | ||
![]() |
b735d32cbc | ||
![]() |
472ffd5b5c | ||
![]() |
4567ca8fce | ||
![]() |
07ed24ca7a | ||
![]() |
52575be2a7 | ||
![]() |
c8187e52bb | ||
![]() |
b0b6b72b4c | ||
![]() |
7676bc5836 | ||
![]() |
f98c1725be | ||
![]() |
c6bd599b63 | ||
![]() |
7908779c89 | ||
![]() |
29ad68afab | ||
![]() |
9aaeac6a08 | ||
![]() |
8f074c2131 | ||
![]() |
930653c86d | ||
![]() |
cc31b7c210 | ||
![]() |
bb19e9308c | ||
![]() |
5e7b4bfe45 | ||
![]() |
dbeeb61cc5 | ||
![]() |
26d8e5856a | ||
![]() |
66be6d1e89 | ||
![]() |
677aa232e7 | ||
![]() |
cabbb45031 | ||
![]() |
ba99df645b | ||
![]() |
282e5ba2d8 | ||
![]() |
42d418da58 | ||
![]() |
cbf270fdba | ||
![]() |
bb9abe104f | ||
![]() |
18f0d6dea3 | ||
![]() |
23dc9a1139 | ||
![]() |
5e18ef5830 | ||
![]() |
63f8fc266d | ||
![]() |
4e46b16f7b | ||
![]() |
ba19b50005 | ||
![]() |
fa867387d4 | ||
![]() |
5762cf5dc5 | ||
![]() |
7d9f624805 | ||
![]() |
5b335ccd59 | ||
![]() |
4792853eb6 | ||
![]() |
cc05bc7db8 | ||
![]() |
d198eaa988 | ||
![]() |
f094da6a4b | ||
![]() |
a53961b235 | ||
![]() |
f644113af8 | ||
![]() |
e4a903ec07 | ||
![]() |
9408fe2a07 | ||
![]() |
394e747a88 | ||
![]() |
e91f12729b | ||
![]() |
134e588b14 | ||
![]() |
d061eb7b58 | ||
![]() |
18089a8076 | ||
![]() |
02236e01d9 | ||
![]() |
c1150d50b1 | ||
![]() |
387a849269 | ||
![]() |
399cebda70 | ||
![]() |
72720b3dfe | ||
![]() |
64f7560b3b | ||
![]() |
e06b646f49 | ||
![]() |
b51d9bb17b | ||
![]() |
4e967c5720 | ||
![]() |
179db38fd1 | ||
![]() |
e51930d7e1 | ||
![]() |
74a299dbe6 | ||
![]() |
282863c526 | ||
![]() |
63d794ed3e | ||
![]() |
c6b8f12f9a | ||
![]() |
d16e292231 | ||
![]() |
29a319a850 | ||
![]() |
c11e0db077 | ||
![]() |
b2dafb5dfa | ||
![]() |
e7ccd01427 | ||
![]() |
447f26458a | ||
![]() |
61fb71a080 | ||
![]() |
329fcdf8f4 | ||
![]() |
37cdb34014 | ||
![]() |
5ee7b85cc4 | ||
![]() |
1f7228f95a | ||
![]() |
fa8418adcd | ||
![]() |
d3b1765ffe | ||
![]() |
0a274ebadb | ||
![]() |
0d1b35edc5 | ||
![]() |
d7e4ae53ce | ||
![]() |
61ceffc6f9 | ||
![]() |
0c422bfd21 | ||
![]() |
a0815b06a6 | ||
![]() |
bd02b7574a | ||
![]() |
1048d923d0 | ||
![]() |
9dbfcf4262 | ||
![]() |
8ea176b5f0 | ||
![]() |
90dcbadc52 | ||
![]() |
e4021bf830 | ||
![]() |
b8b453aba0 | ||
![]() |
aeec2377c1 | ||
![]() |
f8b0ffd39b | ||
![]() |
9953c3c823 | ||
![]() |
d227a07fe9 | ||
![]() |
7c394414d8 | ||
![]() |
1dfb22d02e | ||
![]() |
1847ad5622 | ||
![]() |
beb701ceb4 | ||
![]() |
2fbadea821 | ||
![]() |
bac561d8c7 | ||
![]() |
7bd261a02e | ||
![]() |
df99a889f0 | ||
![]() |
16c5892a1d | ||
![]() |
0236bbaf68 | ||
![]() |
2ca5a290c3 | ||
![]() |
66c388a644 | ||
![]() |
74a77ed271 | ||
![]() |
3d98e6cdc0 | ||
![]() |
831ae96e0f | ||
![]() |
113a91a73f |
@@ -5,13 +5,14 @@ BACKEND_PORT=3000
|
|||||||
WEB_PORT=3001
|
WEB_PORT=3001
|
||||||
|
|
||||||
echo "Configuring backend environment variables..."
|
echo "Configuring backend environment variables..."
|
||||||
|
|
||||||
cd packages/backend
|
cd packages/backend
|
||||||
|
|
||||||
rm -rf .env
|
rm -rf .env
|
||||||
|
|
||||||
echo "
|
echo "
|
||||||
HOST=localhost
|
|
||||||
PROTOCOL=http
|
|
||||||
PORT=$BACKEND_PORT
|
PORT=$BACKEND_PORT
|
||||||
WEB_APP_URL=https://$CODESPACE_NAME-$WEB_PORT.$GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN
|
WEB_APP_URL=http://localhost:$WEB_PORT
|
||||||
APP_ENV=development
|
APP_ENV=development
|
||||||
POSTGRES_DATABASE=automatisch
|
POSTGRES_DATABASE=automatisch
|
||||||
POSTGRES_PORT=5432
|
POSTGRES_PORT=5432
|
||||||
@@ -23,25 +24,34 @@ WEBHOOK_SECRET_KEY=sample_webhook_secret_key
|
|||||||
APP_SECRET_KEY=sample_app_secret_key
|
APP_SECRET_KEY=sample_app_secret_key
|
||||||
REDIS_HOST=redis
|
REDIS_HOST=redis
|
||||||
SERVE_WEB_APP_SEPARATELY=true" >> .env
|
SERVE_WEB_APP_SEPARATELY=true" >> .env
|
||||||
|
|
||||||
|
echo "Installing backend dependencies..."
|
||||||
|
|
||||||
|
yarn
|
||||||
|
|
||||||
cd $CURRENT_DIR
|
cd $CURRENT_DIR
|
||||||
|
|
||||||
echo "Configuring web environment variables..."
|
echo "Configuring web environment variables..."
|
||||||
|
|
||||||
cd packages/web
|
cd packages/web
|
||||||
|
|
||||||
rm -rf .env
|
rm -rf .env
|
||||||
|
|
||||||
echo "
|
echo "
|
||||||
PORT=$WEB_PORT
|
PORT=$WEB_PORT
|
||||||
REACT_APP_GRAPHQL_URL=https://$CODESPACE_NAME-$BACKEND_PORT.$GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN/graphql
|
REACT_APP_BACKEND_URL=http://localhost:$BACKEND_PORT
|
||||||
REACT_APP_BASE_URL=https://$CODESPACE_NAME-$WEB_PORT.$GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN
|
|
||||||
REACT_APP_NOTIFICATIONS_URL=https://notifications.automatisch.io
|
|
||||||
" >> .env
|
" >> .env
|
||||||
|
|
||||||
|
echo "Installing web dependencies..."
|
||||||
|
|
||||||
|
yarn
|
||||||
|
|
||||||
cd $CURRENT_DIR
|
cd $CURRENT_DIR
|
||||||
|
|
||||||
echo "Installing and linking dependencies..."
|
|
||||||
yarn
|
|
||||||
yarn lerna bootstrap
|
|
||||||
|
|
||||||
echo "Migrating database..."
|
echo "Migrating database..."
|
||||||
|
|
||||||
cd packages/backend
|
cd packages/backend
|
||||||
|
|
||||||
yarn db:migrate
|
yarn db:migrate
|
||||||
yarn db:seed:user
|
yarn db:seed:user
|
||||||
|
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
"version": "latest"
|
"version": "latest"
|
||||||
},
|
},
|
||||||
"ghcr.io/devcontainers/features/node:1": {
|
"ghcr.io/devcontainers/features/node:1": {
|
||||||
"version": 16
|
"version": 18
|
||||||
},
|
},
|
||||||
"ghcr.io/devcontainers/features/common-utils:1": {
|
"ghcr.io/devcontainers/features/common-utils:1": {
|
||||||
"username": "vscode",
|
"username": "vscode",
|
||||||
|
@@ -21,11 +21,43 @@ services:
|
|||||||
interval: 10s
|
interval: 10s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 5
|
||||||
|
ports:
|
||||||
|
- '5432:5432'
|
||||||
|
expose:
|
||||||
|
- 5432
|
||||||
redis:
|
redis:
|
||||||
image: 'redis:7.0.4-alpine'
|
image: 'redis:7.0.4-alpine'
|
||||||
volumes:
|
volumes:
|
||||||
- redis_data:/data
|
- redis_data:/data
|
||||||
|
ports:
|
||||||
|
- '6379:6379'
|
||||||
|
expose:
|
||||||
|
- 6379
|
||||||
|
keycloak:
|
||||||
|
image: quay.io/keycloak/keycloak:21.1
|
||||||
|
restart: always
|
||||||
|
environment:
|
||||||
|
- KEYCLOAK_ADMIN=admin
|
||||||
|
- KEYCLOAK_ADMIN_PASSWORD=admin
|
||||||
|
- KC_DB=postgres
|
||||||
|
- KC_DB_URL_HOST=postgres
|
||||||
|
- KC_DB_URL_DATABASE=keycloak
|
||||||
|
- KC_DB_USERNAME=automatisch_user
|
||||||
|
- KC_DB_PASSWORD=automatisch_password
|
||||||
|
- KC_HEALTH_ENABLED=true
|
||||||
|
ports:
|
||||||
|
- "8080:8080"
|
||||||
|
command: start-dev
|
||||||
|
depends_on:
|
||||||
|
- postgres
|
||||||
|
healthcheck:
|
||||||
|
test: "curl -f http://localhost:8080/health/ready || exit 1"
|
||||||
|
volumes:
|
||||||
|
- keycloak:/opt/keycloak/data/
|
||||||
|
expose:
|
||||||
|
- 8080
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
postgres_data:
|
postgres_data:
|
||||||
redis_data:
|
redis_data:
|
||||||
|
keycloak:
|
||||||
|
12
.dockerignore
Normal file
12
.dockerignore
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
**/node_modules/
|
||||||
|
**/dist/
|
||||||
|
**/logs/
|
||||||
|
**/.devcontainer
|
||||||
|
**/.github
|
||||||
|
**/.vscode
|
||||||
|
**/.env
|
||||||
|
**/.env.test
|
||||||
|
**/.env.production
|
||||||
|
**/yarn-error.log
|
||||||
|
packages/docs
|
||||||
|
packages/e2e-test
|
10
.eslintrc.js
10
.eslintrc.js
@@ -1,10 +0,0 @@
|
|||||||
module.exports = {
|
|
||||||
root: true,
|
|
||||||
parser: '@typescript-eslint/parser',
|
|
||||||
plugins: ['@typescript-eslint'],
|
|
||||||
extends: [
|
|
||||||
'eslint:recommended',
|
|
||||||
'plugin:@typescript-eslint/recommended',
|
|
||||||
'prettier',
|
|
||||||
],
|
|
||||||
};
|
|
51
.github/workflows/backend.yml
vendored
Normal file
51
.github/workflows/backend.yml
vendored
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
name: Automatisch Backend Tests
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
timeout-minutes: 60
|
||||||
|
runs-on:
|
||||||
|
- ubuntu-latest
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:14.5-alpine
|
||||||
|
env:
|
||||||
|
POSTGRES_DB: automatisch_test
|
||||||
|
POSTGRES_USER: automatisch_test_user
|
||||||
|
POSTGRES_PASSWORD: automatisch_test_user_password
|
||||||
|
options: >-
|
||||||
|
--health-cmd "pg_isready -U automatisch_test_user -d automatisch_test"
|
||||||
|
--health-interval 10s
|
||||||
|
--health-timeout 5s
|
||||||
|
--health-retries 5
|
||||||
|
ports:
|
||||||
|
- 5432:5432
|
||||||
|
redis:
|
||||||
|
image: redis:7.0.4-alpine
|
||||||
|
options: >-
|
||||||
|
--health-cmd "redis-cli ping"
|
||||||
|
--health-interval 10s
|
||||||
|
--health-timeout 5s
|
||||||
|
--health-retries 5
|
||||||
|
ports:
|
||||||
|
- 6379:6379
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 18
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yarn
|
||||||
|
working-directory: packages/backend
|
||||||
|
- name: Copy .env-example.test file to .env.test
|
||||||
|
run: cp .env-example.test .env.test
|
||||||
|
working-directory: packages/backend
|
||||||
|
- name: Run tests
|
||||||
|
run: yarn test:coverage
|
||||||
|
working-directory: packages/backend
|
79
.github/workflows/ci.yml
vendored
79
.github/workflows/ci.yml
vendored
@@ -1,5 +1,11 @@
|
|||||||
name: Automatisch CI
|
name: Automatisch CI
|
||||||
on: [push]
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
linter:
|
linter:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@@ -10,15 +16,17 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: actions/setup-node@v2
|
- uses: actions/setup-node@v2
|
||||||
with:
|
with:
|
||||||
node-version: '16'
|
node-version: '18'
|
||||||
cache: 'yarn'
|
cache: 'yarn'
|
||||||
cache-dependency-path: yarn.lock
|
cache-dependency-path: packages/backend/yarn.lock
|
||||||
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
||||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||||
- run: yarn --frozen-lockfile
|
- run: yarn --frozen-lockfile
|
||||||
|
working-directory: packages/backend
|
||||||
- run: yarn lint
|
- run: yarn lint
|
||||||
|
working-directory: packages/backend
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
build-backend:
|
start-backend-server:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event."
|
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event."
|
||||||
@@ -27,13 +35,40 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: actions/setup-node@v2
|
- uses: actions/setup-node@v2
|
||||||
with:
|
with:
|
||||||
node-version: '16'
|
node-version: '18'
|
||||||
cache: 'yarn'
|
cache: 'yarn'
|
||||||
cache-dependency-path: yarn.lock
|
cache-dependency-path: packages/backend/yarn.lock
|
||||||
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
||||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||||
- run: yarn --frozen-lockfile && yarn lerna bootstrap
|
- run: yarn --frozen-lockfile
|
||||||
- run: cd packages/backend && yarn build
|
working-directory: packages/backend
|
||||||
|
- run: yarn start
|
||||||
|
working-directory: packages/backend
|
||||||
|
env:
|
||||||
|
ENCRYPTION_KEY: sample_encryption_key
|
||||||
|
WEBHOOK_SECRET_KEY: sample_webhook_secret_key
|
||||||
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
|
start-backend-worker:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event."
|
||||||
|
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by GitHub!"
|
||||||
|
- run: echo "🔎 The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}."
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: actions/setup-node@v2
|
||||||
|
with:
|
||||||
|
node-version: '18'
|
||||||
|
cache: 'yarn'
|
||||||
|
cache-dependency-path: packages/backend/yarn.lock
|
||||||
|
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
||||||
|
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||||
|
- run: yarn --frozen-lockfile
|
||||||
|
working-directory: packages/backend
|
||||||
|
- run: yarn start:worker
|
||||||
|
working-directory: packages/backend
|
||||||
|
env:
|
||||||
|
ENCRYPTION_KEY: sample_encryption_key
|
||||||
|
WEBHOOK_SECRET_KEY: sample_webhook_secret_key
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
build-web:
|
build-web:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@@ -44,31 +79,15 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: actions/setup-node@v2
|
- uses: actions/setup-node@v2
|
||||||
with:
|
with:
|
||||||
node-version: '16'
|
node-version: '18'
|
||||||
cache: 'yarn'
|
cache: 'yarn'
|
||||||
cache-dependency-path: yarn.lock
|
cache-dependency-path: packages/web/yarn.lock
|
||||||
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
||||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||||
- run: yarn --frozen-lockfile && yarn lerna bootstrap
|
- run: yarn --frozen-lockfile
|
||||||
- run: cd packages/web && yarn build
|
working-directory: packages/web
|
||||||
|
- run: yarn build
|
||||||
|
working-directory: packages/web
|
||||||
env:
|
env:
|
||||||
CI: false
|
CI: false
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
build-cli:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event."
|
|
||||||
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by GitHub!"
|
|
||||||
- run: echo "🔎 The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}."
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- uses: actions/setup-node@v2
|
|
||||||
with:
|
|
||||||
node-version: '16'
|
|
||||||
cache: 'yarn'
|
|
||||||
cache-dependency-path: yarn.lock
|
|
||||||
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner."
|
|
||||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
|
||||||
- run: yarn --frozen-lockfile && yarn lerna bootstrap
|
|
||||||
- run: cd packages/backend && yarn build
|
|
||||||
- run: cd packages/cli && yarn build
|
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
|
||||||
|
32
.github/workflows/docs-change.yml
vendored
Normal file
32
.github/workflows/docs-change.yml
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
name: Automatisch Docs Change
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'packages/docs/**'
|
||||||
|
jobs:
|
||||||
|
label:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
- name: Label PR
|
||||||
|
uses: actions/github-script@v6
|
||||||
|
with:
|
||||||
|
script: |
|
||||||
|
const { pull_request } = context.payload;
|
||||||
|
|
||||||
|
const label = 'documentation-change';
|
||||||
|
const hasLabel = pull_request.labels.some(({ name }) => name === label);
|
||||||
|
|
||||||
|
if (!hasLabel) {
|
||||||
|
await github.rest.issues.addLabels({
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
issue_number: pull_request.number,
|
||||||
|
labels: [label],
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log(`Label "${label}" added to PR #${pull_request.number}`);
|
||||||
|
} else {
|
||||||
|
console.log(`Label "${label}" already exists on PR #${pull_request.number}`);
|
||||||
|
}
|
128
.github/workflows/playwright.yml
vendored
Normal file
128
.github/workflows/playwright.yml
vendored
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
name: Automatisch UI Tests
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
# TODO: Add pull request after optimizing the total excecution time of the test suite.
|
||||||
|
# pull_request:
|
||||||
|
# paths:
|
||||||
|
# - 'packages/backend/**'
|
||||||
|
# - 'packages/e2e-tests/**'
|
||||||
|
# - 'packages/web/**'
|
||||||
|
# - '!packages/backend/src/apps/**'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
env:
|
||||||
|
ENCRYPTION_KEY: sample_encryption_key
|
||||||
|
WEBHOOK_SECRET_KEY: sample_webhook_secret_key
|
||||||
|
APP_SECRET_KEY: sample_app_secret_key
|
||||||
|
POSTGRES_HOST: localhost
|
||||||
|
POSTGRES_DATABASE: automatisch
|
||||||
|
POSTGRES_PORT: 5432
|
||||||
|
POSTGRES_USERNAME: automatisch_user
|
||||||
|
POSTGRES_PASSWORD: automatisch_password
|
||||||
|
REDIS_HOST: localhost
|
||||||
|
APP_ENV: production
|
||||||
|
LICENSE_KEY: dummy_license_key
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
timeout-minutes: 60
|
||||||
|
runs-on:
|
||||||
|
- ubuntu-latest
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:14.5-alpine
|
||||||
|
env:
|
||||||
|
POSTGRES_DB: automatisch
|
||||||
|
POSTGRES_USER: automatisch_user
|
||||||
|
POSTGRES_PASSWORD: automatisch_password
|
||||||
|
options: >-
|
||||||
|
--health-cmd "pg_isready -U automatisch_user -d automatisch"
|
||||||
|
--health-interval 10s
|
||||||
|
--health-timeout 5s
|
||||||
|
--health-retries 5
|
||||||
|
ports:
|
||||||
|
- 5432:5432
|
||||||
|
redis:
|
||||||
|
image: redis:7.0.4-alpine
|
||||||
|
options: >-
|
||||||
|
--health-cmd "redis-cli ping"
|
||||||
|
--health-interval 10s
|
||||||
|
--health-timeout 5s
|
||||||
|
--health-retries 5
|
||||||
|
ports:
|
||||||
|
- 6379:6379
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 18
|
||||||
|
- name: Install web dependencies
|
||||||
|
run: yarn
|
||||||
|
working-directory: ./packages/web
|
||||||
|
- name: Install backend dependencies
|
||||||
|
run: yarn
|
||||||
|
working-directory: ./packages/backend
|
||||||
|
- name: Install e2e-tests dependencies
|
||||||
|
run: yarn
|
||||||
|
working-directory: ./packages/e2e-tests
|
||||||
|
- name: Install Playwright Browsers
|
||||||
|
run: yarn playwright install --with-deps
|
||||||
|
working-directory: ./packages/e2e-tests
|
||||||
|
- name: Build Automatisch web
|
||||||
|
run: yarn build
|
||||||
|
working-directory: ./packages/web
|
||||||
|
env:
|
||||||
|
# Keep this until we clean up warnings in build processes
|
||||||
|
CI: false
|
||||||
|
- name: Migrate database
|
||||||
|
working-directory: ./packages/backend
|
||||||
|
run: yarn db:migrate
|
||||||
|
- name: Install certutils
|
||||||
|
run: sudo apt install -y libnss3-tools
|
||||||
|
- name: Install mkcert
|
||||||
|
run: |
|
||||||
|
curl -JLO "https://dl.filippo.io/mkcert/latest?for=linux/amd64" \
|
||||||
|
&& chmod +x mkcert-v*-linux-amd64 \
|
||||||
|
&& sudo cp mkcert-v*-linux-amd64 /usr/local/bin/mkcert
|
||||||
|
- name: Install root certificate via mkcert
|
||||||
|
run: mkcert -install
|
||||||
|
- name: Create certificate
|
||||||
|
run: mkcert automatisch.io "*.automatisch.io" localhost 127.0.0.1 ::1
|
||||||
|
working-directory: ./packages/e2e-tests
|
||||||
|
- name: Set CAROOT environment variable
|
||||||
|
run: echo "NODE_EXTRA_CA_CERTS=$(mkcert -CAROOT)/rootCA.pem" >> "$GITHUB_ENV"
|
||||||
|
- name: Override license server with local server
|
||||||
|
run: sudo echo "127.0.0.1 license.automatisch.io" | sudo tee -a /etc/hosts
|
||||||
|
- name: Run local license server
|
||||||
|
working-directory: ./packages/e2e-tests
|
||||||
|
run: sudo yarn start-mock-license-server &
|
||||||
|
- name: Run Automatisch
|
||||||
|
run: yarn start &
|
||||||
|
working-directory: ./packages/backend
|
||||||
|
- name: Run Automatisch worker
|
||||||
|
run: yarn start:worker &
|
||||||
|
working-directory: ./packages/backend
|
||||||
|
- name: Setup upterm session
|
||||||
|
if: false
|
||||||
|
uses: lhotari/action-upterm@v1
|
||||||
|
with:
|
||||||
|
limit-access-to-actor: true
|
||||||
|
limit-access-to-users: barinali
|
||||||
|
- name: Run Playwright tests
|
||||||
|
working-directory: ./packages/e2e-tests
|
||||||
|
env:
|
||||||
|
LOGIN_EMAIL: user@automatisch.io
|
||||||
|
LOGIN_PASSWORD: sample
|
||||||
|
BASE_URL: http://localhost:3000
|
||||||
|
GITHUB_CLIENT_ID: 1c0417daf898adfbd99a
|
||||||
|
GITHUB_CLIENT_SECRET: 3328fa814dd582ccd03dbe785cfd683fb8da92b3
|
||||||
|
run: yarn test
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
if: always()
|
||||||
|
with:
|
||||||
|
name: playwright-report
|
||||||
|
path: packages/e2e-tests/test-results
|
||||||
|
retention-days: 30
|
4
.gitignore
vendored
4
.gitignore
vendored
@@ -4,7 +4,6 @@ logs
|
|||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
yarn-debug.log*
|
||||||
yarn-error.log*
|
yarn-error.log*
|
||||||
lerna-debug.log*
|
|
||||||
.pnpm-debug.log*
|
.pnpm-debug.log*
|
||||||
|
|
||||||
# Diagnostic reports (https://nodejs.org/api/report.html)
|
# Diagnostic reports (https://nodejs.org/api/report.html)
|
||||||
@@ -125,3 +124,6 @@ dist
|
|||||||
.yarn/build-state.yml
|
.yarn/build-state.yml
|
||||||
.yarn/install-state.gz
|
.yarn/install-state.gz
|
||||||
.pnp.*
|
.pnp.*
|
||||||
|
|
||||||
|
# MacOS finder preferences
|
||||||
|
.DS_store
|
||||||
|
1
.node-version
Normal file
1
.node-version
Normal file
@@ -0,0 +1 @@
|
|||||||
|
18.19.0
|
3
.vscode/settings.json
vendored
3
.vscode/settings.json
vendored
@@ -1,4 +1,7 @@
|
|||||||
{
|
{
|
||||||
"editor.formatOnSave": true,
|
"editor.formatOnSave": true,
|
||||||
|
"editor.defaultFormatter": "esbenp.prettier-vscode",
|
||||||
|
"[javascript]": {
|
||||||
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
5
CONTRIBUTOR_LICENSE_AGREEMENT.md
Normal file
5
CONTRIBUTOR_LICENSE_AGREEMENT.md
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
# Automatisch Contributor License Agreement
|
||||||
|
|
||||||
|
I give Automatisch permission to license my contributions on any terms they like. I am giving them this license in order to make it possible for them to accept my contributions into their project.
|
||||||
|
|
||||||
|
**_As far as the law allows, my contributions come as is, without any warranty or condition, and I will not be liable to anyone for any damages related to this software or this license, under any kind of legal claim._**
|
3
LICENSE
Normal file
3
LICENSE
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
LICENSE.agpl (AGPL-3.0) applies to all files in this
|
||||||
|
repository, except for files that contain ".ee." in their name
|
||||||
|
which are covered by LICENSE.enterprise.
|
35
LICENSE.enterprise
Normal file
35
LICENSE.enterprise
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
The Automatisch Enterprise license (the “Enterprise License”)
|
||||||
|
Copyright (c) 2023-present AB Software GmbH.
|
||||||
|
|
||||||
|
With regard to the Automatisch Software:
|
||||||
|
|
||||||
|
This software and associated documentation files (the "Software") may only be
|
||||||
|
used in production, if you (and any entity that you represent) have a valid
|
||||||
|
Automatisch Enterprise license for the correct number of user seats. Subject
|
||||||
|
to the foregoing sentence, you are free to modify this Software and publish
|
||||||
|
patches to the Software. You agree that Automatisch and/or its licensors
|
||||||
|
(as applicable) retain all right, title and interest in and to all such
|
||||||
|
modifications and/or patches, and all such modifications and/or patches may
|
||||||
|
only be used, copied, modified, displayed, distributed, or otherwise exploited
|
||||||
|
with a valid Automatisch Enterprise license for the correct number of user seats.
|
||||||
|
Notwithstanding the foregoing, you may copy and modify the Software for
|
||||||
|
development and testing purposes, without requiring a subscription. You agree
|
||||||
|
that Automatisch and/or its licensors (as applicable) retain all right, title
|
||||||
|
and interest in and to all such modifications. You are not granted any other
|
||||||
|
rights beyond what is expressly stated herein. Subject to the foregoing, it is
|
||||||
|
forbidden to copy, merge, publish, distribute, sublicense, and/or sell the Software.
|
||||||
|
|
||||||
|
The full text of this Enterprise License shall be included in all copies or
|
||||||
|
substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
|
|
||||||
|
For all third party components incorporated into the Automatisch Software, those
|
||||||
|
components are licensed under the original license provided by the owner of the
|
||||||
|
applicable component.
|
14
README.md
14
README.md
@@ -44,10 +44,18 @@ For other installation types, you can check the [installation](https://automatis
|
|||||||
|
|
||||||
## Support
|
## Support
|
||||||
|
|
||||||
If you have any questions or problems, please visit our GitHub discussions page, and we'll try to help you as soon as possible.
|
If you have any questions or problems, please visit our GitHub issues page, and we'll try to help you as soon as possible.
|
||||||
|
|
||||||
[https://github.com/automatisch/automatisch/discussions](https://github.com/automatisch/automatisch/discussions)
|
[https://github.com/automatisch/automatisch/issues](https://github.com/automatisch/automatisch/issues)
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
Automatisch is an open-source software with the [AGPL 3.0 license](https://github.com/automatisch/automatisch/blob/main/LICENSE.md).
|
Automatisch Community Edition (Automatisch CE) is an open-source software with the [AGPL-3.0 license](LICENSE.agpl).
|
||||||
|
|
||||||
|
Automatisch Enterprise Edition (Automatisch EE) is a commercial offering with the [Enterprise license](LICENSE.enterprise).
|
||||||
|
|
||||||
|
The Automatisch repository contains both AGPL-licensed and Enterprise-licensed files. We maintain a single repository to make development easier.
|
||||||
|
|
||||||
|
All files that contain ".ee." in their name fall under the [Enterprise license](LICENSE.enterprise). All other files fall under the [AGPL-3.0 license](LICENSE.agpl).
|
||||||
|
|
||||||
|
See the [LICENSE](LICENSE) file for more information.
|
||||||
|
@@ -1,14 +1,27 @@
|
|||||||
# syntax=docker/dockerfile:1
|
# syntax=docker/dockerfile:1
|
||||||
FROM node:16-alpine
|
FROM node:18-alpine
|
||||||
|
|
||||||
|
ENV PORT=3000
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
apk --no-cache add --virtual build-dependencies python3 build-base git make g++
|
||||||
|
|
||||||
WORKDIR /automatisch
|
WORKDIR /automatisch
|
||||||
|
|
||||||
RUN apk --no-cache add --virtual build-dependencies python3 build-base
|
# copy the app, note .dockerignore
|
||||||
|
COPY . /automatisch
|
||||||
|
|
||||||
COPY ./entrypoint.sh /entrypoint.sh
|
RUN cd packages/web && yarn
|
||||||
|
|
||||||
RUN yarn global add @automatisch/cli@0.4.0 --network-timeout 1000000
|
RUN cd packages/web && yarn build
|
||||||
|
|
||||||
RUN apk del build-dependencies python3 build-base
|
RUN cd packages/backend && yarn --production
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
rm -rf /usr/local/share/.cache/ && \
|
||||||
|
apk del build-dependencies
|
||||||
|
|
||||||
|
COPY ./docker/entrypoint.sh /entrypoint.sh
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
ENTRYPOINT ["sh", "/entrypoint.sh"]
|
ENTRYPOINT ["sh", "/entrypoint.sh"]
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
# syntax=docker/dockerfile:1
|
# syntax=docker/dockerfile:1
|
||||||
FROM automatischio/automatisch:0.4.0
|
FROM automatischio/automatisch:latest
|
||||||
WORKDIR /automatisch
|
WORKDIR /automatisch
|
||||||
|
|
||||||
RUN apk add --no-cache openssl dos2unix
|
RUN apk add --no-cache openssl dos2unix
|
||||||
|
@@ -2,8 +2,12 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
|
cd packages/backend
|
||||||
|
|
||||||
if [ -n "$WORKER" ]; then
|
if [ -n "$WORKER" ]; then
|
||||||
automatisch start-worker
|
yarn start:worker
|
||||||
else
|
else
|
||||||
automatisch start
|
yarn db:migrate
|
||||||
|
yarn db:seed:user
|
||||||
|
yarn start
|
||||||
fi
|
fi
|
||||||
|
13
lerna.json
13
lerna.json
@@ -1,13 +0,0 @@
|
|||||||
{
|
|
||||||
"packages": [
|
|
||||||
"packages/*"
|
|
||||||
],
|
|
||||||
"version": "0.4.0",
|
|
||||||
"npmClient": "yarn",
|
|
||||||
"useWorkspaces": true,
|
|
||||||
"command": {
|
|
||||||
"add": {
|
|
||||||
"exact": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
37
package.json
37
package.json
@@ -1,37 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "@automatisch/root",
|
|
||||||
"license": "AGPL-3.0",
|
|
||||||
"private": true,
|
|
||||||
"scripts": {
|
|
||||||
"start": "lerna run --stream --parallel --scope=@*/{web,backend} dev",
|
|
||||||
"start:web": "lerna run --stream --scope=@*/web dev",
|
|
||||||
"start:backend": "lerna run --stream --scope=@*/backend dev",
|
|
||||||
"lint": "lerna run --no-bail --stream --parallel --scope=@*/{web,backend,cli} lint",
|
|
||||||
"build:watch": "lerna run --no-bail --stream --parallel --scope=@*/{web,backend,cli} build:watch",
|
|
||||||
"build:docs": "cd ./packages/docs && yarn install && yarn build"
|
|
||||||
},
|
|
||||||
"workspaces": {
|
|
||||||
"packages": [
|
|
||||||
"packages/*"
|
|
||||||
],
|
|
||||||
"nohoist": [
|
|
||||||
"**/babel-loader",
|
|
||||||
"**/webpack",
|
|
||||||
"**/@automatisch/web",
|
|
||||||
"**/@automatisch/types",
|
|
||||||
"**/ajv"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@typescript-eslint/eslint-plugin": "^5.9.1",
|
|
||||||
"@typescript-eslint/parser": "^5.9.1",
|
|
||||||
"eslint": "^8.13.0",
|
|
||||||
"eslint-config-prettier": "^8.3.0",
|
|
||||||
"eslint-plugin-prettier": "^4.0.0",
|
|
||||||
"lerna": "^4.0.0",
|
|
||||||
"prettier": "^2.5.1"
|
|
||||||
},
|
|
||||||
"publishConfig": {
|
|
||||||
"access": "public"
|
|
||||||
}
|
|
||||||
}
|
|
15
packages/backend/.env-example.test
Normal file
15
packages/backend/.env-example.test
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
APP_ENV=test
|
||||||
|
HOST=localhost
|
||||||
|
PROTOCOL=http
|
||||||
|
PORT=3000
|
||||||
|
LOG_LEVEL=debug
|
||||||
|
ENCRYPTION_KEY=sample_encryption_key
|
||||||
|
WEBHOOK_SECRET_KEY=sample_webhook_secret_key
|
||||||
|
APP_SECRET_KEY=sample_app_secret_key
|
||||||
|
POSTGRES_HOST=localhost
|
||||||
|
POSTGRES_DATABASE=automatisch_test
|
||||||
|
POSTGRES_PORT=5432
|
||||||
|
POSTGRES_USERNAME=automatisch_test_user
|
||||||
|
POSTGRES_PASSWORD=automatisch_test_user_password
|
||||||
|
REDIS_HOST=localhost
|
||||||
|
AUTOMATISCH_CLOUD=true
|
12
packages/backend/.eslintrc.json
Normal file
12
packages/backend/.eslintrc.json
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"root": true,
|
||||||
|
"env": {
|
||||||
|
"node": true,
|
||||||
|
"es6": true
|
||||||
|
},
|
||||||
|
"extends": ["eslint:recommended", "prettier"],
|
||||||
|
"parserOptions": {
|
||||||
|
"ecmaVersion": "latest",
|
||||||
|
"sourceType": "module"
|
||||||
|
}
|
||||||
|
}
|
9
packages/backend/bin/database/client.js
Normal file
9
packages/backend/bin/database/client.js
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
import pg from 'pg';
|
||||||
|
|
||||||
|
const client = new pg.Client({
|
||||||
|
host: 'localhost',
|
||||||
|
user: 'postgres',
|
||||||
|
port: 5432,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default client;
|
@@ -1,9 +0,0 @@
|
|||||||
import { Client } from 'pg';
|
|
||||||
|
|
||||||
const client = new Client({
|
|
||||||
host: 'localhost',
|
|
||||||
user: 'postgres',
|
|
||||||
port: 5432,
|
|
||||||
});
|
|
||||||
|
|
||||||
export default client;
|
|
31
packages/backend/bin/database/convert-migrations.js
Normal file
31
packages/backend/bin/database/convert-migrations.js
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
import appConfig from '../../src/config/app.js';
|
||||||
|
import logger from '../../src/helpers/logger.js';
|
||||||
|
import '../../src/config/orm.js';
|
||||||
|
import { client as knex } from '../../src/config/database.js';
|
||||||
|
|
||||||
|
export const renameMigrationsAsJsFiles = async () => {
|
||||||
|
if (!appConfig.isDev) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const tableExists = await knex.schema.hasTable('knex_migrations');
|
||||||
|
|
||||||
|
if (tableExists) {
|
||||||
|
await knex('knex_migrations')
|
||||||
|
.where('name', 'like', '%.ts')
|
||||||
|
.update({
|
||||||
|
name: knex.raw("REPLACE(name, '.ts', '.js')"),
|
||||||
|
});
|
||||||
|
logger.info(
|
||||||
|
`Migration file names with typescript renamed as JS file names!`
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
logger.error(err.message);
|
||||||
|
}
|
||||||
|
|
||||||
|
await knex.destroy();
|
||||||
|
};
|
||||||
|
|
||||||
|
renameMigrationsAsJsFiles();
|
3
packages/backend/bin/database/create.js
Normal file
3
packages/backend/bin/database/create.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import { createDatabaseAndUser } from './utils.js';
|
||||||
|
|
||||||
|
createDatabaseAndUser();
|
@@ -1,3 +0,0 @@
|
|||||||
import { createDatabaseAndUser } from './utils';
|
|
||||||
|
|
||||||
createDatabaseAndUser();
|
|
3
packages/backend/bin/database/drop.js
Normal file
3
packages/backend/bin/database/drop.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import { dropDatabase } from './utils.js';
|
||||||
|
|
||||||
|
dropDatabase();
|
@@ -1,3 +0,0 @@
|
|||||||
import { dropDatabase } from './utils';
|
|
||||||
|
|
||||||
dropDatabase();
|
|
3
packages/backend/bin/database/seed-user.js
Normal file
3
packages/backend/bin/database/seed-user.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import { createUser } from './utils.js';
|
||||||
|
|
||||||
|
createUser();
|
@@ -1,3 +0,0 @@
|
|||||||
import { createUser } from './utils';
|
|
||||||
|
|
||||||
createUser();
|
|
145
packages/backend/bin/database/utils.js
Normal file
145
packages/backend/bin/database/utils.js
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
import appConfig from '../../src/config/app.js';
|
||||||
|
import logger from '../../src/helpers/logger.js';
|
||||||
|
import client from './client.js';
|
||||||
|
import User from '../../src/models/user.js';
|
||||||
|
import Config from '../../src/models/config.js';
|
||||||
|
import Role from '../../src/models/role.js';
|
||||||
|
import '../../src/config/orm.js';
|
||||||
|
import process from 'process';
|
||||||
|
|
||||||
|
async function fetchAdminRole() {
|
||||||
|
const role = await Role.query()
|
||||||
|
.where({
|
||||||
|
name: 'Admin',
|
||||||
|
})
|
||||||
|
.limit(1)
|
||||||
|
.first();
|
||||||
|
|
||||||
|
return role;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function createUser(
|
||||||
|
email = 'user@automatisch.io',
|
||||||
|
password = 'sample'
|
||||||
|
) {
|
||||||
|
if (appConfig.disableSeedUser) {
|
||||||
|
logger.info('Seed user is disabled.');
|
||||||
|
|
||||||
|
process.exit(0);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const UNIQUE_VIOLATION_CODE = '23505';
|
||||||
|
|
||||||
|
const role = await fetchAdminRole();
|
||||||
|
const userParams = {
|
||||||
|
email,
|
||||||
|
password,
|
||||||
|
fullName: 'Initial admin',
|
||||||
|
roleId: role.id,
|
||||||
|
};
|
||||||
|
|
||||||
|
try {
|
||||||
|
const userCount = await User.query().resultSize();
|
||||||
|
|
||||||
|
if (userCount === 0) {
|
||||||
|
const user = await User.query().insertAndFetch(userParams);
|
||||||
|
logger.info(`User has been saved: ${user.email}`);
|
||||||
|
|
||||||
|
await Config.markInstallationCompleted();
|
||||||
|
} else {
|
||||||
|
logger.info('No need to seed a user.');
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
if (err.nativeError.code !== UNIQUE_VIOLATION_CODE) {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.info(`User already exists: ${email}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
process.exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
export const createDatabaseAndUser = async (
|
||||||
|
database = appConfig.postgresDatabase,
|
||||||
|
user = appConfig.postgresUsername
|
||||||
|
) => {
|
||||||
|
await client.connect();
|
||||||
|
await createDatabase(database);
|
||||||
|
await createDatabaseUser(user);
|
||||||
|
await grantPrivileges(database, user);
|
||||||
|
|
||||||
|
await client.end();
|
||||||
|
process.exit(0);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const createDatabase = async (database = appConfig.postgresDatabase) => {
|
||||||
|
const DUPLICATE_DB_CODE = '42P04';
|
||||||
|
|
||||||
|
try {
|
||||||
|
await client.query(`CREATE DATABASE ${database}`);
|
||||||
|
logger.info(`Database: ${database} created!`);
|
||||||
|
} catch (err) {
|
||||||
|
if (err.code !== DUPLICATE_DB_CODE) {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.info(`Database: ${database} already exists!`);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const createDatabaseUser = async (user = appConfig.postgresUsername) => {
|
||||||
|
const DUPLICATE_OBJECT_CODE = '42710';
|
||||||
|
|
||||||
|
try {
|
||||||
|
const result = await client.query(`CREATE USER ${user}`);
|
||||||
|
logger.info(`Database User: ${user} created!`);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
} catch (err) {
|
||||||
|
if (err.code !== DUPLICATE_OBJECT_CODE) {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.info(`Database User: ${user} already exists!`);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const grantPrivileges = async (
|
||||||
|
database = appConfig.postgresDatabase,
|
||||||
|
user = appConfig.postgresUsername
|
||||||
|
) => {
|
||||||
|
await client.query(
|
||||||
|
`GRANT ALL PRIVILEGES ON DATABASE ${database} TO ${user};`
|
||||||
|
);
|
||||||
|
|
||||||
|
logger.info(`${user} has granted all privileges on ${database}!`);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const dropDatabase = async () => {
|
||||||
|
if (appConfig.appEnv != 'development' && appConfig.appEnv != 'test') {
|
||||||
|
const errorMessage =
|
||||||
|
'Drop database command can be used only with development or test environments!';
|
||||||
|
|
||||||
|
logger.error(errorMessage);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await client.connect();
|
||||||
|
await dropDatabaseAndUser();
|
||||||
|
|
||||||
|
await client.end();
|
||||||
|
};
|
||||||
|
|
||||||
|
export const dropDatabaseAndUser = async (
|
||||||
|
database = appConfig.postgresDatabase,
|
||||||
|
user = appConfig.postgresUsername
|
||||||
|
) => {
|
||||||
|
await client.query(`DROP DATABASE IF EXISTS ${database}`);
|
||||||
|
logger.info(`Database: ${database} removed!`);
|
||||||
|
|
||||||
|
await client.query(`DROP USER IF EXISTS ${user}`);
|
||||||
|
logger.info(`Database User: ${user} removed!`);
|
||||||
|
};
|
@@ -1,114 +0,0 @@
|
|||||||
import appConfig from '../../src/config/app';
|
|
||||||
import logger from '../../src/helpers/logger';
|
|
||||||
import client from './client';
|
|
||||||
import User from '../../src/models/user';
|
|
||||||
import '../../src/config/orm';
|
|
||||||
|
|
||||||
export async function createUser(
|
|
||||||
email = 'user@automatisch.io',
|
|
||||||
password = 'sample'
|
|
||||||
) {
|
|
||||||
const UNIQUE_VIOLATION_CODE = '23505';
|
|
||||||
const userParams = {
|
|
||||||
email,
|
|
||||||
password,
|
|
||||||
};
|
|
||||||
|
|
||||||
try {
|
|
||||||
const userCount = await User.query().resultSize();
|
|
||||||
|
|
||||||
if (userCount === 0) {
|
|
||||||
const user = await User.query().insertAndFetch(userParams);
|
|
||||||
logger.info(`User has been saved: ${user.email}`);
|
|
||||||
} else {
|
|
||||||
logger.info('No need to seed a user.');
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
if ((err as any).nativeError.code !== UNIQUE_VIOLATION_CODE) {
|
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info(`User already exists: ${email}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const createDatabaseAndUser = async (
|
|
||||||
database = appConfig.postgresDatabase,
|
|
||||||
user = appConfig.postgresUsername
|
|
||||||
) => {
|
|
||||||
await client.connect();
|
|
||||||
await createDatabase(database);
|
|
||||||
await createDatabaseUser(user);
|
|
||||||
await grantPrivileges(database, user);
|
|
||||||
|
|
||||||
await client.end();
|
|
||||||
};
|
|
||||||
|
|
||||||
export const createDatabase = async (database = appConfig.postgresDatabase) => {
|
|
||||||
const DUPLICATE_DB_CODE = '42P04';
|
|
||||||
|
|
||||||
try {
|
|
||||||
await client.query(`CREATE DATABASE ${database}`);
|
|
||||||
logger.info(`Database: ${database} created!`);
|
|
||||||
} catch (err) {
|
|
||||||
if ((err as any).code !== DUPLICATE_DB_CODE) {
|
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info(`Database: ${database} already exists!`);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export const createDatabaseUser = async (user = appConfig.postgresUsername) => {
|
|
||||||
const DUPLICATE_OBJECT_CODE = '42710';
|
|
||||||
|
|
||||||
try {
|
|
||||||
const result = await client.query(`CREATE USER ${user}`);
|
|
||||||
logger.info(`Database User: ${user} created!`);
|
|
||||||
|
|
||||||
return result;
|
|
||||||
} catch (err) {
|
|
||||||
if ((err as any).code !== DUPLICATE_OBJECT_CODE) {
|
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info(`Database User: ${user} already exists!`);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export const grantPrivileges = async (
|
|
||||||
database = appConfig.postgresDatabase,
|
|
||||||
user = appConfig.postgresUsername
|
|
||||||
) => {
|
|
||||||
await client.query(
|
|
||||||
`GRANT ALL PRIVILEGES ON DATABASE ${database} TO ${user};`
|
|
||||||
);
|
|
||||||
|
|
||||||
logger.info(`${user} has granted all privileges on ${database}!`);
|
|
||||||
};
|
|
||||||
|
|
||||||
export const dropDatabase = async () => {
|
|
||||||
if (appConfig.appEnv != 'development' && appConfig.appEnv != 'test') {
|
|
||||||
const errorMessage =
|
|
||||||
'Drop database command can be used only with development or test environments!';
|
|
||||||
|
|
||||||
logger.error(errorMessage);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await client.connect();
|
|
||||||
await dropDatabaseAndUser();
|
|
||||||
|
|
||||||
await client.end();
|
|
||||||
};
|
|
||||||
|
|
||||||
export const dropDatabaseAndUser = async (
|
|
||||||
database = appConfig.postgresDatabase,
|
|
||||||
user = appConfig.postgresUsername
|
|
||||||
) => {
|
|
||||||
await client.query(`DROP DATABASE IF EXISTS ${database}`);
|
|
||||||
logger.info(`Database: ${database} removed!`);
|
|
||||||
|
|
||||||
await client.query(`DROP USER IF EXISTS ${user}`);
|
|
||||||
logger.info(`Database User: ${user} removed!`);
|
|
||||||
};
|
|
1
packages/backend/database-utils.d.ts
vendored
1
packages/backend/database-utils.d.ts
vendored
@@ -1 +0,0 @@
|
|||||||
export * from './dist/bin/database/utils';
|
|
@@ -1,2 +0,0 @@
|
|||||||
/* eslint-disable */
|
|
||||||
module.exports = require('./dist/bin/database/utils');
|
|
1
packages/backend/database.d.ts
vendored
1
packages/backend/database.d.ts
vendored
@@ -1 +0,0 @@
|
|||||||
export * from './dist/src/config/database';
|
|
@@ -1,2 +0,0 @@
|
|||||||
/* eslint-disable */
|
|
||||||
module.exports = require('./dist/src/config/database');
|
|
33
packages/backend/knexfile.js
Normal file
33
packages/backend/knexfile.js
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
import { knexSnakeCaseMappers } from 'objection';
|
||||||
|
import appConfig from './src/config/app.js';
|
||||||
|
import path, { join } from 'path';
|
||||||
|
import { fileURLToPath } from 'url';
|
||||||
|
|
||||||
|
const fileExtension = 'js';
|
||||||
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
|
const knexConfig = {
|
||||||
|
client: 'pg',
|
||||||
|
connection: {
|
||||||
|
host: appConfig.postgresHost,
|
||||||
|
port: appConfig.postgresPort,
|
||||||
|
user: appConfig.postgresUsername,
|
||||||
|
password: appConfig.postgresPassword,
|
||||||
|
database: appConfig.postgresDatabase,
|
||||||
|
ssl: appConfig.postgresEnableSsl,
|
||||||
|
},
|
||||||
|
asyncStackTraces: appConfig.isDev,
|
||||||
|
searchPath: [appConfig.postgresSchema],
|
||||||
|
pool: { min: 0, max: 20 },
|
||||||
|
migrations: {
|
||||||
|
directory: join(__dirname, '/src/db/migrations'),
|
||||||
|
extension: fileExtension,
|
||||||
|
loadExtensions: [`.${fileExtension}`],
|
||||||
|
},
|
||||||
|
seeds: {
|
||||||
|
directory: join(__dirname, '/src/db/seeds'),
|
||||||
|
},
|
||||||
|
...(appConfig.isTest ? knexSnakeCaseMappers() : {}),
|
||||||
|
};
|
||||||
|
|
||||||
|
export default knexConfig;
|
@@ -1,26 +0,0 @@
|
|||||||
import appConfig from './src/config/app';
|
|
||||||
|
|
||||||
const fileExtension = appConfig.isDev ? 'ts' : 'js';
|
|
||||||
|
|
||||||
const knexConfig = {
|
|
||||||
client: 'pg',
|
|
||||||
connection: {
|
|
||||||
host: appConfig.postgresHost,
|
|
||||||
port: appConfig.postgresPort,
|
|
||||||
user: appConfig.postgresUsername,
|
|
||||||
password: appConfig.postgresPassword,
|
|
||||||
database: appConfig.postgresDatabase,
|
|
||||||
ssl: appConfig.postgresEnableSsl,
|
|
||||||
},
|
|
||||||
pool: { min: 0, max: 20 },
|
|
||||||
migrations: {
|
|
||||||
directory: __dirname + '/src/db/migrations',
|
|
||||||
extension: fileExtension,
|
|
||||||
loadExtensions: [`.${fileExtension}`],
|
|
||||||
},
|
|
||||||
seeds: {
|
|
||||||
directory: __dirname + '/src/db/seeds',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export default knexConfig;
|
|
1
packages/backend/logger.d.ts
vendored
1
packages/backend/logger.d.ts
vendored
@@ -1 +0,0 @@
|
|||||||
export * from './dist/src/helpers/logger';
|
|
@@ -1,2 +0,0 @@
|
|||||||
/* eslint-disable */
|
|
||||||
module.exports = require('./dist/src/helpers/logger');
|
|
@@ -1,62 +1,77 @@
|
|||||||
{
|
{
|
||||||
"name": "@automatisch/backend",
|
"name": "@automatisch/backend",
|
||||||
"version": "0.4.0",
|
"version": "0.10.0",
|
||||||
"license": "AGPL-3.0",
|
"license": "See LICENSE file",
|
||||||
"description": "The open source Zapier alternative. Build workflow automation without spending time and money.",
|
"description": "The open source Zapier alternative. Build workflow automation without spending time and money.",
|
||||||
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "ts-node-dev --exit-child src/server.ts",
|
"dev": "nodemon --exec node src/server.js",
|
||||||
"worker": "nodemon --watch 'src/**/*.ts' --exec 'ts-node' src/worker.ts",
|
"worker": "nodemon --exec node src/worker.js",
|
||||||
"build": "tsc && yarn copy-statics",
|
"start": "node src/server.js",
|
||||||
"build:watch": "nodemon --watch 'src/**/*.ts' --watch 'bin/**/*.ts' --exec yarn build --ext ts",
|
"start:worker": "node src/worker.js",
|
||||||
"start": "node dist/src/server.js",
|
"pretest": "APP_ENV=test node ./test/setup/prepare-test-env.js",
|
||||||
"test": "ava",
|
"test": "APP_ENV=test vitest run",
|
||||||
"lint": "eslint . --ignore-path ../../.eslintignore",
|
"test:watch": "APP_ENV=test vitest watch",
|
||||||
"db:create": "ts-node ./bin/database/create.ts",
|
"test:coverage": "yarn test --coverage",
|
||||||
"db:seed:user": "ts-node ./bin/database/seed-user.ts",
|
"lint": "eslint .",
|
||||||
"db:drop": "ts-node ./bin/database/drop.ts",
|
"db:create": "node ./bin/database/create.js",
|
||||||
|
"db:seed:user": "node ./bin/database/seed-user.js",
|
||||||
|
"db:drop": "node ./bin/database/drop.js",
|
||||||
"db:migration:create": "knex migrate:make",
|
"db:migration:create": "knex migrate:make",
|
||||||
"db:rollback": "knex migrate:rollback",
|
"db:rollback": "knex migrate:rollback",
|
||||||
"db:migrate": "knex migrate:latest",
|
"db:migrate": "node ./bin/database/convert-migrations.js && knex migrate:latest"
|
||||||
"copy-statics": "copyfiles src/**/*.{graphql,json,svg} dist",
|
|
||||||
"prepack": "yarn build",
|
|
||||||
"prebuild": "rm -rf ./dist"
|
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@automatisch/web": "^0.4.0",
|
|
||||||
"@bull-board/express": "^3.10.1",
|
"@bull-board/express": "^3.10.1",
|
||||||
"@graphql-tools/graphql-file-loader": "^7.3.4",
|
"@casl/ability": "^6.5.0",
|
||||||
"@graphql-tools/load": "^7.5.2",
|
"@faker-js/faker": "^9.2.0",
|
||||||
|
"@node-saml/passport-saml": "^4.0.4",
|
||||||
"@rudderstack/rudder-sdk-node": "^1.1.2",
|
"@rudderstack/rudder-sdk-node": "^1.1.2",
|
||||||
"@types/luxon": "^2.3.1",
|
"@sentry/node": "^7.42.0",
|
||||||
|
"@sentry/tracing": "^7.42.0",
|
||||||
|
"accounting": "^0.4.1",
|
||||||
"ajv-formats": "^2.1.1",
|
"ajv-formats": "^2.1.1",
|
||||||
"axios": "0.24.0",
|
"axios": "1.6.0",
|
||||||
"bcrypt": "^5.0.1",
|
"bcrypt": "^5.1.0",
|
||||||
"bullmq": "^3.0.0",
|
"bullmq": "^3.0.0",
|
||||||
"copyfiles": "^2.4.1",
|
|
||||||
"cors": "^2.8.5",
|
"cors": "^2.8.5",
|
||||||
"crypto-js": "^4.1.1",
|
"crypto-js": "^4.1.1",
|
||||||
"debug": "~2.6.9",
|
"debug": "~2.6.9",
|
||||||
"dotenv": "^10.0.0",
|
"dotenv": "^10.0.0",
|
||||||
|
"eslint": "^8.13.0",
|
||||||
|
"eslint-config-prettier": "^8.3.0",
|
||||||
|
"eslint-plugin-prettier": "^4.0.0",
|
||||||
"express": "~4.18.2",
|
"express": "~4.18.2",
|
||||||
|
"express-async-errors": "^3.1.1",
|
||||||
"express-basic-auth": "^1.2.1",
|
"express-basic-auth": "^1.2.1",
|
||||||
"express-graphql": "^0.12.0",
|
|
||||||
"fast-xml-parser": "^4.0.11",
|
"fast-xml-parser": "^4.0.11",
|
||||||
"graphql-middleware": "^6.1.15",
|
"handlebars": "^4.7.7",
|
||||||
"graphql-shield": "^7.5.0",
|
|
||||||
"graphql-tools": "^8.2.0",
|
|
||||||
"graphql-type-json": "^0.3.2",
|
|
||||||
"http-errors": "~1.6.3",
|
"http-errors": "~1.6.3",
|
||||||
|
"http-proxy-agent": "^7.0.0",
|
||||||
|
"https-proxy-agent": "^7.0.1",
|
||||||
|
"isolated-vm": "^5.0.1",
|
||||||
"jsonwebtoken": "^9.0.0",
|
"jsonwebtoken": "^9.0.0",
|
||||||
"knex": "^2.4.0",
|
"knex": "^2.4.0",
|
||||||
|
"libphonenumber-js": "^1.10.48",
|
||||||
"lodash.get": "^4.4.2",
|
"lodash.get": "^4.4.2",
|
||||||
"luxon": "2.5.2",
|
"luxon": "2.5.2",
|
||||||
|
"memory-cache": "^0.2.0",
|
||||||
"morgan": "^1.10.0",
|
"morgan": "^1.10.0",
|
||||||
"multer": "1.4.5-lts.1",
|
"multer": "1.4.5-lts.1",
|
||||||
|
"node-html-markdown": "^1.3.0",
|
||||||
"nodemailer": "6.7.0",
|
"nodemailer": "6.7.0",
|
||||||
"oauth-1.0a": "^2.2.6",
|
"oauth-1.0a": "^2.2.6",
|
||||||
"objection": "^3.0.0",
|
"objection": "^3.0.0",
|
||||||
|
"passport": "^0.6.0",
|
||||||
"pg": "^8.7.1",
|
"pg": "^8.7.1",
|
||||||
"winston": "^3.7.1"
|
"php-serialize": "^4.0.2",
|
||||||
|
"pluralize": "^8.0.0",
|
||||||
|
"prettier": "^2.5.1",
|
||||||
|
"raw-body": "^2.5.2",
|
||||||
|
"showdown": "^2.1.0",
|
||||||
|
"uuid": "^9.0.1",
|
||||||
|
"winston": "^3.7.1",
|
||||||
|
"xmlrpc": "^1.3.2"
|
||||||
},
|
},
|
||||||
"contributors": [
|
"contributors": [
|
||||||
{
|
{
|
||||||
@@ -65,26 +80,15 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"homepage": "https://github.com/automatisch/automatisch#readme",
|
"homepage": "https://github.com/automatisch/automatisch#readme",
|
||||||
"main": "dist/src/app",
|
"main": "src/server",
|
||||||
"directories": {
|
"directories": {
|
||||||
"bin": "bin",
|
"bin": "bin",
|
||||||
"src": "src",
|
"src": "src",
|
||||||
"test": "__tests__"
|
"test": "__tests__"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"dist",
|
|
||||||
"bin",
|
"bin",
|
||||||
"src",
|
"src"
|
||||||
"server.js",
|
|
||||||
"server.d.ts",
|
|
||||||
"worker.js",
|
|
||||||
"worker.d.ts",
|
|
||||||
"logger.js",
|
|
||||||
"logger.d.ts",
|
|
||||||
"database.js",
|
|
||||||
"database.d.ts",
|
|
||||||
"database-utils.js",
|
|
||||||
"database-utils.d.ts"
|
|
||||||
],
|
],
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@@ -94,39 +98,19 @@
|
|||||||
"url": "https://github.com/automatisch/automatisch/issues"
|
"url": "https://github.com/automatisch/automatisch/issues"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@automatisch/types": "^0.4.0",
|
"@vitest/coverage-v8": "^2.1.5",
|
||||||
"@types/bcrypt": "^5.0.0",
|
"node-gyp": "^10.1.0",
|
||||||
"@types/bull": "^3.15.8",
|
|
||||||
"@types/cors": "^2.8.12",
|
|
||||||
"@types/crypto-js": "^4.0.2",
|
|
||||||
"@types/express": "^4.17.15",
|
|
||||||
"@types/http-errors": "^1.8.1",
|
|
||||||
"@types/jsonwebtoken": "^8.5.8",
|
|
||||||
"@types/lodash.get": "^4.4.6",
|
|
||||||
"@types/morgan": "^1.9.3",
|
|
||||||
"@types/multer": "1.4.7",
|
|
||||||
"@types/node": "^16.10.2",
|
|
||||||
"@types/nodemailer": "^6.4.4",
|
|
||||||
"@types/pg": "^8.6.1",
|
|
||||||
"@types/pino": "^7.0.5",
|
|
||||||
"ava": "^3.15.0",
|
|
||||||
"nodemon": "^2.0.13",
|
"nodemon": "^2.0.13",
|
||||||
"sinon": "^11.1.2",
|
"supertest": "^6.3.3",
|
||||||
"ts-node": "^10.2.1",
|
"vitest": "^2.1.5"
|
||||||
"ts-node-dev": "^1.1.8"
|
|
||||||
},
|
|
||||||
"ava": {
|
|
||||||
"files": [
|
|
||||||
"test/**/*"
|
|
||||||
],
|
|
||||||
"extensions": [
|
|
||||||
"ts"
|
|
||||||
],
|
|
||||||
"require": [
|
|
||||||
"ts-node/register"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"publishConfig": {
|
"publishConfig": {
|
||||||
"access": "public"
|
"access": "public"
|
||||||
|
},
|
||||||
|
"nodemonConfig": {
|
||||||
|
"watch": [
|
||||||
|
"src/"
|
||||||
|
],
|
||||||
|
"ext": "js"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
1
packages/backend/server.d.ts
vendored
1
packages/backend/server.d.ts
vendored
@@ -1 +0,0 @@
|
|||||||
export * from './dist/src/server';
|
|
@@ -1,2 +0,0 @@
|
|||||||
/* eslint-disable */
|
|
||||||
module.exports = require('./dist/src/server.js');
|
|
71
packages/backend/src/app.js
Normal file
71
packages/backend/src/app.js
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
import createError from 'http-errors';
|
||||||
|
import express from 'express';
|
||||||
|
import 'express-async-errors';
|
||||||
|
import cors from 'cors';
|
||||||
|
|
||||||
|
import appConfig from './config/app.js';
|
||||||
|
import corsOptions from './config/cors-options.js';
|
||||||
|
import morgan from './helpers/morgan.js';
|
||||||
|
import * as Sentry from './helpers/sentry.ee.js';
|
||||||
|
import appAssetsHandler from './helpers/app-assets-handler.js';
|
||||||
|
import webUIHandler from './helpers/web-ui-handler.js';
|
||||||
|
import errorHandler from './helpers/error-handler.js';
|
||||||
|
import './config/orm.js';
|
||||||
|
import {
|
||||||
|
createBullBoardHandler,
|
||||||
|
serverAdapter,
|
||||||
|
} from './helpers/create-bull-board-handler.js';
|
||||||
|
import injectBullBoardHandler from './helpers/inject-bull-board-handler.js';
|
||||||
|
import router from './routes/index.js';
|
||||||
|
import configurePassport from './helpers/passport.js';
|
||||||
|
|
||||||
|
createBullBoardHandler(serverAdapter);
|
||||||
|
|
||||||
|
const app = express();
|
||||||
|
|
||||||
|
Sentry.init(app);
|
||||||
|
|
||||||
|
Sentry.attachRequestHandler(app);
|
||||||
|
Sentry.attachTracingHandler(app);
|
||||||
|
|
||||||
|
injectBullBoardHandler(app, serverAdapter);
|
||||||
|
|
||||||
|
appAssetsHandler(app);
|
||||||
|
|
||||||
|
app.use(morgan);
|
||||||
|
|
||||||
|
app.use(
|
||||||
|
express.json({
|
||||||
|
limit: appConfig.requestBodySizeLimit,
|
||||||
|
verify(req, res, buf) {
|
||||||
|
req.rawBody = buf;
|
||||||
|
},
|
||||||
|
})
|
||||||
|
);
|
||||||
|
app.use(
|
||||||
|
express.urlencoded({
|
||||||
|
extended: true,
|
||||||
|
limit: appConfig.requestBodySizeLimit,
|
||||||
|
verify(req, res, buf) {
|
||||||
|
req.rawBody = buf;
|
||||||
|
},
|
||||||
|
})
|
||||||
|
);
|
||||||
|
app.use(cors(corsOptions));
|
||||||
|
|
||||||
|
configurePassport(app);
|
||||||
|
|
||||||
|
app.use('/', router);
|
||||||
|
|
||||||
|
webUIHandler(app);
|
||||||
|
|
||||||
|
// catch 404 and forward to error handler
|
||||||
|
app.use(function (req, res, next) {
|
||||||
|
next(createError(404));
|
||||||
|
});
|
||||||
|
|
||||||
|
Sentry.attachErrorHandler(app);
|
||||||
|
|
||||||
|
app.use(errorHandler);
|
||||||
|
|
||||||
|
export default app;
|
@@ -1,55 +0,0 @@
|
|||||||
import createError from 'http-errors';
|
|
||||||
import express from 'express';
|
|
||||||
import appConfig from './config/app';
|
|
||||||
import cors from 'cors';
|
|
||||||
import corsOptions from './config/cors-options';
|
|
||||||
import morgan from './helpers/morgan';
|
|
||||||
import appAssetsHandler from './helpers/app-assets-handler';
|
|
||||||
import webUIHandler from './helpers/web-ui-handler';
|
|
||||||
import errorHandler from './helpers/error-handler';
|
|
||||||
import './config/orm';
|
|
||||||
import {
|
|
||||||
createBullBoardHandler,
|
|
||||||
serverAdapter,
|
|
||||||
} from './helpers/create-bull-board-handler';
|
|
||||||
import injectBullBoardHandler from './helpers/inject-bull-board-handler';
|
|
||||||
import router from './routes';
|
|
||||||
import { IRequest } from '@automatisch/types';
|
|
||||||
|
|
||||||
createBullBoardHandler(serverAdapter);
|
|
||||||
|
|
||||||
const app = express();
|
|
||||||
|
|
||||||
injectBullBoardHandler(app, serverAdapter);
|
|
||||||
|
|
||||||
appAssetsHandler(app);
|
|
||||||
|
|
||||||
app.use(morgan);
|
|
||||||
app.use(
|
|
||||||
express.json({
|
|
||||||
limit: appConfig.requestBodySizeLimit,
|
|
||||||
verify(req, res, buf) {
|
|
||||||
(req as IRequest).rawBody = buf;
|
|
||||||
},
|
|
||||||
})
|
|
||||||
);
|
|
||||||
app.use(express.urlencoded({
|
|
||||||
extended: false,
|
|
||||||
limit: appConfig.requestBodySizeLimit,
|
|
||||||
verify(req, res, buf) {
|
|
||||||
(req as IRequest).rawBody = buf;
|
|
||||||
},
|
|
||||||
}));
|
|
||||||
app.use(cors(corsOptions));
|
|
||||||
app.use('/', router);
|
|
||||||
|
|
||||||
webUIHandler(app);
|
|
||||||
|
|
||||||
// catch 404 and forward to error handler
|
|
||||||
app.use(function (req, res, next) {
|
|
||||||
next(createError(404));
|
|
||||||
});
|
|
||||||
|
|
||||||
app.use(errorHandler);
|
|
||||||
|
|
||||||
export default app;
|
|
@@ -0,0 +1,92 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action.js';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Create record',
|
||||||
|
key: 'createRecord',
|
||||||
|
description: 'Creates a new record with fields that automatically populate.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Base',
|
||||||
|
key: 'baseId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
description: 'Base in which to create the record.',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listBases',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Table',
|
||||||
|
key: 'tableId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
dependsOn: ['parameters.baseId'],
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listTables',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.baseId',
|
||||||
|
value: '{parameters.baseId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
additionalFields: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicFields',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listFields',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.baseId',
|
||||||
|
value: '{parameters.baseId}',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.tableId',
|
||||||
|
value: '{parameters.tableId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const { baseId, tableId, ...rest } = $.step.parameters;
|
||||||
|
|
||||||
|
const fields = Object.entries(rest).reduce((result, [key, value]) => {
|
||||||
|
if (Array.isArray(value)) {
|
||||||
|
result[key] = value.map((item) => item.value);
|
||||||
|
} else if (value !== '') {
|
||||||
|
result[key] = value;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}, {});
|
||||||
|
|
||||||
|
const body = {
|
||||||
|
typecast: true,
|
||||||
|
fields,
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.post(`/v0/${baseId}/${tableId}`, body);
|
||||||
|
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
174
packages/backend/src/apps/airtable/actions/find-record/index.js
Normal file
174
packages/backend/src/apps/airtable/actions/find-record/index.js
Normal file
@@ -0,0 +1,174 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action.js';
|
||||||
|
import { URLSearchParams } from 'url';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Find record',
|
||||||
|
key: 'findRecord',
|
||||||
|
description:
|
||||||
|
"Finds a record using simple field search or use Airtable's formula syntax to find a matching record.",
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Base',
|
||||||
|
key: 'baseId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
description: 'Base in which to create the record.',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listBases',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Table',
|
||||||
|
key: 'tableId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
dependsOn: ['parameters.baseId'],
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listTables',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.baseId',
|
||||||
|
value: '{parameters.baseId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Search by field',
|
||||||
|
key: 'tableField',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: false,
|
||||||
|
dependsOn: ['parameters.baseId', 'parameters.tableId'],
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listTableFields',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.baseId',
|
||||||
|
value: '{parameters.baseId}',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.tableId',
|
||||||
|
value: '{parameters.tableId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Search Value',
|
||||||
|
key: 'searchValue',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'The value of unique identifier for the record. For date values, please use the ISO format (e.g., "YYYY-MM-DD").',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Search for exact match?',
|
||||||
|
key: 'exactMatch',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
options: [
|
||||||
|
{ label: 'Yes', value: 'true' },
|
||||||
|
{ label: 'No', value: 'false' },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Search Formula',
|
||||||
|
key: 'searchFormula',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'Instead, you have the option to use an Airtable search formula for locating records according to sophisticated criteria and across various fields.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Limit to View',
|
||||||
|
key: 'limitToView',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: false,
|
||||||
|
dependsOn: ['parameters.baseId', 'parameters.tableId'],
|
||||||
|
description:
|
||||||
|
'You have the choice to restrict the search to a particular view ID if desired.',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listTableViews',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.baseId',
|
||||||
|
value: '{parameters.baseId}',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.tableId',
|
||||||
|
value: '{parameters.tableId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const {
|
||||||
|
baseId,
|
||||||
|
tableId,
|
||||||
|
tableField,
|
||||||
|
searchValue,
|
||||||
|
exactMatch,
|
||||||
|
searchFormula,
|
||||||
|
limitToView,
|
||||||
|
} = $.step.parameters;
|
||||||
|
|
||||||
|
let filterByFormula;
|
||||||
|
|
||||||
|
if (tableField && searchValue) {
|
||||||
|
filterByFormula =
|
||||||
|
exactMatch === 'true'
|
||||||
|
? `{${tableField}} = '${searchValue}'`
|
||||||
|
: `LOWER({${tableField}}) = LOWER('${searchValue}')`;
|
||||||
|
} else {
|
||||||
|
filterByFormula = searchFormula;
|
||||||
|
}
|
||||||
|
|
||||||
|
const body = new URLSearchParams({
|
||||||
|
filterByFormula,
|
||||||
|
view: limitToView,
|
||||||
|
});
|
||||||
|
|
||||||
|
const { data } = await $.http.post(
|
||||||
|
`/v0/${baseId}/${tableId}/listRecords`,
|
||||||
|
body
|
||||||
|
);
|
||||||
|
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
4
packages/backend/src/apps/airtable/actions/index.js
Normal file
4
packages/backend/src/apps/airtable/actions/index.js
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import createRecord from './create-record/index.js';
|
||||||
|
import findRecord from './find-record/index.js';
|
||||||
|
|
||||||
|
export default [createRecord, findRecord];
|
9
packages/backend/src/apps/airtable/assets/favicon.svg
Normal file
9
packages/backend/src/apps/airtable/assets/favicon.svg
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="256px" height="215px" viewBox="0 0 256 215" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" preserveAspectRatio="xMidYMid">
|
||||||
|
<g>
|
||||||
|
<path d="M114.25873,2.70101695 L18.8604023,42.1756384 C13.5552723,44.3711638 13.6102328,51.9065311 18.9486282,54.0225085 L114.746142,92.0117514 C123.163769,95.3498757 132.537419,95.3498757 140.9536,92.0117514 L236.75256,54.0225085 C242.08951,51.9065311 242.145916,44.3711638 236.83934,42.1756384 L141.442459,2.70101695 C132.738459,-0.900338983 122.961284,-0.900338983 114.25873,2.70101695" fill="#FFBF00"></path>
|
||||||
|
<path d="M136.349071,112.756863 L136.349071,207.659101 C136.349071,212.173089 140.900664,215.263892 145.096461,213.600615 L251.844122,172.166219 C254.281184,171.200072 255.879376,168.845451 255.879376,166.224705 L255.879376,71.3224678 C255.879376,66.8084791 251.327783,63.7176768 247.131986,65.3809537 L140.384325,106.815349 C137.94871,107.781496 136.349071,110.136118 136.349071,112.756863" fill="#26B5F8"></path>
|
||||||
|
<path d="M111.422771,117.65355 L79.742409,132.949912 L76.5257763,134.504714 L9.65047684,166.548104 C5.4112904,168.593211 0.000578531073,165.503855 0.000578531073,160.794612 L0.000578531073,71.7210757 C0.000578531073,70.0173017 0.874160452,68.5463864 2.04568588,67.4384994 C2.53454463,66.9481944 3.08848814,66.5446689 3.66412655,66.2250305 C5.26231864,65.2661153 7.54173107,65.0101153 9.47981017,65.7766689 L110.890522,105.957098 C116.045234,108.002206 116.450206,115.225166 111.422771,117.65355" fill="#ED3049"></path>
|
||||||
|
<path d="M111.422771,117.65355 L79.742409,132.949912 L2.04568588,67.4384994 C2.53454463,66.9481944 3.08848814,66.5446689 3.66412655,66.2250305 C5.26231864,65.2661153 7.54173107,65.0101153 9.47981017,65.7766689 L110.890522,105.957098 C116.045234,108.002206 116.450206,115.225166 111.422771,117.65355" fill-opacity="0.25" fill="#000000"></path>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.9 KiB |
38
packages/backend/src/apps/airtable/auth/generate-auth-url.js
Normal file
38
packages/backend/src/apps/airtable/auth/generate-auth-url.js
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
import crypto from 'crypto';
|
||||||
|
import { URLSearchParams } from 'url';
|
||||||
|
import authScope from '../common/auth-scope.js';
|
||||||
|
|
||||||
|
export default async function generateAuthUrl($) {
|
||||||
|
const oauthRedirectUrlField = $.app.auth.fields.find(
|
||||||
|
(field) => field.key == 'oAuthRedirectUrl'
|
||||||
|
);
|
||||||
|
const redirectUri = oauthRedirectUrlField.value;
|
||||||
|
const state = crypto.randomBytes(100).toString('base64url');
|
||||||
|
const codeVerifier = crypto.randomBytes(96).toString('base64url');
|
||||||
|
const codeChallenge = crypto
|
||||||
|
.createHash('sha256')
|
||||||
|
.update(codeVerifier)
|
||||||
|
.digest('base64')
|
||||||
|
.replace(/=/g, '')
|
||||||
|
.replace(/\+/g, '-')
|
||||||
|
.replace(/\//g, '_');
|
||||||
|
|
||||||
|
const searchParams = new URLSearchParams({
|
||||||
|
client_id: $.auth.data.clientId,
|
||||||
|
redirect_uri: redirectUri,
|
||||||
|
response_type: 'code',
|
||||||
|
scope: authScope.join(' '),
|
||||||
|
state,
|
||||||
|
code_challenge: codeChallenge,
|
||||||
|
code_challenge_method: 'S256',
|
||||||
|
});
|
||||||
|
|
||||||
|
const url = `https://airtable.com/oauth2/v1/authorize?${searchParams.toString()}`;
|
||||||
|
|
||||||
|
await $.auth.set({
|
||||||
|
url,
|
||||||
|
originalCodeChallenge: codeChallenge,
|
||||||
|
originalState: state,
|
||||||
|
codeVerifier,
|
||||||
|
});
|
||||||
|
}
|
48
packages/backend/src/apps/airtable/auth/index.js
Normal file
48
packages/backend/src/apps/airtable/auth/index.js
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
import generateAuthUrl from './generate-auth-url.js';
|
||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
import refreshToken from './refresh-token.js';
|
||||||
|
import isStillVerified from './is-still-verified.js';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
key: 'oAuthRedirectUrl',
|
||||||
|
label: 'OAuth Redirect URL',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: true,
|
||||||
|
value: '{WEB_APP_URL}/app/airtable/connections/add',
|
||||||
|
placeholder: null,
|
||||||
|
description:
|
||||||
|
'When asked to input a redirect URL in Airtable, enter the URL above.',
|
||||||
|
clickToCopy: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'clientId',
|
||||||
|
label: 'Client ID',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: null,
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'clientSecret',
|
||||||
|
label: 'Client Secret',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: null,
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
generateAuthUrl,
|
||||||
|
verifyCredentials,
|
||||||
|
isStillVerified,
|
||||||
|
refreshToken,
|
||||||
|
};
|
@@ -0,0 +1,8 @@
|
|||||||
|
import getCurrentUser from '../common/get-current-user.js';
|
||||||
|
|
||||||
|
const isStillVerified = async ($) => {
|
||||||
|
const currentUser = await getCurrentUser($);
|
||||||
|
return !!currentUser.id;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default isStillVerified;
|
40
packages/backend/src/apps/airtable/auth/refresh-token.js
Normal file
40
packages/backend/src/apps/airtable/auth/refresh-token.js
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
import { URLSearchParams } from 'node:url';
|
||||||
|
|
||||||
|
import authScope from '../common/auth-scope.js';
|
||||||
|
|
||||||
|
const refreshToken = async ($) => {
|
||||||
|
const params = new URLSearchParams({
|
||||||
|
client_id: $.auth.data.clientId,
|
||||||
|
grant_type: 'refresh_token',
|
||||||
|
refresh_token: $.auth.data.refreshToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
const basicAuthToken = Buffer.from(
|
||||||
|
$.auth.data.clientId + ':' + $.auth.data.clientSecret
|
||||||
|
).toString('base64');
|
||||||
|
|
||||||
|
const { data } = await $.http.post(
|
||||||
|
'https://airtable.com/oauth2/v1/token',
|
||||||
|
params.toString(),
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'application/x-www-form-urlencoded',
|
||||||
|
Authorization: `Basic ${basicAuthToken}`,
|
||||||
|
},
|
||||||
|
additionalProperties: {
|
||||||
|
skipAddingAuthHeader: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
await $.auth.set({
|
||||||
|
accessToken: data.access_token,
|
||||||
|
refreshToken: data.refresh_token,
|
||||||
|
expiresIn: data.expires_in,
|
||||||
|
refreshExpiresIn: data.refresh_expires_in,
|
||||||
|
scope: authScope.join(' '),
|
||||||
|
tokenType: data.token_type,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
export default refreshToken;
|
@@ -0,0 +1,56 @@
|
|||||||
|
import getCurrentUser from '../common/get-current-user.js';
|
||||||
|
|
||||||
|
const verifyCredentials = async ($) => {
|
||||||
|
if ($.auth.data.originalState !== $.auth.data.state) {
|
||||||
|
throw new Error("The 'state' parameter does not match.");
|
||||||
|
}
|
||||||
|
if ($.auth.data.originalCodeChallenge !== $.auth.data.code_challenge) {
|
||||||
|
throw new Error("The 'code challenge' parameter does not match.");
|
||||||
|
}
|
||||||
|
const oauthRedirectUrlField = $.app.auth.fields.find(
|
||||||
|
(field) => field.key == 'oAuthRedirectUrl'
|
||||||
|
);
|
||||||
|
const redirectUri = oauthRedirectUrlField.value;
|
||||||
|
const basicAuthToken = Buffer.from(
|
||||||
|
$.auth.data.clientId + ':' + $.auth.data.clientSecret
|
||||||
|
).toString('base64');
|
||||||
|
|
||||||
|
const { data } = await $.http.post(
|
||||||
|
'https://airtable.com/oauth2/v1/token',
|
||||||
|
{
|
||||||
|
code: $.auth.data.code,
|
||||||
|
client_id: $.auth.data.clientId,
|
||||||
|
redirect_uri: redirectUri,
|
||||||
|
grant_type: 'authorization_code',
|
||||||
|
code_verifier: $.auth.data.codeVerifier,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'application/x-www-form-urlencoded',
|
||||||
|
Authorization: `Basic ${basicAuthToken}`,
|
||||||
|
},
|
||||||
|
additionalProperties: {
|
||||||
|
skipAddingAuthHeader: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
await $.auth.set({
|
||||||
|
accessToken: data.access_token,
|
||||||
|
tokenType: data.token_type,
|
||||||
|
});
|
||||||
|
|
||||||
|
const currentUser = await getCurrentUser($);
|
||||||
|
|
||||||
|
await $.auth.set({
|
||||||
|
clientId: $.auth.data.clientId,
|
||||||
|
clientSecret: $.auth.data.clientSecret,
|
||||||
|
scope: $.auth.data.scope,
|
||||||
|
expiresIn: data.expires_in,
|
||||||
|
refreshExpiresIn: data.refresh_expires_in,
|
||||||
|
refreshToken: data.refresh_token,
|
||||||
|
screenName: currentUser.email,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
export default verifyCredentials;
|
12
packages/backend/src/apps/airtable/common/add-auth-header.js
Normal file
12
packages/backend/src/apps/airtable/common/add-auth-header.js
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
const addAuthHeader = ($, requestConfig) => {
|
||||||
|
if (
|
||||||
|
!requestConfig.additionalProperties?.skipAddingAuthHeader &&
|
||||||
|
$.auth.data?.accessToken
|
||||||
|
) {
|
||||||
|
requestConfig.headers.Authorization = `${$.auth.data.tokenType} ${$.auth.data.accessToken}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default addAuthHeader;
|
12
packages/backend/src/apps/airtable/common/auth-scope.js
Normal file
12
packages/backend/src/apps/airtable/common/auth-scope.js
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
const authScope = [
|
||||||
|
'data.records:read',
|
||||||
|
'data.records:write',
|
||||||
|
'data.recordComments:read',
|
||||||
|
'data.recordComments:write',
|
||||||
|
'schema.bases:read',
|
||||||
|
'schema.bases:write',
|
||||||
|
'user.email:read',
|
||||||
|
'webhook:manage',
|
||||||
|
];
|
||||||
|
|
||||||
|
export default authScope;
|
@@ -0,0 +1,6 @@
|
|||||||
|
const getCurrentUser = async ($) => {
|
||||||
|
const { data: currentUser } = await $.http.get('/v0/meta/whoami');
|
||||||
|
return currentUser;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default getCurrentUser;
|
6
packages/backend/src/apps/airtable/dynamic-data/index.js
Normal file
6
packages/backend/src/apps/airtable/dynamic-data/index.js
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
import listBases from './list-bases/index.js';
|
||||||
|
import listTableFields from './list-table-fields/index.js';
|
||||||
|
import listTableViews from './list-table-views/index.js';
|
||||||
|
import listTables from './list-tables/index.js';
|
||||||
|
|
||||||
|
export default [listBases, listTableFields, listTableViews, listTables];
|
@@ -0,0 +1,28 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List bases',
|
||||||
|
key: 'listBases',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const bases = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
|
||||||
|
const params = {};
|
||||||
|
|
||||||
|
do {
|
||||||
|
const { data } = await $.http.get('/v0/meta/bases', { params });
|
||||||
|
params.offset = data.offset;
|
||||||
|
|
||||||
|
if (data?.bases) {
|
||||||
|
for (const base of data.bases) {
|
||||||
|
bases.data.push({
|
||||||
|
value: base.id,
|
||||||
|
name: base.name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} while (params.offset);
|
||||||
|
|
||||||
|
return bases;
|
||||||
|
},
|
||||||
|
};
|
@@ -0,0 +1,39 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List table fields',
|
||||||
|
key: 'listTableFields',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const tableFields = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
const { baseId, tableId } = $.step.parameters;
|
||||||
|
|
||||||
|
if (!baseId) {
|
||||||
|
return tableFields;
|
||||||
|
}
|
||||||
|
|
||||||
|
const params = {};
|
||||||
|
|
||||||
|
do {
|
||||||
|
const { data } = await $.http.get(`/v0/meta/bases/${baseId}/tables`, {
|
||||||
|
params,
|
||||||
|
});
|
||||||
|
params.offset = data.offset;
|
||||||
|
|
||||||
|
if (data?.tables) {
|
||||||
|
for (const table of data.tables) {
|
||||||
|
if (table.id === tableId) {
|
||||||
|
table.fields.forEach((field) => {
|
||||||
|
tableFields.data.push({
|
||||||
|
value: field.name,
|
||||||
|
name: field.name,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} while (params.offset);
|
||||||
|
|
||||||
|
return tableFields;
|
||||||
|
},
|
||||||
|
};
|
@@ -0,0 +1,39 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List table views',
|
||||||
|
key: 'listTableViews',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const tableViews = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
const { baseId, tableId } = $.step.parameters;
|
||||||
|
|
||||||
|
if (!baseId) {
|
||||||
|
return tableViews;
|
||||||
|
}
|
||||||
|
|
||||||
|
const params = {};
|
||||||
|
|
||||||
|
do {
|
||||||
|
const { data } = await $.http.get(`/v0/meta/bases/${baseId}/tables`, {
|
||||||
|
params,
|
||||||
|
});
|
||||||
|
params.offset = data.offset;
|
||||||
|
|
||||||
|
if (data?.tables) {
|
||||||
|
for (const table of data.tables) {
|
||||||
|
if (table.id === tableId) {
|
||||||
|
table.views.forEach((view) => {
|
||||||
|
tableViews.data.push({
|
||||||
|
value: view.id,
|
||||||
|
name: view.name,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} while (params.offset);
|
||||||
|
|
||||||
|
return tableViews;
|
||||||
|
},
|
||||||
|
};
|
@@ -0,0 +1,35 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List tables',
|
||||||
|
key: 'listTables',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const tables = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
const baseId = $.step.parameters.baseId;
|
||||||
|
|
||||||
|
if (!baseId) {
|
||||||
|
return tables;
|
||||||
|
}
|
||||||
|
|
||||||
|
const params = {};
|
||||||
|
|
||||||
|
do {
|
||||||
|
const { data } = await $.http.get(`/v0/meta/bases/${baseId}/tables`, {
|
||||||
|
params,
|
||||||
|
});
|
||||||
|
params.offset = data.offset;
|
||||||
|
|
||||||
|
if (data?.tables) {
|
||||||
|
for (const table of data.tables) {
|
||||||
|
tables.data.push({
|
||||||
|
value: table.id,
|
||||||
|
name: table.name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} while (params.offset);
|
||||||
|
|
||||||
|
return tables;
|
||||||
|
},
|
||||||
|
};
|
@@ -0,0 +1,3 @@
|
|||||||
|
import listFields from './list-fields/index.js';
|
||||||
|
|
||||||
|
export default [listFields];
|
@@ -0,0 +1,86 @@
|
|||||||
|
const hasValue = (value) => value !== null && value !== undefined;
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'List fields',
|
||||||
|
key: 'listFields',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const options = [];
|
||||||
|
const { baseId, tableId } = $.step.parameters;
|
||||||
|
|
||||||
|
if (!hasValue(baseId) || !hasValue(tableId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const { data } = await $.http.get(`/v0/meta/bases/${baseId}/tables`);
|
||||||
|
|
||||||
|
const selectedTable = data.tables.find((table) => table.id === tableId);
|
||||||
|
|
||||||
|
if (!selectedTable) return;
|
||||||
|
|
||||||
|
selectedTable.fields.forEach((field) => {
|
||||||
|
if (field.type === 'singleSelect') {
|
||||||
|
options.push({
|
||||||
|
label: field.name,
|
||||||
|
key: field.name,
|
||||||
|
type: 'dropdown',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
options: field.options.choices.map((choice) => ({
|
||||||
|
label: choice.name,
|
||||||
|
value: choice.id,
|
||||||
|
})),
|
||||||
|
});
|
||||||
|
} else if (field.type === 'multipleSelects') {
|
||||||
|
options.push({
|
||||||
|
label: field.name,
|
||||||
|
key: field.name,
|
||||||
|
type: 'dynamic',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
label: 'Value',
|
||||||
|
key: 'value',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
options: field.options.choices.map((choice) => ({
|
||||||
|
label: choice.name,
|
||||||
|
value: choice.id,
|
||||||
|
})),
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
} else if (field.type === 'checkbox') {
|
||||||
|
options.push({
|
||||||
|
label: field.name,
|
||||||
|
key: field.name,
|
||||||
|
type: 'dropdown',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
label: 'Yes',
|
||||||
|
value: 'true',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'No',
|
||||||
|
value: 'false',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
options.push({
|
||||||
|
label: field.name,
|
||||||
|
key: field.name,
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return options;
|
||||||
|
},
|
||||||
|
};
|
22
packages/backend/src/apps/airtable/index.js
Normal file
22
packages/backend/src/apps/airtable/index.js
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
import defineApp from '../../helpers/define-app.js';
|
||||||
|
import addAuthHeader from './common/add-auth-header.js';
|
||||||
|
import auth from './auth/index.js';
|
||||||
|
import actions from './actions/index.js';
|
||||||
|
import dynamicData from './dynamic-data/index.js';
|
||||||
|
import dynamicFields from './dynamic-fields/index.js';
|
||||||
|
|
||||||
|
export default defineApp({
|
||||||
|
name: 'Airtable',
|
||||||
|
key: 'airtable',
|
||||||
|
baseUrl: 'https://airtable.com',
|
||||||
|
apiBaseUrl: 'https://api.airtable.com',
|
||||||
|
iconUrl: '{BASE_URL}/apps/airtable/assets/favicon.svg',
|
||||||
|
authDocUrl: '{DOCS_URL}/apps/airtable/connection',
|
||||||
|
primaryColor: '#FFBF00',
|
||||||
|
supportsConnections: true,
|
||||||
|
beforeRequest: [addAuthHeader],
|
||||||
|
auth,
|
||||||
|
actions,
|
||||||
|
dynamicData,
|
||||||
|
dynamicFields,
|
||||||
|
});
|
1
packages/backend/src/apps/appwrite/assets/favicon.svg
Normal file
1
packages/backend/src/apps/appwrite/assets/favicon.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg" width="132" height="24" fill="none" viewBox="0 0 132 24"><path fill="#19191C" d="M38.557 19.495c2.16 0 3.25-1.113 3.725-1.87h.214c.094.805.664 1.562 1.779 1.562h2.111V16.82h-.545c-.38 0-.57-.213-.57-.545V6.776h-2.8v1.516h-.213c-.545-.758-1.684-1.824-3.772-1.824-3.321 0-5.789 2.748-5.789 6.514s2.515 6.513 5.86 6.513m.498-2.7c-1.969 0-3.51-1.445-3.51-3.79 0-2.297 1.494-3.86 3.487-3.86 1.898 0 3.487 1.397 3.487 3.86 0 2.108-1.352 3.79-3.463 3.79M48.04 24h2.799v-6.376h.213c.522.758 1.637 1.871 3.844 1.871 3.321 0 5.741-2.795 5.741-6.513 0-3.743-2.586-6.514-5.931-6.514-2.135 0-3.18 1.16-3.678 1.8h-.213V6.776h-2.776V24m6.263-7.134c-1.922 0-3.512-1.42-3.512-3.884 0-2.108 1.353-3.885 3.464-3.885 1.97 0 3.511 1.54 3.511 3.885 0 2.297-1.494 3.884-3.463 3.884M62.082 24h2.8v-6.376h.213c.522.758 1.637 1.871 3.843 1.871 3.321 0 5.51-2.795 5.51-6.513 0-3.743-2.355-6.514-5.7-6.514-2.135 0-3.179 1.16-3.677 1.8h-.214V6.776h-2.775zm6.263-7.134c-1.922 0-3.511-1.42-3.511-3.884 0-2.108 1.352-3.885 3.463-3.885 1.97 0 3.512 1.54 3.512 3.885 0 2.297-1.495 3.884-3.464 3.884m9.805 2.61h3.961l2.254-9.735h.143l2.253 9.735H90.7l3.153-12.412h-2.821l-2.254 9.759h-.214l-2.253-9.759h-3.725l-2.278 9.759h-.213l-2.23-9.759h-2.99l3.274 12.412m17.123 0h2.8V13.34c0-2.345 1.09-3.79 3.131-3.79h1.233V6.756h-.925c-1.59 0-2.8 1.09-3.274 2.132h-.19V7.064h-2.775zm21.057 0h2.183v-2.487h-2.159c-.854 0-1.21-.38-1.21-1.256V9.528h3.511V7.064h-3.511V3.582h-2.657v3.482h-2.325v2.464h2.159v6.229c0 2.63 1.589 3.719 4.009 3.719m9.693.019c2.586 0 4.864-1.279 5.67-3.86l-2.562-.616c-.451 1.373-1.755 2.084-3.131 2.084-2.041 0-3.393-1.326-3.417-3.41h9.419v-.782c0-3.695-2.301-6.443-6.097-6.443-3.346 0-6.216 2.63-6.216 6.537 0 3.79 2.538 6.49 6.334 6.49m-3.416-7.84c.166-1.492 1.518-2.747 3.298-2.747 1.708 0 3.108 1.066 3.25 2.747h-6.548"/><path fill="#19191C" fill-rule="evenodd" d="M108.916 19.476h-2.8V9.528h-2.182V7.064h4.982z" clip-rule="evenodd"/><path fill="#19191C" d="M107.309 5.342c1.02 0 1.779-.758 1.779-1.753 0-.971-.759-1.73-1.779-1.73-1.021 0-1.78.759-1.78 1.73 0 .995.759 1.753 1.78 1.753"/><path fill="#FD366E" d="M24.443 16.432v5.478H10.752c-3.989 0-7.472-2.203-9.335-5.478A11.041 11.041 0 0 1 0 11.695v-1.48a10.97 10.97 0 0 1 .381-2.247C1.661 3.368 5.82 0 10.751 0c4.934 0 9.092 3.37 10.371 7.967h-5.854c-.96-1.499-2.624-2.49-4.516-2.49s-3.555.991-4.516 2.49a5.47 5.47 0 0 0-.67 1.494 5.562 5.562 0 0 0-.202 1.494 5.5 5.5 0 0 0 1.69 3.983 5.32 5.32 0 0 0 3.698 1.494h13.69"/><path fill="#FD366E" d="M24.443 9.46v5.478h-9.994a5.5 5.5 0 0 0 1.691-3.983 5.56 5.56 0 0 0-.203-1.494h8.506"/></svg>
|
After Width: | Height: | Size: 2.6 KiB |
65
packages/backend/src/apps/appwrite/auth/index.js
Normal file
65
packages/backend/src/apps/appwrite/auth/index.js
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
import isStillVerified from './is-still-verified.js';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
key: 'screenName',
|
||||||
|
label: 'Screen Name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description:
|
||||||
|
'Screen name of your connection to be used on Automatisch UI.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'projectId',
|
||||||
|
label: 'Project ID',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'Project ID of your Appwrite project.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'apiKey',
|
||||||
|
label: 'API Key',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'API key of your Appwrite project.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'instanceUrl',
|
||||||
|
label: 'Appwrite instance URL',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
readOnly: false,
|
||||||
|
placeholder: '',
|
||||||
|
description: '',
|
||||||
|
clickToCopy: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'host',
|
||||||
|
label: 'Host Name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'Host name of your Appwrite project.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
verifyCredentials,
|
||||||
|
isStillVerified,
|
||||||
|
};
|
@@ -0,0 +1,8 @@
|
|||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
|
||||||
|
const isStillVerified = async ($) => {
|
||||||
|
await verifyCredentials($);
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default isStillVerified;
|
@@ -0,0 +1,5 @@
|
|||||||
|
const verifyCredentials = async ($) => {
|
||||||
|
await $.http.get('/v1/users');
|
||||||
|
};
|
||||||
|
|
||||||
|
export default verifyCredentials;
|
16
packages/backend/src/apps/appwrite/common/add-auth-header.js
Normal file
16
packages/backend/src/apps/appwrite/common/add-auth-header.js
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
const addAuthHeader = ($, requestConfig) => {
|
||||||
|
requestConfig.headers['Content-Type'] = 'application/json';
|
||||||
|
|
||||||
|
if ($.auth.data?.apiKey && $.auth.data?.projectId) {
|
||||||
|
requestConfig.headers['X-Appwrite-Project'] = $.auth.data.projectId;
|
||||||
|
requestConfig.headers['X-Appwrite-Key'] = $.auth.data.apiKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($.auth.data?.host) {
|
||||||
|
requestConfig.headers['Host'] = $.auth.data.host;
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default addAuthHeader;
|
13
packages/backend/src/apps/appwrite/common/set-base-url.js
Normal file
13
packages/backend/src/apps/appwrite/common/set-base-url.js
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
const setBaseUrl = ($, requestConfig) => {
|
||||||
|
const instanceUrl = $.auth.data.instanceUrl;
|
||||||
|
|
||||||
|
if (instanceUrl) {
|
||||||
|
requestConfig.baseURL = instanceUrl;
|
||||||
|
} else if ($.app.apiBaseUrl) {
|
||||||
|
requestConfig.baseURL = $.app.apiBaseUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default setBaseUrl;
|
4
packages/backend/src/apps/appwrite/dynamic-data/index.js
Normal file
4
packages/backend/src/apps/appwrite/dynamic-data/index.js
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import listCollections from './list-collections/index.js';
|
||||||
|
import listDatabases from './list-databases/index.js';
|
||||||
|
|
||||||
|
export default [listCollections, listDatabases];
|
@@ -0,0 +1,44 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List collections',
|
||||||
|
key: 'listCollections',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const collections = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
const databaseId = $.step.parameters.databaseId;
|
||||||
|
|
||||||
|
if (!databaseId) {
|
||||||
|
return collections;
|
||||||
|
}
|
||||||
|
|
||||||
|
const params = {
|
||||||
|
queries: [
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'orderAsc',
|
||||||
|
attribute: 'name',
|
||||||
|
}),
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'limit',
|
||||||
|
values: [100],
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.get(
|
||||||
|
`/v1/databases/${databaseId}/collections`,
|
||||||
|
{ params }
|
||||||
|
);
|
||||||
|
|
||||||
|
if (data?.collections) {
|
||||||
|
for (const collection of data.collections) {
|
||||||
|
collections.data.push({
|
||||||
|
value: collection.$id,
|
||||||
|
name: collection.name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return collections;
|
||||||
|
},
|
||||||
|
};
|
@@ -0,0 +1,36 @@
|
|||||||
|
export default {
|
||||||
|
name: 'List databases',
|
||||||
|
key: 'listDatabases',
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const databases = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
|
||||||
|
const params = {
|
||||||
|
queries: [
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'orderAsc',
|
||||||
|
attribute: 'name',
|
||||||
|
}),
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'limit',
|
||||||
|
values: [100],
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.get('/v1/databases', { params });
|
||||||
|
|
||||||
|
if (data?.databases) {
|
||||||
|
for (const database of data.databases) {
|
||||||
|
databases.data.push({
|
||||||
|
value: database.$id,
|
||||||
|
name: database.name,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return databases;
|
||||||
|
},
|
||||||
|
};
|
21
packages/backend/src/apps/appwrite/index.js
Normal file
21
packages/backend/src/apps/appwrite/index.js
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
import defineApp from '../../helpers/define-app.js';
|
||||||
|
import addAuthHeader from './common/add-auth-header.js';
|
||||||
|
import setBaseUrl from './common/set-base-url.js';
|
||||||
|
import auth from './auth/index.js';
|
||||||
|
import triggers from './triggers/index.js';
|
||||||
|
import dynamicData from './dynamic-data/index.js';
|
||||||
|
|
||||||
|
export default defineApp({
|
||||||
|
name: 'Appwrite',
|
||||||
|
key: 'appwrite',
|
||||||
|
baseUrl: 'https://appwrite.io',
|
||||||
|
apiBaseUrl: 'https://cloud.appwrite.io',
|
||||||
|
iconUrl: '{BASE_URL}/apps/appwrite/assets/favicon.svg',
|
||||||
|
authDocUrl: '{DOCS_URL}/apps/appwrite/connection',
|
||||||
|
primaryColor: '#FD366E',
|
||||||
|
supportsConnections: true,
|
||||||
|
beforeRequest: [setBaseUrl, addAuthHeader],
|
||||||
|
auth,
|
||||||
|
triggers,
|
||||||
|
dynamicData,
|
||||||
|
});
|
3
packages/backend/src/apps/appwrite/triggers/index.js
Normal file
3
packages/backend/src/apps/appwrite/triggers/index.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import newDocuments from './new-documents/index.js';
|
||||||
|
|
||||||
|
export default [newDocuments];
|
@@ -0,0 +1,104 @@
|
|||||||
|
import defineTrigger from '../../../../helpers/define-trigger.js';
|
||||||
|
|
||||||
|
export default defineTrigger({
|
||||||
|
name: 'New documents',
|
||||||
|
key: 'newDocuments',
|
||||||
|
pollInterval: 15,
|
||||||
|
description: 'Triggers when a new document is created.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Database',
|
||||||
|
key: 'databaseId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listDatabases',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Collection',
|
||||||
|
key: 'collectionId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
dependsOn: ['parameters.databaseId'],
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listCollections',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.databaseId',
|
||||||
|
value: '{parameters.databaseId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const { databaseId, collectionId } = $.step.parameters;
|
||||||
|
|
||||||
|
const limit = 1;
|
||||||
|
let lastDocumentId = undefined;
|
||||||
|
let offset = 0;
|
||||||
|
let documentCount = 0;
|
||||||
|
|
||||||
|
do {
|
||||||
|
const params = {
|
||||||
|
queries: [
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'orderDesc',
|
||||||
|
attribute: '$createdAt',
|
||||||
|
}),
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'limit',
|
||||||
|
values: [limit],
|
||||||
|
}),
|
||||||
|
// An invalid cursor shouldn't be sent.
|
||||||
|
lastDocumentId &&
|
||||||
|
JSON.stringify({
|
||||||
|
method: 'cursorAfter',
|
||||||
|
values: [lastDocumentId],
|
||||||
|
}),
|
||||||
|
].filter(Boolean),
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.get(
|
||||||
|
`/v1/databases/${databaseId}/collections/${collectionId}/documents`,
|
||||||
|
{ params }
|
||||||
|
);
|
||||||
|
|
||||||
|
const documents = data?.documents;
|
||||||
|
documentCount = documents?.length;
|
||||||
|
offset = offset + limit;
|
||||||
|
lastDocumentId = documents[documentCount - 1]?.$id;
|
||||||
|
|
||||||
|
if (!documentCount) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const document of documents) {
|
||||||
|
$.pushTriggerItem({
|
||||||
|
raw: document,
|
||||||
|
meta: {
|
||||||
|
internalId: document.$id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} while (documentCount === limit);
|
||||||
|
},
|
||||||
|
});
|
3
packages/backend/src/apps/azure-openai/actions/index.js
Normal file
3
packages/backend/src/apps/azure-openai/actions/index.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import sendPrompt from './send-prompt/index.js';
|
||||||
|
|
||||||
|
export default [sendPrompt];
|
@@ -0,0 +1,97 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action.js';
|
||||||
|
|
||||||
|
const castFloatOrUndefined = (value) => {
|
||||||
|
return value === '' ? undefined : parseFloat(value);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Send prompt',
|
||||||
|
key: 'sendPrompt',
|
||||||
|
description: 'Creates a completion for the provided prompt and parameters.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Prompt',
|
||||||
|
key: 'prompt',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
variables: true,
|
||||||
|
description: 'The text to analyze.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Temperature',
|
||||||
|
key: 'temperature',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'What sampling temperature to use, between 0 and 2. Higher values means the model will take more risks. Try 0.9 for more creative applications, and 0 (argmax sampling) for ones with a well-defined answer. We generally recommend altering this or Top P but not both.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Maximum tokens',
|
||||||
|
key: 'maxTokens',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'The maximum number of tokens to generate in the completion.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Stop Sequence',
|
||||||
|
key: 'stopSequence',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'Single stop sequence where the API will stop generating further tokens. The returned text will not contain the stop sequence.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Top P',
|
||||||
|
key: 'topP',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description:
|
||||||
|
'An alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with top_p probability mass. So 0.1 means only the tokens comprising the top 10% probability mass are considered. We generally recommend altering this or temperature but not both.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Frequency Penalty',
|
||||||
|
key: 'frequencyPenalty',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description: `Number between -2.0 and 2.0. Positive values penalize new tokens based on their existing frequency in the text so far, decreasing the model's likelihood to repeat the same line verbatim.`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Presence Penalty',
|
||||||
|
key: 'presencePenalty',
|
||||||
|
type: 'string',
|
||||||
|
required: false,
|
||||||
|
variables: true,
|
||||||
|
description: `Number between -2.0 and 2.0. Positive values penalize new tokens based on whether they appear in the text so far, increasing the model's likelihood to talk about new topics.`,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const payload = {
|
||||||
|
model: $.step.parameters.model,
|
||||||
|
prompt: $.step.parameters.prompt,
|
||||||
|
temperature: castFloatOrUndefined($.step.parameters.temperature),
|
||||||
|
max_tokens: castFloatOrUndefined($.step.parameters.maxTokens),
|
||||||
|
stop: $.step.parameters.stopSequence || null,
|
||||||
|
top_p: castFloatOrUndefined($.step.parameters.topP),
|
||||||
|
frequency_penalty: castFloatOrUndefined(
|
||||||
|
$.step.parameters.frequencyPenalty
|
||||||
|
),
|
||||||
|
presence_penalty: castFloatOrUndefined($.step.parameters.presencePenalty),
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.post(
|
||||||
|
`/deployments/${$.auth.data.deploymentId}/completions`,
|
||||||
|
payload
|
||||||
|
);
|
||||||
|
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
@@ -0,0 +1,6 @@
|
|||||||
|
<svg width="256px" height="260px" viewBox="0 0 256 260" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" preserveAspectRatio="xMidYMid">
|
||||||
|
<title>OpenAI</title>
|
||||||
|
<g>
|
||||||
|
<path d="M239.183914,106.202783 C245.054304,88.5242096 243.02228,69.1733805 233.607599,53.0998864 C219.451678,28.4588021 190.999703,15.7836129 163.213007,21.739505 C147.554077,4.32145883 123.794909,-3.42398554 100.87901,1.41873898 C77.9631105,6.26146349 59.3690093,22.9572536 52.0959621,45.2214219 C33.8436494,48.9644867 18.0901721,60.392749 8.86672513,76.5818033 C-5.443491,101.182962 -2.19544431,132.215255 16.8986662,153.320094 C11.0060865,170.990656 13.0197283,190.343991 22.4238231,206.422991 C36.5975553,231.072344 65.0680342,243.746566 92.8695738,237.783372 C105.235639,251.708249 123.001113,259.630942 141.623968,259.52692 C170.105359,259.552169 195.337611,241.165718 204.037777,214.045661 C222.28734,210.296356 238.038489,198.869783 247.267014,182.68528 C261.404453,158.127515 258.142494,127.262775 239.183914,106.202783 L239.183914,106.202783 Z M141.623968,242.541207 C130.255682,242.559177 119.243876,238.574642 110.519381,231.286197 L112.054146,230.416496 L163.724595,200.590881 C166.340648,199.056444 167.954321,196.256818 167.970781,193.224005 L167.970781,120.373788 L189.815614,133.010026 C190.034132,133.121423 190.186235,133.330564 190.224885,133.572774 L190.224885,193.940229 C190.168603,220.758427 168.442166,242.484864 141.623968,242.541207 Z M37.1575749,197.93062 C31.456498,188.086359 29.4094818,176.546984 31.3766237,165.342426 L32.9113895,166.263285 L84.6329973,196.088901 C87.2389349,197.618207 90.4682717,197.618207 93.0742093,196.088901 L156.255402,159.663793 L156.255402,184.885111 C156.243557,185.149771 156.111725,185.394602 155.89729,185.550176 L103.561776,215.733903 C80.3054953,229.131632 50.5924954,221.165435 37.1575749,197.93062 Z M23.5493181,85.3811273 C29.2899861,75.4733097 38.3511911,67.9162648 49.1287482,64.0478825 L49.1287482,125.438515 C49.0891492,128.459425 50.6965386,131.262556 53.3237748,132.754232 L116.198014,169.025864 L94.3531808,181.662102 C94.1132325,181.789434 93.8257461,181.789434 93.5857979,181.662102 L41.3526015,151.529534 C18.1419426,138.076098 10.1817681,108.385562 23.5493181,85.125333 L23.5493181,85.3811273 Z M203.0146,127.075598 L139.935725,90.4458545 L161.7294,77.8607748 C161.969348,77.7334434 162.256834,77.7334434 162.496783,77.8607748 L214.729979,108.044502 C231.032329,117.451747 240.437294,135.426109 238.871504,154.182739 C237.305714,172.939368 225.050719,189.105572 207.414262,195.67963 L207.414262,134.288998 C207.322521,131.276867 205.650697,128.535853 203.0146,127.075598 Z M224.757116,94.3850867 L223.22235,93.4642272 L171.60306,63.3828173 C168.981293,61.8443751 165.732456,61.8443751 163.110689,63.3828173 L99.9806554,99.8079259 L99.9806554,74.5866077 C99.9533004,74.3254088 100.071095,74.0701869 100.287609,73.9215426 L152.520805,43.7889738 C168.863098,34.3743518 189.174256,35.2529043 204.642579,46.0434841 C220.110903,56.8340638 227.949269,75.5923959 224.757116,94.1804513 L224.757116,94.3850867 Z M88.0606409,139.097931 L66.2158076,126.512851 C65.9950399,126.379091 65.8450965,126.154176 65.8065367,125.898945 L65.8065367,65.684966 C65.8314495,46.8285367 76.7500605,29.6846032 93.8270852,21.6883055 C110.90411,13.6920079 131.063833,16.2835462 145.5632,28.338998 L144.028434,29.2086986 L92.3579852,59.0343142 C89.7419327,60.5687513 88.1282597,63.3683767 88.1117998,66.4011901 L88.0606409,139.097931 Z M99.9294965,113.5185 L128.06687,97.3011417 L156.255402,113.5185 L156.255402,145.953218 L128.169187,162.170577 L99.9806554,145.953218 L99.9294965,113.5185 Z" fill="#000000"></path>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 3.6 KiB |
58
packages/backend/src/apps/azure-openai/auth/index.js
Normal file
58
packages/backend/src/apps/azure-openai/auth/index.js
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
import isStillVerified from './is-still-verified.js';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
key: 'screenName',
|
||||||
|
label: 'Screen Name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description:
|
||||||
|
'Screen name of your connection to be used on Automatisch UI.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'yourResourceName',
|
||||||
|
label: 'Your Resource Name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'The name of your Azure OpenAI Resource.',
|
||||||
|
docUrl: 'https://automatisch.io/docs/azure-openai#your-resource-name',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'deploymentId',
|
||||||
|
label: 'Deployment ID',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'The deployment name you chose when you deployed the model.',
|
||||||
|
docUrl: 'https://automatisch.io/docs/azure-openai#deployment-id',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'apiKey',
|
||||||
|
label: 'API Key',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'Azure OpenAI API key of your account.',
|
||||||
|
docUrl: 'https://automatisch.io/docs/azure-openai#api-key',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
verifyCredentials,
|
||||||
|
isStillVerified,
|
||||||
|
};
|
@@ -0,0 +1,6 @@
|
|||||||
|
const isStillVerified = async ($) => {
|
||||||
|
await $.http.get('/fine_tuning/jobs');
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default isStillVerified;
|
@@ -0,0 +1,5 @@
|
|||||||
|
const verifyCredentials = async ($) => {
|
||||||
|
await $.http.get('/fine_tuning/jobs');
|
||||||
|
};
|
||||||
|
|
||||||
|
export default verifyCredentials;
|
@@ -0,0 +1,13 @@
|
|||||||
|
const addAuthHeader = ($, requestConfig) => {
|
||||||
|
if ($.auth.data?.apiKey) {
|
||||||
|
requestConfig.headers['api-key'] = $.auth.data.apiKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
requestConfig.params = {
|
||||||
|
'api-version': '2023-10-01-preview',
|
||||||
|
};
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default addAuthHeader;
|
@@ -0,0 +1,11 @@
|
|||||||
|
const setBaseUrl = ($, requestConfig) => {
|
||||||
|
const yourResourceName = $.auth.data.yourResourceName;
|
||||||
|
|
||||||
|
if (yourResourceName) {
|
||||||
|
requestConfig.baseURL = `https://${yourResourceName}.openai.azure.com/openai`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default setBaseUrl;
|
20
packages/backend/src/apps/azure-openai/index.js
Normal file
20
packages/backend/src/apps/azure-openai/index.js
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
import defineApp from '../../helpers/define-app.js';
|
||||||
|
import setBaseUrl from './common/set-base-url.js';
|
||||||
|
import addAuthHeader from './common/add-auth-header.js';
|
||||||
|
import auth from './auth/index.js';
|
||||||
|
import actions from './actions/index.js';
|
||||||
|
|
||||||
|
export default defineApp({
|
||||||
|
name: 'Azure OpenAI',
|
||||||
|
key: 'azure-openai',
|
||||||
|
baseUrl:
|
||||||
|
'https://azure.microsoft.com/en-us/products/ai-services/openai-service',
|
||||||
|
apiBaseUrl: '',
|
||||||
|
iconUrl: '{BASE_URL}/apps/azure-openai/assets/favicon.svg',
|
||||||
|
authDocUrl: '{DOCS_URL}/apps/azure-openai/connection',
|
||||||
|
primaryColor: '#000000',
|
||||||
|
supportsConnections: true,
|
||||||
|
beforeRequest: [setBaseUrl, addAuthHeader],
|
||||||
|
auth,
|
||||||
|
actions,
|
||||||
|
});
|
@@ -0,0 +1,35 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action.js';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Add Template',
|
||||||
|
key: 'addTemplate',
|
||||||
|
description:
|
||||||
|
'Creates an attachment of a specified object by given parent ID.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Template Data',
|
||||||
|
key: 'templateData',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
variables: true,
|
||||||
|
description: 'The content of your new Template in XML/HTML format.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const templateData = $.step.parameters.templateData;
|
||||||
|
|
||||||
|
const base64Data = Buffer.from(templateData).toString('base64');
|
||||||
|
const dataURI = `data:application/xml;base64,${base64Data}`;
|
||||||
|
|
||||||
|
const body = JSON.stringify({ template: dataURI });
|
||||||
|
|
||||||
|
const response = await $.http.post('/template', body, {
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'application/json',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
$.setActionItem({ raw: response.data });
|
||||||
|
},
|
||||||
|
});
|
3
packages/backend/src/apps/carbone/actions/index.js
Normal file
3
packages/backend/src/apps/carbone/actions/index.js
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import addTemplate from './add-template/index.js';
|
||||||
|
|
||||||
|
export default [addTemplate];
|
444
packages/backend/src/apps/carbone/assets/favicon.svg
Normal file
444
packages/backend/src/apps/carbone/assets/favicon.svg
Normal file
@@ -0,0 +1,444 @@
|
|||||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||||
|
width="100%" viewBox="0 0 1173 1173" enable-background="new 0 0 1173 1173" xml:space="preserve">
|
||||||
|
<path fill="#73348B" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M1174.000000,208.000000
|
||||||
|
C1174.000000,529.969421 1174.000000,851.938782 1174.000000,1173.954102
|
||||||
|
C783.067810,1173.954102 392.135559,1173.954102 1.101677,1173.954102
|
||||||
|
C1.101677,783.104980 1.101677,392.209930 1.101677,1.000000
|
||||||
|
C322.697510,1.000000 644.395142,1.000000 966.516235,1.467920
|
||||||
|
C966.918274,68.235474 966.895691,134.535110 966.877258,200.834747
|
||||||
|
C966.875183,208.314804 966.885986,208.322311 974.623108,208.322571
|
||||||
|
C1038.924072,208.324631 1103.225098,208.326889 1167.526123,208.310104
|
||||||
|
C1169.684082,208.309540 1171.842041,208.107910 1174.000000,208.000000
|
||||||
|
M824.469116,403.972260
|
||||||
|
C830.640320,396.844513 836.811584,389.716736 843.084839,382.471130
|
||||||
|
C813.026611,353.649353 780.256958,329.661011 741.486328,314.979523
|
||||||
|
C680.713013,291.966217 618.102173,287.454407 554.867737,301.133331
|
||||||
|
C463.817413,320.829376 397.312988,373.276550 356.951416,457.320282
|
||||||
|
C326.804779,520.093689 319.957764,586.465027 335.155365,654.111511
|
||||||
|
C358.404633,757.597168 419.946594,829.052856 520.224731,865.190979
|
||||||
|
C575.706055,885.185242 632.887451,885.395691 690.185303,873.820862
|
||||||
|
C753.158081,861.099548 803.501465,826.733521 847.328979,780.124756
|
||||||
|
C825.522522,758.991638 803.799194,737.939087 781.866882,716.683960
|
||||||
|
C775.039185,722.581055 767.314697,729.376404 759.459290,736.016846
|
||||||
|
C716.790833,772.086792 668.088501,791.050049 611.649048,788.182129
|
||||||
|
C555.974548,785.353088 510.796692,761.934998 476.366638,718.347046
|
||||||
|
C450.585236,685.708313 437.160706,648.031494 433.752258,606.690613
|
||||||
|
C430.193268,563.523926 437.309692,522.406311 457.904602,484.052490
|
||||||
|
C496.945190,411.347198 573.378845,374.580780 654.712402,388.765686
|
||||||
|
C691.388062,395.162079 723.361389,411.383057 752.404175,434.001740
|
||||||
|
C761.432556,441.033173 770.043213,448.601013 779.130859,456.160980
|
||||||
|
C794.123657,438.910675 809.069336,421.714569 824.469116,403.972260
|
||||||
|
M401.126434,1003.500000
|
||||||
|
C401.122375,996.333740 401.039398,989.166199 401.152191,982.001770
|
||||||
|
C401.198700,979.046997 400.149170,977.760315 397.091583,977.847290
|
||||||
|
C392.096008,977.989441 387.061035,978.231079 382.102264,977.778320
|
||||||
|
C376.825531,977.296387 375.754608,979.441406 375.775360,984.315125
|
||||||
|
C375.949005,1025.145630 375.873474,1065.977417 375.874237,1106.808716
|
||||||
|
C375.874329,1113.141724 375.994049,1119.477539 375.836487,1125.806519
|
||||||
|
C375.755646,1129.053101 376.993805,1130.258667 380.217560,1130.162231
|
||||||
|
C385.712311,1129.997559 391.222198,1129.953491 396.712982,1130.175049
|
||||||
|
C400.378265,1130.322998 401.327179,1128.650757 401.160339,1125.375610
|
||||||
|
C400.987305,1121.979004 401.121826,1118.566772 401.121826,1114.051758
|
||||||
|
C403.029083,1115.849609 404.038116,1116.655273 404.875366,1117.611572
|
||||||
|
C423.297913,1138.649780 456.085083,1135.565308 472.987305,1118.665161
|
||||||
|
C494.109619,1097.545654 495.745544,1057.582886 476.289124,1034.845947
|
||||||
|
C458.642456,1014.223816 423.619873,1010.312439 404.695007,1033.663574
|
||||||
|
C403.933044,1034.603882 402.896790,1035.321899 401.126709,1036.922485
|
||||||
|
C401.126709,1025.377563 401.126709,1014.938782 401.126434,1003.500000
|
||||||
|
M1021.364685,1102.039429
|
||||||
|
C1034.668091,1125.202515 1054.950562,1134.733032 1081.114746,1132.114380
|
||||||
|
C1116.971191,1128.525757 1140.394165,1093.509888 1130.352783,1058.871704
|
||||||
|
C1120.842163,1026.064697 1084.911865,1009.039368 1051.827393,1021.662964
|
||||||
|
C1020.072083,1033.779419 1006.094421,1069.964478 1021.364685,1102.039429
|
||||||
|
M513.859009,1053.461792
|
||||||
|
C508.981232,1065.614258 508.319275,1078.089722 511.612946,1090.667114
|
||||||
|
C518.928467,1118.602539 545.601379,1135.665771 576.077942,1132.138428
|
||||||
|
C615.868713,1127.533081 639.243103,1085.250000 621.290771,1049.613525
|
||||||
|
C609.925598,1027.053101 590.627502,1017.015625 565.767517,1017.961548
|
||||||
|
C541.582703,1018.881775 524.357849,1030.779541 513.859009,1053.461792
|
||||||
|
M853.945312,1105.526489
|
||||||
|
C844.979370,1111.390137 835.234131,1113.082764 824.789001,1110.928833
|
||||||
|
C812.187134,1108.330078 801.815186,1096.424561 801.983032,1084.128296
|
||||||
|
C803.915649,1084.128296 805.872803,1084.128418 807.829956,1084.128296
|
||||||
|
C827.828918,1084.128174 847.827942,1084.128174 867.826904,1084.128052
|
||||||
|
C883.022278,1084.128052 883.416565,1084.089355 881.911011,1068.743774
|
||||||
|
C877.873352,1027.588623 845.873840,1010.303040 812.589294,1020.461792
|
||||||
|
C788.140564,1027.923828 771.315674,1053.597778 776.625183,1086.417480
|
||||||
|
C782.995667,1125.795166 822.767029,1141.211426 855.517578,1128.350586
|
||||||
|
C864.166870,1124.953979 871.321899,1119.494873 877.282959,1111.812744
|
||||||
|
C872.197815,1107.281738 867.508911,1103.103882 862.714783,1098.832153
|
||||||
|
C859.777344,1101.088501 857.158447,1103.100098 853.945312,1105.526489
|
||||||
|
M183.035294,1022.439941
|
||||||
|
C178.726364,1024.044678 174.417435,1025.649414 169.759094,1027.384277
|
||||||
|
C172.080597,1034.339355 174.168320,1040.594116 176.396927,1047.270874
|
||||||
|
C178.710007,1046.498047 180.428452,1045.982422 182.104675,1045.354126
|
||||||
|
C192.414581,1041.489502 203.049866,1039.981567 214.012650,1041.017212
|
||||||
|
C228.197418,1042.357178 237.230057,1053.265137 234.370621,1065.622192
|
||||||
|
C233.945877,1065.733521 233.456528,1066.014160 233.019272,1065.948486
|
||||||
|
C231.544067,1065.726807 230.081848,1065.406616 228.624466,1065.080322
|
||||||
|
C213.432663,1061.679199 198.251007,1060.834473 183.260117,1065.925537
|
||||||
|
C168.246078,1071.024536 160.203674,1082.376099 160.159256,1097.991577
|
||||||
|
C160.116211,1113.124634 168.617416,1125.277100 183.512024,1129.868774
|
||||||
|
C201.272339,1135.343872 217.762161,1132.975952 231.922165,1119.980591
|
||||||
|
C232.681229,1119.283936 233.598526,1118.759888 234.998825,1117.756470
|
||||||
|
C234.998825,1120.660034 235.167923,1122.828491 234.961670,1124.960815
|
||||||
|
C234.595810,1128.743408 235.836517,1130.435547 239.938004,1130.198853
|
||||||
|
C245.253296,1129.892090 250.601852,1130.021362 255.931290,1130.154541
|
||||||
|
C258.904449,1130.228760 260.057526,1129.146118 260.038300,1126.091797
|
||||||
|
C259.899628,1104.095337 260.293976,1082.087280 259.708466,1060.104492
|
||||||
|
C259.149353,1039.110596 247.823425,1025.003418 228.752792,1020.447083
|
||||||
|
C213.662979,1016.841919 198.651810,1018.154236 183.035294,1022.439941
|
||||||
|
M652.674988,1084.500000
|
||||||
|
C652.676819,1097.990356 652.774353,1111.481812 652.619568,1124.970337
|
||||||
|
C652.575684,1128.797485 653.756165,1130.430420 657.763428,1130.184448
|
||||||
|
C662.243225,1129.909424 666.753052,1130.130493 671.249817,1130.123413
|
||||||
|
C677.988098,1130.112915 677.994995,1130.108398 677.998840,1123.280029
|
||||||
|
C678.009644,1104.127197 677.813293,1084.971313 678.088196,1065.822388
|
||||||
|
C678.289795,1051.782104 687.650574,1041.728882 700.475464,1040.969238
|
||||||
|
C714.725037,1040.125244 723.562256,1047.280884 725.706665,1061.495361
|
||||||
|
C726.002808,1063.458374 725.985596,1065.479614 725.987732,1067.474121
|
||||||
|
C726.007690,1086.627075 726.075562,1105.780396 725.937012,1124.932373
|
||||||
|
C725.910034,1128.659790 726.763428,1130.436401 730.909912,1130.197876
|
||||||
|
C736.388123,1129.882690 741.898499,1130.048462 747.393127,1130.132080
|
||||||
|
C750.111389,1130.173340 751.333618,1129.085205 751.318970,1126.315796
|
||||||
|
C751.187561,1101.504028 751.651367,1076.672607 750.778564,1051.887817
|
||||||
|
C750.329590,1039.136963 743.986084,1028.674927 732.321106,1022.254761
|
||||||
|
C716.863159,1013.746887 695.690918,1017.041931 683.479919,1029.807129
|
||||||
|
C681.911743,1031.446533 680.418274,1033.157227 677.994934,1035.817871
|
||||||
|
C677.994934,1031.179810 677.847046,1027.753906 678.037964,1024.347046
|
||||||
|
C678.215881,1021.172424 677.140076,1019.820496 673.800659,1019.952393
|
||||||
|
C668.645813,1020.156006 663.460022,1020.260315 658.319153,1019.922363
|
||||||
|
C653.942261,1019.634521 652.544373,1021.128174 652.590515,1025.542358
|
||||||
|
C652.792175,1044.859741 652.675354,1064.180542 652.674988,1084.500000
|
||||||
|
M119.317238,1046.101074
|
||||||
|
C122.268578,1048.446411 125.219917,1050.791626 127.387344,1052.514038
|
||||||
|
C132.109711,1048.247925 136.374313,1044.289062 140.759842,1040.468872
|
||||||
|
C144.010681,1037.637085 143.275986,1035.555298 140.351669,1032.810791
|
||||||
|
C125.930077,1019.275879 108.562424,1015.442383 89.835030,1018.619995
|
||||||
|
C58.671745,1023.907654 39.333969,1050.496826 43.188984,1083.193359
|
||||||
|
C45.926426,1106.411377 59.195229,1122.338257 81.478561,1129.875244
|
||||||
|
C103.477272,1137.315918 128.440613,1130.652588 142.387802,1114.456543
|
||||||
|
C144.090958,1112.478760 144.008331,1111.254517 142.279175,1109.447876
|
||||||
|
C138.256943,1105.245117 134.418365,1100.866577 130.299011,1096.332031
|
||||||
|
C121.771889,1103.853394 113.867172,1109.740845 103.144859,1110.191895
|
||||||
|
C92.244728,1110.650269 83.239876,1107.153076 76.138634,1098.826416
|
||||||
|
C65.223991,1086.028564 65.297775,1064.157593 76.319031,1051.184937
|
||||||
|
C87.046638,1038.557983 103.476791,1036.430054 119.317238,1046.101074
|
||||||
|
M353.950317,1043.008423
|
||||||
|
C354.006683,1036.186401 353.906464,1029.358154 354.180176,1022.544922
|
||||||
|
C354.335571,1018.677124 352.771240,1017.653687 349.151764,1017.919495
|
||||||
|
C335.330078,1018.934265 325.588013,1026.116211 318.604279,1037.643921
|
||||||
|
C317.750885,1039.052734 316.890594,1040.457275 316.033447,1041.863770
|
||||||
|
C315.121674,1035.918945 314.900055,1030.423950 315.194824,1024.956665
|
||||||
|
C315.413696,1020.897034 313.799438,1019.733093 309.981384,1019.938782
|
||||||
|
C305.168030,1020.198242 300.312347,1020.256714 295.507935,1019.924500
|
||||||
|
C291.198883,1019.626587 289.697205,1020.959900 289.777374,1025.465820
|
||||||
|
C290.040833,1040.276245 289.874969,1055.094116 289.875153,1069.909180
|
||||||
|
C289.875397,1088.219849 289.984222,1106.531616 289.796387,1124.840332
|
||||||
|
C289.753448,1129.024658 291.144775,1130.494019 295.243988,1130.181030
|
||||||
|
C298.884857,1129.903076 302.564056,1130.154053 306.225861,1130.119141
|
||||||
|
C316.127838,1130.024902 314.970276,1131.203003 315.137146,1121.384644
|
||||||
|
C315.383026,1106.919067 314.932556,1092.386353 316.201233,1078.007690
|
||||||
|
C317.784821,1060.059814 328.779388,1048.418091 344.942749,1045.376465
|
||||||
|
C347.832062,1044.832642 350.733795,1044.354858 353.950317,1043.008423
|
||||||
|
M970.561462,1130.149170
|
||||||
|
C976.347717,1130.149170 982.133972,1130.149170 988.190430,1130.149170
|
||||||
|
C988.190430,1093.234131 988.190430,1056.859741 988.190430,1020.333618
|
||||||
|
C979.702515,1020.333618 971.488037,1020.333618 963.325317,1020.333618
|
||||||
|
C963.325317,1057.058838 963.325317,1093.449585 963.325317,1130.149170
|
||||||
|
C965.622131,1130.149170 967.600586,1130.149170 970.561462,1130.149170
|
||||||
|
M931.087708,1129.856323
|
||||||
|
C931.087708,1120.373291 931.087708,1110.890259 931.087708,1101.511963
|
||||||
|
C922.010315,1101.511963 913.093201,1101.511963 904.095581,1101.511963
|
||||||
|
C904.095581,1111.126099 904.095581,1120.382812 904.095581,1130.103516
|
||||||
|
C912.953064,1130.103516 921.562012,1130.103516 931.087708,1129.856323
|
||||||
|
M989.143494,1000.348511
|
||||||
|
C989.143494,993.401855 989.143494,986.455139 989.143494,979.396606
|
||||||
|
C979.834900,979.396606 970.989380,979.396606 962.400879,979.396606
|
||||||
|
C962.400879,987.527710 962.400879,995.258179 962.400879,1003.146362
|
||||||
|
C970.452820,1003.146362 978.106445,1003.221008 985.755371,1003.064941
|
||||||
|
C986.887451,1003.041870 987.997314,1001.928955 989.143494,1000.348511
|
||||||
|
z"/>
|
||||||
|
<path fill="#B497C6" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M1174.000000,207.750000
|
||||||
|
C1171.842041,208.107910 1169.684082,208.309540 1167.526123,208.310104
|
||||||
|
C1103.225098,208.326889 1038.924072,208.324631 974.623108,208.322571
|
||||||
|
C966.885986,208.322311 966.875183,208.314804 966.877258,200.834747
|
||||||
|
C966.895691,134.535110 966.918274,68.235474 966.969849,1.467920
|
||||||
|
C967.000000,1.000000 967.500000,1.000000 967.892212,1.300326
|
||||||
|
C968.620972,1.969603 968.943176,2.352815 969.295898,2.705561
|
||||||
|
C1036.645020,70.060425 1103.995605,137.413895 1171.356201,204.757263
|
||||||
|
C1172.170776,205.571564 1173.115845,206.255310 1174.000000,207.000000
|
||||||
|
C1174.000000,207.000000 1174.000000,207.500000 1174.000000,207.750000
|
||||||
|
z"/>
|
||||||
|
<path fill="#FFFFFF" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M1174.000000,206.533020
|
||||||
|
C1173.115845,206.255310 1172.170776,205.571564 1171.356201,204.757263
|
||||||
|
C1103.995605,137.413895 1036.645020,70.060425 969.295898,2.705561
|
||||||
|
C968.943176,2.352815 968.620972,1.969603 968.142212,1.300326
|
||||||
|
C1036.594238,1.000000 1105.188599,1.000000 1174.000000,1.000000
|
||||||
|
C1174.000000,69.355194 1174.000000,137.710617 1174.000000,206.533020
|
||||||
|
z"/>
|
||||||
|
<path fill="#FFFFFF" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M824.242065,404.245361
|
||||||
|
C809.069336,421.714569 794.123657,438.910675 779.130859,456.160980
|
||||||
|
C770.043213,448.601013 761.432556,441.033173 752.404175,434.001740
|
||||||
|
C723.361389,411.383057 691.388062,395.162079 654.712402,388.765686
|
||||||
|
C573.378845,374.580780 496.945190,411.347198 457.904602,484.052490
|
||||||
|
C437.309692,522.406311 430.193268,563.523926 433.752258,606.690613
|
||||||
|
C437.160706,648.031494 450.585236,685.708313 476.366638,718.347046
|
||||||
|
C510.796692,761.934998 555.974548,785.353088 611.649048,788.182129
|
||||||
|
C668.088501,791.050049 716.790833,772.086792 759.459290,736.016846
|
||||||
|
C767.314697,729.376404 775.039185,722.581055 781.866882,716.683960
|
||||||
|
C803.799194,737.939087 825.522522,758.991638 847.328979,780.124756
|
||||||
|
C803.501465,826.733521 753.158081,861.099548 690.185303,873.820862
|
||||||
|
C632.887451,885.395691 575.706055,885.185242 520.224731,865.190979
|
||||||
|
C419.946594,829.052856 358.404633,757.597168 335.155365,654.111511
|
||||||
|
C319.957764,586.465027 326.804779,520.093689 356.951416,457.320282
|
||||||
|
C397.312988,373.276550 463.817413,320.829376 554.867737,301.133331
|
||||||
|
C618.102173,287.454407 680.713013,291.966217 741.486328,314.979523
|
||||||
|
C780.256958,329.661011 813.026611,353.649353 843.084839,382.471130
|
||||||
|
C836.811584,389.716736 830.640320,396.844513 824.242065,404.245361
|
||||||
|
z"/>
|
||||||
|
<path fill="#B496C6" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M401.126587,1004.000000
|
||||||
|
C401.126709,1014.938782 401.126709,1025.377563 401.126709,1036.922485
|
||||||
|
C402.896790,1035.321899 403.933044,1034.603882 404.695007,1033.663574
|
||||||
|
C423.619873,1010.312439 458.642456,1014.223816 476.289124,1034.845947
|
||||||
|
C495.745544,1057.582886 494.109619,1097.545654 472.987305,1118.665161
|
||||||
|
C456.085083,1135.565308 423.297913,1138.649780 404.875366,1117.611572
|
||||||
|
C404.038116,1116.655273 403.029083,1115.849609 401.121826,1114.051758
|
||||||
|
C401.121826,1118.566772 400.987305,1121.979004 401.160339,1125.375610
|
||||||
|
C401.327179,1128.650757 400.378265,1130.322998 396.712982,1130.175049
|
||||||
|
C391.222198,1129.953491 385.712311,1129.997559 380.217560,1130.162231
|
||||||
|
C376.993805,1130.258667 375.755646,1129.053101 375.836487,1125.806519
|
||||||
|
C375.994049,1119.477539 375.874329,1113.141724 375.874237,1106.808716
|
||||||
|
C375.873474,1065.977417 375.949005,1025.145630 375.775360,984.315125
|
||||||
|
C375.754608,979.441406 376.825531,977.296387 382.102264,977.778320
|
||||||
|
C387.061035,978.231079 392.096008,977.989441 397.091583,977.847290
|
||||||
|
C400.149170,977.760315 401.198700,979.046997 401.152191,982.001770
|
||||||
|
C401.039398,989.166199 401.122375,996.333740 401.126587,1004.000000
|
||||||
|
M401.102875,1069.011719
|
||||||
|
C400.098053,1078.886963 401.329559,1088.256470 407.101685,1096.684570
|
||||||
|
C420.591766,1116.381714 449.957458,1114.592529 459.843262,1092.900513
|
||||||
|
C462.811829,1086.386719 463.929352,1078.394409 463.659058,1071.163086
|
||||||
|
C462.954895,1052.325073 448.612427,1039.179199 431.024689,1039.892334
|
||||||
|
C416.229248,1040.492432 405.168213,1050.977661 401.102875,1069.011719
|
||||||
|
z"/>
|
||||||
|
<path fill="#FEFDFE" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M1021.202576,1101.701294
|
||||||
|
C1006.094421,1069.964478 1020.072083,1033.779419 1051.827393,1021.662964
|
||||||
|
C1084.911865,1009.039368 1120.842163,1026.064697 1130.352783,1058.871704
|
||||||
|
C1140.394165,1093.509888 1116.971191,1128.525757 1081.114746,1132.114380
|
||||||
|
C1054.950562,1134.733032 1034.668091,1125.202515 1021.202576,1101.701294
|
||||||
|
M1063.986572,1041.223145
|
||||||
|
C1048.638306,1046.359863 1041.596069,1057.693604 1040.531982,1073.203491
|
||||||
|
C1038.714111,1099.699341 1064.766113,1118.165283 1088.315552,1107.193970
|
||||||
|
C1103.746460,1100.005005 1111.074951,1080.915771 1105.178711,1063.268677
|
||||||
|
C1099.385498,1045.930298 1083.597778,1037.239746 1063.986572,1041.223145
|
||||||
|
z"/>
|
||||||
|
<path fill="#B396C5" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M513.996948,1053.104736
|
||||||
|
C524.357849,1030.779541 541.582703,1018.881775 565.767517,1017.961548
|
||||||
|
C590.627502,1017.015625 609.925598,1027.053101 621.290771,1049.613525
|
||||||
|
C639.243103,1085.250000 615.868713,1127.533081 576.077942,1132.138428
|
||||||
|
C545.601379,1135.665771 518.928467,1118.602539 511.612946,1090.667114
|
||||||
|
C508.319275,1078.089722 508.981232,1065.614258 513.996948,1053.104736
|
||||||
|
M562.260620,1040.444092
|
||||||
|
C546.615784,1043.979858 537.547485,1054.070801 535.297913,1070.447632
|
||||||
|
C533.121765,1086.289917 541.953796,1102.308838 555.941284,1107.888672
|
||||||
|
C570.341492,1113.633301 586.898376,1109.268066 595.135681,1096.926514
|
||||||
|
C603.733704,1084.044556 604.355286,1070.265991 596.774170,1056.799438
|
||||||
|
C589.497620,1043.873901 577.771179,1038.791748 562.260620,1040.444092
|
||||||
|
z"/>
|
||||||
|
<path fill="#B396C5" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M854.242432,1105.319092
|
||||||
|
C857.158447,1103.100098 859.777344,1101.088501 862.714783,1098.832153
|
||||||
|
C867.508911,1103.103882 872.197815,1107.281738 877.282959,1111.812744
|
||||||
|
C871.321899,1119.494873 864.166870,1124.953979 855.517578,1128.350586
|
||||||
|
C822.767029,1141.211426 782.995667,1125.795166 776.625183,1086.417480
|
||||||
|
C771.315674,1053.597778 788.140564,1027.923828 812.589294,1020.461792
|
||||||
|
C845.873840,1010.303040 877.873352,1027.588623 881.911011,1068.743774
|
||||||
|
C883.416565,1084.089355 883.022278,1084.128052 867.826904,1084.128052
|
||||||
|
C847.827942,1084.128174 827.828918,1084.128174 807.829956,1084.128296
|
||||||
|
C805.872803,1084.128418 803.915649,1084.128296 801.983032,1084.128296
|
||||||
|
C801.815186,1096.424561 812.187134,1108.330078 824.789001,1110.928833
|
||||||
|
C835.234131,1113.082764 844.979370,1111.390137 854.242432,1105.319092
|
||||||
|
M807.682800,1067.153442
|
||||||
|
C823.922729,1067.153442 840.162659,1067.153442 856.360352,1067.153442
|
||||||
|
C857.024231,1051.490723 843.821167,1038.060181 828.868347,1038.415405
|
||||||
|
C814.209839,1038.763672 800.809204,1052.746582 801.885498,1066.903320
|
||||||
|
C803.478333,1066.985229 805.112427,1067.069336 807.682800,1067.153442
|
||||||
|
z"/>
|
||||||
|
<path fill="#B396C6" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M183.418549,1022.317383
|
||||||
|
C198.651810,1018.154236 213.662979,1016.841919 228.752792,1020.447083
|
||||||
|
C247.823425,1025.003418 259.149353,1039.110596 259.708466,1060.104492
|
||||||
|
C260.293976,1082.087280 259.899628,1104.095337 260.038300,1126.091797
|
||||||
|
C260.057526,1129.146118 258.904449,1130.228760 255.931290,1130.154541
|
||||||
|
C250.601852,1130.021362 245.253296,1129.892090 239.938004,1130.198853
|
||||||
|
C235.836517,1130.435547 234.595810,1128.743408 234.961670,1124.960815
|
||||||
|
C235.167923,1122.828491 234.998825,1120.660034 234.998825,1117.756470
|
||||||
|
C233.598526,1118.759888 232.681229,1119.283936 231.922165,1119.980591
|
||||||
|
C217.762161,1132.975952 201.272339,1135.343872 183.512024,1129.868774
|
||||||
|
C168.617416,1125.277100 160.116211,1113.124634 160.159256,1097.991577
|
||||||
|
C160.203674,1082.376099 168.246078,1071.024536 183.260117,1065.925537
|
||||||
|
C198.251007,1060.834473 213.432663,1061.679199 228.624466,1065.080322
|
||||||
|
C230.081848,1065.406616 231.544067,1065.726807 233.019272,1065.948486
|
||||||
|
C233.456528,1066.014160 233.945877,1065.733521 234.370621,1065.622192
|
||||||
|
C237.230057,1053.265137 228.197418,1042.357178 214.012650,1041.017212
|
||||||
|
C203.049866,1039.981567 192.414581,1041.489502 182.104675,1045.354126
|
||||||
|
C180.428452,1045.982422 178.710007,1046.498047 176.396927,1047.270874
|
||||||
|
C174.168320,1040.594116 172.080597,1034.339355 169.759094,1027.384277
|
||||||
|
C174.417435,1025.649414 178.726364,1024.044678 183.418549,1022.317383
|
||||||
|
M222.614487,1110.282959
|
||||||
|
C232.280441,1105.292969 236.480362,1097.197876 235.760620,1086.535889
|
||||||
|
C235.661087,1085.061401 234.448975,1082.775879 233.263031,1082.397217
|
||||||
|
C220.997086,1078.481323 208.516418,1076.766968 196.064621,1081.398193
|
||||||
|
C188.557663,1084.190308 184.559586,1090.745972 185.061066,1098.121948
|
||||||
|
C185.541321,1105.185791 190.386749,1110.687134 198.052612,1112.792114
|
||||||
|
C206.277649,1115.050659 214.217789,1113.966431 222.614487,1110.282959
|
||||||
|
z"/>
|
||||||
|
<path fill="#B497C6" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M652.674561,1084.000000
|
||||||
|
C652.675354,1064.180542 652.792175,1044.859741 652.590515,1025.542358
|
||||||
|
C652.544373,1021.128174 653.942261,1019.634521 658.319153,1019.922363
|
||||||
|
C663.460022,1020.260315 668.645813,1020.156006 673.800659,1019.952393
|
||||||
|
C677.140076,1019.820496 678.215881,1021.172424 678.037964,1024.347046
|
||||||
|
C677.847046,1027.753906 677.994934,1031.179810 677.994934,1035.817871
|
||||||
|
C680.418274,1033.157227 681.911743,1031.446533 683.479919,1029.807129
|
||||||
|
C695.690918,1017.041931 716.863159,1013.746887 732.321106,1022.254761
|
||||||
|
C743.986084,1028.674927 750.329590,1039.136963 750.778564,1051.887817
|
||||||
|
C751.651367,1076.672607 751.187561,1101.504028 751.318970,1126.315796
|
||||||
|
C751.333618,1129.085205 750.111389,1130.173340 747.393127,1130.132080
|
||||||
|
C741.898499,1130.048462 736.388123,1129.882690 730.909912,1130.197876
|
||||||
|
C726.763428,1130.436401 725.910034,1128.659790 725.937012,1124.932373
|
||||||
|
C726.075562,1105.780396 726.007690,1086.627075 725.987732,1067.474121
|
||||||
|
C725.985596,1065.479614 726.002808,1063.458374 725.706665,1061.495361
|
||||||
|
C723.562256,1047.280884 714.725037,1040.125244 700.475464,1040.969238
|
||||||
|
C687.650574,1041.728882 678.289795,1051.782104 678.088196,1065.822388
|
||||||
|
C677.813293,1084.971313 678.009644,1104.127197 677.998840,1123.280029
|
||||||
|
C677.994995,1130.108398 677.988098,1130.112915 671.249817,1130.123413
|
||||||
|
C666.753052,1130.130493 662.243225,1129.909424 657.763428,1130.184448
|
||||||
|
C653.756165,1130.430420 652.575684,1128.797485 652.619568,1124.970337
|
||||||
|
C652.774353,1111.481812 652.676819,1097.990356 652.674561,1084.000000
|
||||||
|
z"/>
|
||||||
|
<path fill="#B396C5" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M119.017403,1045.897461
|
||||||
|
C103.476791,1036.430054 87.046638,1038.557983 76.319031,1051.184937
|
||||||
|
C65.297775,1064.157593 65.223991,1086.028564 76.138634,1098.826416
|
||||||
|
C83.239876,1107.153076 92.244728,1110.650269 103.144859,1110.191895
|
||||||
|
C113.867172,1109.740845 121.771889,1103.853394 130.299011,1096.332031
|
||||||
|
C134.418365,1100.866577 138.256943,1105.245117 142.279175,1109.447876
|
||||||
|
C144.008331,1111.254517 144.090958,1112.478760 142.387802,1114.456543
|
||||||
|
C128.440613,1130.652588 103.477272,1137.315918 81.478561,1129.875244
|
||||||
|
C59.195229,1122.338257 45.926426,1106.411377 43.188984,1083.193359
|
||||||
|
C39.333969,1050.496826 58.671745,1023.907654 89.835030,1018.619995
|
||||||
|
C108.562424,1015.442383 125.930077,1019.275879 140.351669,1032.810791
|
||||||
|
C143.275986,1035.555298 144.010681,1037.637085 140.759842,1040.468872
|
||||||
|
C136.374313,1044.289062 132.109711,1048.247925 127.387344,1052.514038
|
||||||
|
C125.219917,1050.791626 122.268578,1048.446411 119.017403,1045.897461
|
||||||
|
z"/>
|
||||||
|
<path fill="#B497C6" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M353.790070,1043.427490
|
||||||
|
C350.733795,1044.354858 347.832062,1044.832642 344.942749,1045.376465
|
||||||
|
C328.779388,1048.418091 317.784821,1060.059814 316.201233,1078.007690
|
||||||
|
C314.932556,1092.386353 315.383026,1106.919067 315.137146,1121.384644
|
||||||
|
C314.970276,1131.203003 316.127838,1130.024902 306.225861,1130.119141
|
||||||
|
C302.564056,1130.154053 298.884857,1129.903076 295.243988,1130.181030
|
||||||
|
C291.144775,1130.494019 289.753448,1129.024658 289.796387,1124.840332
|
||||||
|
C289.984222,1106.531616 289.875397,1088.219849 289.875153,1069.909180
|
||||||
|
C289.874969,1055.094116 290.040833,1040.276245 289.777374,1025.465820
|
||||||
|
C289.697205,1020.959900 291.198883,1019.626587 295.507935,1019.924500
|
||||||
|
C300.312347,1020.256714 305.168030,1020.198242 309.981384,1019.938782
|
||||||
|
C313.799438,1019.733093 315.413696,1020.897034 315.194824,1024.956665
|
||||||
|
C314.900055,1030.423950 315.121674,1035.918945 316.033447,1041.863770
|
||||||
|
C316.890594,1040.457275 317.750885,1039.052734 318.604279,1037.643921
|
||||||
|
C325.588013,1026.116211 335.330078,1018.934265 349.151764,1017.919495
|
||||||
|
C352.771240,1017.653687 354.335571,1018.677124 354.180176,1022.544922
|
||||||
|
C353.906464,1029.358154 354.006683,1036.186401 353.790070,1043.427490
|
||||||
|
z"/>
|
||||||
|
<path fill="#FFFFFF" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M970.070190,1130.149170
|
||||||
|
C967.600586,1130.149170 965.622131,1130.149170 963.325317,1130.149170
|
||||||
|
C963.325317,1093.449585 963.325317,1057.058838 963.325317,1020.333618
|
||||||
|
C971.488037,1020.333618 979.702515,1020.333618 988.190430,1020.333618
|
||||||
|
C988.190430,1056.859741 988.190430,1093.234131 988.190430,1130.149170
|
||||||
|
C982.133972,1130.149170 976.347717,1130.149170 970.070190,1130.149170
|
||||||
|
z"/>
|
||||||
|
<path fill="#FCFBFD" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M930.629333,1129.979980
|
||||||
|
C921.562012,1130.103516 912.953064,1130.103516 904.095581,1130.103516
|
||||||
|
C904.095581,1120.382812 904.095581,1111.126099 904.095581,1101.511963
|
||||||
|
C913.093201,1101.511963 922.010315,1101.511963 931.087708,1101.511963
|
||||||
|
C931.087708,1110.890259 931.087708,1120.373291 930.629333,1129.979980
|
||||||
|
z"/>
|
||||||
|
<path fill="#FFFFFF" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M989.130493,1000.834351
|
||||||
|
C987.997314,1001.928955 986.887451,1003.041870 985.755371,1003.064941
|
||||||
|
C978.106445,1003.221008 970.452820,1003.146362 962.400879,1003.146362
|
||||||
|
C962.400879,995.258179 962.400879,987.527710 962.400879,979.396606
|
||||||
|
C970.989380,979.396606 979.834900,979.396606 989.143494,979.396606
|
||||||
|
C989.143494,986.455139 989.143494,993.401855 989.130493,1000.834351
|
||||||
|
z"/>
|
||||||
|
<path fill="#73358B" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M401.167480,1068.572754
|
||||||
|
C405.168213,1050.977661 416.229248,1040.492432 431.024689,1039.892334
|
||||||
|
C448.612427,1039.179199 462.954895,1052.325073 463.659058,1071.163086
|
||||||
|
C463.929352,1078.394409 462.811829,1086.386719 459.843262,1092.900513
|
||||||
|
C449.957458,1114.592529 420.591766,1116.381714 407.101685,1096.684570
|
||||||
|
C401.329559,1088.256470 400.098053,1078.886963 401.167480,1068.572754
|
||||||
|
z"/>
|
||||||
|
<path fill="#74368C" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M1064.389893,1041.130493
|
||||||
|
C1083.597778,1037.239746 1099.385498,1045.930298 1105.178711,1063.268677
|
||||||
|
C1111.074951,1080.915771 1103.746460,1100.005005 1088.315552,1107.193970
|
||||||
|
C1064.766113,1118.165283 1038.714111,1099.699341 1040.531982,1073.203491
|
||||||
|
C1041.596069,1057.693604 1048.638306,1046.359863 1064.389893,1041.130493
|
||||||
|
z"/>
|
||||||
|
<path fill="#73358B" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M562.688843,1040.359863
|
||||||
|
C577.771179,1038.791748 589.497620,1043.873901 596.774170,1056.799438
|
||||||
|
C604.355286,1070.265991 603.733704,1084.044556 595.135681,1096.926514
|
||||||
|
C586.898376,1109.268066 570.341492,1113.633301 555.941284,1107.888672
|
||||||
|
C541.953796,1102.308838 533.121765,1086.289917 535.297913,1070.447632
|
||||||
|
C537.547485,1054.070801 546.615784,1043.979858 562.688843,1040.359863
|
||||||
|
z"/>
|
||||||
|
<path fill="#74358C" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M807.214600,1067.153320
|
||||||
|
C805.112427,1067.069336 803.478333,1066.985229 801.885498,1066.903320
|
||||||
|
C800.809204,1052.746582 814.209839,1038.763672 828.868347,1038.415405
|
||||||
|
C843.821167,1038.060181 857.024231,1051.490723 856.360352,1067.153442
|
||||||
|
C840.162659,1067.153442 823.922729,1067.153442 807.214600,1067.153320
|
||||||
|
z"/>
|
||||||
|
<path fill="#74358C" opacity="1.000000" stroke="none"
|
||||||
|
d="
|
||||||
|
M222.282150,1110.464844
|
||||||
|
C214.217789,1113.966431 206.277649,1115.050659 198.052612,1112.792114
|
||||||
|
C190.386749,1110.687134 185.541321,1105.185791 185.061066,1098.121948
|
||||||
|
C184.559586,1090.745972 188.557663,1084.190308 196.064621,1081.398193
|
||||||
|
C208.516418,1076.766968 220.997086,1078.481323 233.263031,1082.397217
|
||||||
|
C234.448975,1082.775879 235.661087,1085.061401 235.760620,1086.535889
|
||||||
|
C236.480362,1097.197876 232.280441,1105.292969 222.282150,1110.464844
|
||||||
|
z"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 26 KiB |
33
packages/backend/src/apps/carbone/auth/index.js
Normal file
33
packages/backend/src/apps/carbone/auth/index.js
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
import isStillVerified from './is-still-verified.js';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
key: 'screenName',
|
||||||
|
label: 'Screen Name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description:
|
||||||
|
'Screen name of your connection to be used on Automatisch UI.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'apiKey',
|
||||||
|
label: 'API Key',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
readOnly: false,
|
||||||
|
value: null,
|
||||||
|
placeholder: null,
|
||||||
|
description: 'Carbone API key of your account.',
|
||||||
|
clickToCopy: false,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
verifyCredentials,
|
||||||
|
isStillVerified,
|
||||||
|
};
|
@@ -0,0 +1,8 @@
|
|||||||
|
import verifyCredentials from './verify-credentials.js';
|
||||||
|
|
||||||
|
const isStillVerified = async ($) => {
|
||||||
|
await verifyCredentials($);
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default isStillVerified;
|
10
packages/backend/src/apps/carbone/auth/verify-credentials.js
Normal file
10
packages/backend/src/apps/carbone/auth/verify-credentials.js
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
const verifyCredentials = async ($) => {
|
||||||
|
await $.http.get('/templates');
|
||||||
|
|
||||||
|
await $.auth.set({
|
||||||
|
screenName: $.auth.data.screenName,
|
||||||
|
apiKey: $.auth.data.apiKey,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
export default verifyCredentials;
|
10
packages/backend/src/apps/carbone/common/add-auth-header.js
Normal file
10
packages/backend/src/apps/carbone/common/add-auth-header.js
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
const addAuthHeader = ($, requestConfig) => {
|
||||||
|
if ($.auth.data?.apiKey) {
|
||||||
|
requestConfig.headers.Authorization = `Bearer ${$.auth.data.apiKey}`;
|
||||||
|
requestConfig.headers['carbone-version'] = '4';
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default addAuthHeader;
|
18
packages/backend/src/apps/carbone/index.js
Normal file
18
packages/backend/src/apps/carbone/index.js
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
import defineApp from '../../helpers/define-app.js';
|
||||||
|
import addAuthHeader from './common/add-auth-header.js';
|
||||||
|
import auth from './auth/index.js';
|
||||||
|
import actions from './actions/index.js';
|
||||||
|
|
||||||
|
export default defineApp({
|
||||||
|
name: 'Carbone',
|
||||||
|
key: 'carbone',
|
||||||
|
iconUrl: '{BASE_URL}/apps/carbone/assets/favicon.svg',
|
||||||
|
authDocUrl: '{DOCS_URL}/apps/carbone/connection',
|
||||||
|
supportsConnections: true,
|
||||||
|
baseUrl: 'https://carbone.io',
|
||||||
|
apiBaseUrl: 'https://api.carbone.io',
|
||||||
|
primaryColor: '#6f42c1',
|
||||||
|
beforeRequest: [addAuthHeader],
|
||||||
|
auth,
|
||||||
|
actions,
|
||||||
|
});
|
@@ -0,0 +1,72 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action.js';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Create folder',
|
||||||
|
key: 'createFolder',
|
||||||
|
description: 'Creates a new folder.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Workspace',
|
||||||
|
key: 'workspaceId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listWorkspaces',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Space',
|
||||||
|
key: 'spaceId',
|
||||||
|
type: 'dropdown',
|
||||||
|
required: true,
|
||||||
|
dependsOn: ['parameters.workspaceId'],
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listSpaces',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'parameters.workspaceId',
|
||||||
|
value: '{parameters.workspaceId}',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Folder Name',
|
||||||
|
key: 'folderName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
description: '',
|
||||||
|
variables: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const { spaceId, folderName } = $.step.parameters;
|
||||||
|
|
||||||
|
const body = {
|
||||||
|
name: folderName,
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.post(`/v2/space/${spaceId}/folder`, body);
|
||||||
|
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user