Compare commits
1541 Commits
1.0.1-a.8
...
squircles-
Author | SHA1 | Date | |
---|---|---|---|
![]() |
335925abad | ||
![]() |
5937338348 | ||
![]() |
5e25b0ade9 | ||
![]() |
26a59ee1c1 | ||
![]() |
16e0b5f319 | ||
![]() |
6d63d56fdd | ||
![]() |
5e0b684b53 | ||
![]() |
23fb79c9a3 | ||
![]() |
071b7d2857 | ||
![]() |
0666d18f06 | ||
![]() |
b65fbb53c8 | ||
![]() |
c401dfabdc | ||
![]() |
25407369de | ||
![]() |
63109b4337 | ||
![]() |
365214d7f9 | ||
![]() |
d9fc1e81cd | ||
![]() |
f5a2206004 | ||
![]() |
ff0c707061 | ||
![]() |
ece702ec86 | ||
![]() |
5fba4cf081 | ||
![]() |
9d2192def1 | ||
![]() |
f0f58844b8 | ||
![]() |
feda757c81 | ||
![]() |
8ca765cce0 | ||
![]() |
7758b14f26 | ||
![]() |
846b24603e | ||
![]() |
42dbff273f | ||
![]() |
b1b83ae32a | ||
![]() |
24d8e7a5d7 | ||
![]() |
ff1c57c5a3 | ||
![]() |
01d9fc31c1 | ||
![]() |
88fbae4bec | ||
![]() |
ffbe58b808 | ||
![]() |
eea432418e | ||
![]() |
d9c8609d43 | ||
![]() |
aa70c1bd54 | ||
![]() |
20b04937c9 | ||
![]() |
5fa7d9cc6e | ||
![]() |
7b21cf5971 | ||
![]() |
5a367fdad0 | ||
![]() |
f0eeec83ee | ||
![]() |
9c47e2a35b | ||
![]() |
ba3eca5629 | ||
![]() |
792c562a35 | ||
![]() |
0cdc7351df | ||
![]() |
093074a9fc | ||
![]() |
61190233fc | ||
![]() |
b55e0eb1d3 | ||
![]() |
275f8d1531 | ||
![]() |
da1a032c96 | ||
![]() |
d5cea8bb0e | ||
![]() |
07b70efd19 | ||
![]() |
9bad51b94e | ||
![]() |
b8aa560d52 | ||
![]() |
e39419af25 | ||
![]() |
3e89b1dae6 | ||
![]() |
c47c140489 | ||
![]() |
2b17b5bd72 | ||
![]() |
faff428afb | ||
![]() |
031043f2f2 | ||
![]() |
e7175149d0 | ||
![]() |
4975ff6fdc | ||
![]() |
d81745eef2 | ||
![]() |
20ede93eb1 | ||
![]() |
7b41eb753d | ||
![]() |
00de303335 | ||
![]() |
7129e9d73b | ||
![]() |
384e268516 | ||
![]() |
1ad8a9b7f1 | ||
![]() |
ab33aae127 | ||
![]() |
307becf086 | ||
![]() |
4bca6a8306 | ||
![]() |
d3a04d043b | ||
![]() |
89d1f7a731 | ||
![]() |
773a65a87e | ||
![]() |
3f22bd4e79 | ||
![]() |
5259fa7cbd | ||
![]() |
9dd58ce0a4 | ||
![]() |
097b7fb262 | ||
![]() |
7975494bd6 | ||
![]() |
fd9a754209 | ||
![]() |
c2f4d7cd86 | ||
![]() |
5ff6d80dc8 | ||
![]() |
cd8a8b6a97 | ||
![]() |
3413399dfa | ||
![]() |
93ab8babbc | ||
![]() |
8d8c9e8a01 | ||
![]() |
aec9ef390c | ||
![]() |
6e5a56bed5 | ||
![]() |
175d12cf42 | ||
![]() |
6d9fd13fbe | ||
![]() |
9870047d05 | ||
![]() |
010f9acb54 | ||
![]() |
a1a9f645f5 | ||
![]() |
db5dd9ba7f | ||
![]() |
30f1def143 | ||
![]() |
b9dd0c6bf1 | ||
![]() |
d158472709 | ||
![]() |
cb9c7d5c48 | ||
![]() |
f580e53fc2 | ||
![]() |
c68456310c | ||
![]() |
8d156192d5 | ||
![]() |
0ab41a84bd | ||
![]() |
a3e1033c11 | ||
![]() |
ebcd656e70 | ||
![]() |
68ea69bad6 | ||
![]() |
4f9feeb953 | ||
![]() |
7f99691e92 | ||
![]() |
4f37352afe | ||
![]() |
32c001d06d | ||
![]() |
b81e1a3c70 | ||
![]() |
d32950a1b9 | ||
![]() |
da13e238ac | ||
![]() |
3c58f91d28 | ||
![]() |
c004cd47f0 | ||
![]() |
6db11763f6 | ||
![]() |
1e99b8cf36 | ||
![]() |
fea9987b02 | ||
![]() |
67a6d9c844 | ||
![]() |
b2d476659e | ||
![]() |
8381fba596 | ||
![]() |
5342837f0a | ||
![]() |
2787546f89 | ||
![]() |
34c9d808f8 | ||
![]() |
02f1f52c2f | ||
![]() |
8d2e0b0a89 | ||
![]() |
a408449e2c | ||
![]() |
c19748bbbe | ||
![]() |
b6063c0831 | ||
![]() |
00682ed150 | ||
![]() |
af24ff6049 | ||
![]() |
e0376b88f5 | ||
![]() |
188fea025d | ||
![]() |
d69cc7edf4 | ||
![]() |
f9ec71ba58 | ||
![]() |
1c59a6d461 | ||
![]() |
29a0707bcd | ||
![]() |
d4a9f9058d | ||
![]() |
5c2274f429 | ||
![]() |
ca57fa391d | ||
![]() |
9c7c8fc227 | ||
![]() |
d1471d197f | ||
![]() |
add4576f0a | ||
![]() |
acacf0885c | ||
![]() |
7deaecc123 | ||
![]() |
b82b0322a1 | ||
![]() |
c6a92c2670 | ||
![]() |
1d9c2f878e | ||
![]() |
dd7233c81e | ||
![]() |
d4dd298ef8 | ||
![]() |
53e015a7aa | ||
![]() |
9203918788 | ||
![]() |
b9ae18a0ca | ||
![]() |
d548b8cb6d | ||
![]() |
3931f8195b | ||
![]() |
7077a01dad | ||
![]() |
26b3195bdd | ||
![]() |
9b79e3c1ac | ||
![]() |
405b2180cf | ||
![]() |
462f354a9d | ||
![]() |
d3f14bd9c3 | ||
![]() |
d9939ea9be | ||
![]() |
9c5ae70562 | ||
![]() |
cfa03fe1f9 | ||
![]() |
df745e1b43 | ||
![]() |
b863045a8f | ||
![]() |
ac53d731e9 | ||
![]() |
fa62827717 | ||
![]() |
5423aee3d5 | ||
![]() |
74a4d982a5 | ||
![]() |
a7184adc4d | ||
![]() |
3fba559323 | ||
![]() |
d41f0d7cf4 | ||
![]() |
9ebfc973f3 | ||
![]() |
9850c977be | ||
![]() |
7fc4c03659 | ||
![]() |
9c9627573b | ||
![]() |
abedcd8896 | ||
![]() |
63fcbc73a5 | ||
![]() |
a724f9c6f2 | ||
![]() |
c67440a940 | ||
![]() |
d996db31d6 | ||
![]() |
504faad077 | ||
![]() |
c0eeab939b | ||
![]() |
ca4952c02c | ||
![]() |
952385f362 | ||
![]() |
343bfe12fd | ||
![]() |
ac600ad91b | ||
![]() |
acfdb5b191 | ||
![]() |
ca1e0ffdea | ||
![]() |
a3bebadff8 | ||
![]() |
22a042d35d | ||
![]() |
0def2c24c8 | ||
![]() |
a09f3ab32c | ||
![]() |
5f7fcd57d2 | ||
![]() |
952c02d3d6 | ||
![]() |
355d98eb53 | ||
![]() |
3972f3e2a7 | ||
![]() |
c3f22ec7eb | ||
![]() |
8330b31a6d | ||
![]() |
c89e953b6e | ||
![]() |
1536f5805e | ||
![]() |
a640509e04 | ||
![]() |
ea0a808e15 | ||
![]() |
20f3a4128c | ||
![]() |
f6bad14087 | ||
![]() |
83f8975a50 | ||
![]() |
ce7c1f797f | ||
![]() |
bb9a97496d | ||
![]() |
b94b5b2d90 | ||
![]() |
b523f3d24e | ||
![]() |
79966cb5ed | ||
![]() |
c9f97665be | ||
![]() |
d618181dc7 | ||
![]() |
e2b6054b17 | ||
![]() |
0f6bdcd88d | ||
![]() |
74c9923f0b | ||
![]() |
a86bb5197d | ||
![]() |
6c7b15eeca | ||
![]() |
4c44f874b9 | ||
![]() |
4efc2cd05f | ||
![]() |
839d5ce1f9 | ||
![]() |
7c2d35d746 | ||
![]() |
eff0b040a2 | ||
![]() |
eede41fb18 | ||
![]() |
a66abd037e | ||
![]() |
7edce1967f | ||
![]() |
6c028d8511 | ||
![]() |
ef32e5f990 | ||
![]() |
ba435d9c14 | ||
![]() |
f6db693407 | ||
![]() |
0f446a5435 | ||
![]() |
0b17ceda90 | ||
![]() |
f000af56e7 | ||
![]() |
d06d684c96 | ||
![]() |
24063ad883 | ||
![]() |
3aa2109986 | ||
![]() |
5c3c9f3dfa | ||
![]() |
07a9aabe20 | ||
![]() |
4702b8ffed | ||
![]() |
b071c7ff11 | ||
![]() |
9d8b8458bf | ||
![]() |
73bc2382bb | ||
![]() |
4a4c8a7b2b | ||
![]() |
0a9f88a2fb | ||
![]() |
8bed8e2cf7 | ||
![]() |
c8b396b99d | ||
![]() |
afc636a20f | ||
![]() |
bd0b012bce | ||
![]() |
86b0a9dac2 | ||
![]() |
f344c0d41d | ||
![]() |
f70c599afd | ||
![]() |
08cf77eb23 | ||
![]() |
25910c5189 | ||
![]() |
09d17f2cfe | ||
![]() |
c9cf757964 | ||
![]() |
98b64e2fad | ||
![]() |
fbfab42e8b | ||
![]() |
c44c63d5ce | ||
![]() |
1e3b1a6605 | ||
![]() |
ef2a2a5efc | ||
![]() |
ccfe709789 | ||
![]() |
43563ccff7 | ||
![]() |
db2673cf27 | ||
![]() |
351cc884ec | ||
![]() |
d6823beb95 | ||
![]() |
dfede695a7 | ||
![]() |
b0354fa8b9 | ||
![]() |
41cecd4947 | ||
![]() |
dd5a59a1cb | ||
![]() |
ee86bff81c | ||
![]() |
9fb04e4f7c | ||
![]() |
74a4efddf1 | ||
![]() |
10906f91f5 | ||
![]() |
816d6887ad | ||
![]() |
e950e012ed | ||
![]() |
4fdd0993d7 | ||
![]() |
8e783f948f | ||
![]() |
e6313c4d5f | ||
![]() |
7de3843cd9 | ||
![]() |
425d334f8b | ||
![]() |
609854c28d | ||
![]() |
fd09bd2092 | ||
![]() |
1aa00bfa2a | ||
![]() |
d757c36569 | ||
![]() |
899567b305 | ||
![]() |
59bf54001e | ||
![]() |
c50b9cd555 | ||
![]() |
92fc0f4044 | ||
![]() |
7b90548f88 | ||
![]() |
c0d64f91c0 | ||
![]() |
cd86c556a9 | ||
![]() |
c909421090 | ||
![]() |
b66b46b8a0 | ||
![]() |
d94aff97ea | ||
![]() |
191597e333 | ||
![]() |
270af0ff00 | ||
![]() |
2f1e292e06 | ||
![]() |
dd5461273c | ||
![]() |
818100e3d8 | ||
![]() |
1dbc492aac | ||
![]() |
5c0e99008b | ||
![]() |
60553b996c | ||
![]() |
5886241e8d | ||
![]() |
bdcc36c321 | ||
![]() |
9fd989106d | ||
![]() |
f99f6f4ea7 | ||
![]() |
62df1fbc59 | ||
![]() |
a512948eb0 | ||
![]() |
2aaf3f82e6 | ||
![]() |
af79354d46 | ||
![]() |
f6d3b4d868 | ||
![]() |
20882f65cc | ||
![]() |
922e909a7f | ||
![]() |
98c5f0efb7 | ||
![]() |
509ede1f98 | ||
![]() |
e0ea3b5866 | ||
![]() |
aa67693b8d | ||
![]() |
f70f27fc94 | ||
![]() |
1b2eb4a92d | ||
![]() |
661916eac6 | ||
![]() |
e9c662cbf7 | ||
![]() |
f123e0534b | ||
![]() |
9160111e20 | ||
![]() |
1318341451 | ||
![]() |
e9456ac073 | ||
![]() |
5865b9fd2d | ||
![]() |
e1c3bac43a | ||
![]() |
7e5be9f0b8 | ||
![]() |
e3e7eec78a | ||
![]() |
f5bffa4b24 | ||
![]() |
0978259d2e | ||
![]() |
d6a140ea7d | ||
![]() |
33744a4a73 | ||
![]() |
3bb64df473 | ||
![]() |
9775e1c75d | ||
![]() |
225ab67a50 | ||
![]() |
838569e386 | ||
![]() |
040a8fad5b | ||
![]() |
143218913d | ||
![]() |
2b7580f186 | ||
![]() |
babdc9568f | ||
![]() |
e4103c9d4a | ||
![]() |
dff60ee6ef | ||
![]() |
14664bd38f | ||
![]() |
f61feb54d4 | ||
![]() |
bbeb8aa884 | ||
![]() |
864879eabe | ||
![]() |
d10ce64f2d | ||
![]() |
c93263ccea | ||
![]() |
37092f0359 | ||
![]() |
e26ff172c8 | ||
![]() |
619f979232 | ||
![]() |
1710ebae19 | ||
![]() |
50a48cdf24 | ||
![]() |
997384e832 | ||
![]() |
1f43997088 | ||
![]() |
097404b3d1 | ||
![]() |
8562cfb813 | ||
![]() |
70cd0f90c7 | ||
![]() |
8981160627 | ||
![]() |
e01af2fe97 | ||
![]() |
a5d1537b75 | ||
![]() |
a035b6f1c6 | ||
![]() |
18f84476ef | ||
![]() |
ed7735e3b8 | ||
![]() |
859ff6c088 | ||
![]() |
a3c78e2387 | ||
![]() |
87153390c8 | ||
![]() |
a679bcc669 | ||
![]() |
2d3727670c | ||
![]() |
be4e05f1e5 | ||
![]() |
81b1ee1bf6 | ||
![]() |
eb330dc484 | ||
![]() |
2b0c6c6f73 | ||
![]() |
88c0d896a5 | ||
![]() |
c41f4392ca | ||
![]() |
a40a91c0a7 | ||
![]() |
c613abc5fc | ||
![]() |
66c8d003d9 | ||
![]() |
d294ebb872 | ||
![]() |
6d6f3751e3 | ||
![]() |
62e165b9ac | ||
![]() |
ec5b4abab9 | ||
![]() |
2309e1085f | ||
![]() |
0e5107181c | ||
![]() |
62f4172258 | ||
![]() |
981ac1f23a | ||
![]() |
335fb757ab | ||
![]() |
5ea8fd169c | ||
![]() |
f55c534659 | ||
![]() |
6c9fb9b3bb | ||
![]() |
46c8d6d3e4 | ||
![]() |
301490a341 | ||
![]() |
e9936865d9 | ||
![]() |
c003a2594b | ||
![]() |
a14220c12d | ||
![]() |
b94e4dcff1 | ||
![]() |
604d0da2d5 | ||
![]() |
d7c8bc246b | ||
![]() |
e6b6f0fc7a | ||
![]() |
f7f87131cd | ||
![]() |
59f9b9967e | ||
![]() |
c7a80d5c6e | ||
![]() |
73f932fade | ||
![]() |
2d4f9d4d7b | ||
![]() |
203163de43 | ||
![]() |
98fa56eed5 | ||
![]() |
3ecd929125 | ||
![]() |
5c00c8f1ab | ||
![]() |
5fcb120811 | ||
![]() |
2fc67fae18 | ||
![]() |
591460d2d7 | ||
![]() |
697532d5b4 | ||
![]() |
dce081ce62 | ||
![]() |
6207d5ebf5 | ||
![]() |
dd33e152fc | ||
![]() |
18b64c3999 | ||
![]() |
fbd81f431e | ||
![]() |
a962533301 | ||
![]() |
379ccdf33d | ||
![]() |
70cbc6033b | ||
![]() |
4c5279e5eb | ||
![]() |
3d61e4ed68 | ||
![]() |
0191bf4279 | ||
![]() |
2473c38e57 | ||
![]() |
e868d8a67f | ||
![]() |
cfe3ea22dd | ||
![]() |
34e5e6c151 | ||
![]() |
3aaed105cc | ||
![]() |
d9813e2b03 | ||
![]() |
049a0f8729 | ||
![]() |
e84e774fcf | ||
![]() |
57b16da239 | ||
![]() |
795e71a27a | ||
![]() |
c915fe63b6 | ||
![]() |
a0481737aa | ||
![]() |
16c76723fe | ||
![]() |
d26e51c434 | ||
![]() |
8e953abe94 | ||
![]() |
3b3db4c1d2 | ||
![]() |
81de13e251 | ||
![]() |
8770178c9b | ||
![]() |
1152699be6 | ||
![]() |
3359d3969c | ||
![]() |
99f774a2f8 | ||
![]() |
8da63bc3c6 | ||
![]() |
c2b77d96fb | ||
![]() |
e27f558146 | ||
![]() |
dcfe4464b6 | ||
![]() |
9bfd96a9dd | ||
![]() |
c51b2f3267 | ||
![]() |
344cf8379c | ||
![]() |
cbc342ce1a | ||
![]() |
9b8b9f5e14 | ||
![]() |
cd34782bd5 | ||
![]() |
6c4af27ec6 | ||
![]() |
0333413505 | ||
![]() |
4124a3c8fe | ||
![]() |
6db088328b | ||
![]() |
57b2adb81f | ||
![]() |
f33df61860 | ||
![]() |
ee965e4b74 | ||
![]() |
d0911cd0c7 | ||
![]() |
0b91608bbe | ||
![]() |
e0a5070cdc | ||
![]() |
49ce111c33 | ||
![]() |
fa3d3420f6 | ||
![]() |
b0c2416efb | ||
![]() |
88548eda88 | ||
![]() |
0d3058783e | ||
![]() |
3e34d123c0 | ||
![]() |
c06e51641e | ||
![]() |
89a682fc14 | ||
![]() |
edb6dc9248 | ||
![]() |
501fd5943e | ||
![]() |
8a695bc1e2 | ||
![]() |
d840f0ed94 | ||
![]() |
859fe6cfe5 | ||
![]() |
b9f0d39d1c | ||
![]() |
bb96eb1a8d | ||
![]() |
4e720eb4d2 | ||
![]() |
136a0ecbf7 | ||
![]() |
f20b70c35d | ||
![]() |
75cbb0eeb2 | ||
![]() |
21dde671de | ||
![]() |
22a0884203 | ||
![]() |
76cc2fdb25 | ||
![]() |
b67ff738cb | ||
![]() |
6291e65165 | ||
![]() |
6b2239212c | ||
![]() |
9aa0ac9396 | ||
![]() |
a16040073f | ||
![]() |
f1a16f2eb2 | ||
![]() |
5a9f29bd9d | ||
![]() |
d9417a9aa9 | ||
![]() |
3a2d168c0c | ||
![]() |
4abe2cdb6d | ||
![]() |
83cb4553ad | ||
![]() |
aac415d1fa | ||
![]() |
1e51804b74 | ||
![]() |
d5573be1e9 | ||
![]() |
728cd96cfa | ||
![]() |
bc6c6ce66d | ||
![]() |
20b5ef02b9 | ||
![]() |
a37b6d46e8 | ||
![]() |
4c6b802cb9 | ||
![]() |
6ced8bd137 | ||
![]() |
374eb82d40 | ||
![]() |
9581020e33 | ||
![]() |
476b400315 | ||
![]() |
0e45e0a843 | ||
![]() |
f93f4985b3 | ||
![]() |
67f3da6be2 | ||
![]() |
9ff2cf35c6 | ||
![]() |
86a3a06bb1 | ||
![]() |
f81835cc60 | ||
![]() |
8ab4f8bd93 | ||
![]() |
ae5526c928 | ||
![]() |
335cd41eca | ||
![]() |
4c1fa34f2c | ||
![]() |
f94d3f91cf | ||
![]() |
2b1224b3df | ||
![]() |
5e77f44e05 | ||
![]() |
6e4bd83a69 | ||
![]() |
5de241c2c6 | ||
![]() |
729f61b84c | ||
![]() |
100f7f4147 | ||
![]() |
7dfa6d55ba | ||
![]() |
22515592f0 | ||
![]() |
0a5db20cb8 | ||
![]() |
d91c9dc41f | ||
![]() |
711f189e0e | ||
![]() |
1d579d12d2 | ||
![]() |
624fde5b46 | ||
![]() |
87a3c923a6 | ||
![]() |
c38c82bf6a | ||
![]() |
cd03077b77 | ||
![]() |
871f320de7 | ||
![]() |
3ab089c264 | ||
![]() |
d993ab7b48 | ||
![]() |
b1103ab227 | ||
![]() |
2217959242 | ||
![]() |
d38274acae | ||
![]() |
08e4b07364 | ||
![]() |
8c129ab512 | ||
![]() |
32e9d6fe72 | ||
![]() |
dd8ba803d4 | ||
![]() |
6f90cd5b04 | ||
![]() |
59e6d18c68 | ||
![]() |
81099e6141 | ||
![]() |
9bf6b6ec4a | ||
![]() |
abdbec2523 | ||
![]() |
be62ec31d8 | ||
![]() |
a62bbd1aed | ||
![]() |
d916d8f8df | ||
![]() |
4ce8ae67bc | ||
![]() |
225a18c2ab | ||
![]() |
b23ba4f66d | ||
![]() |
d30b713c74 | ||
![]() |
2dba594954 | ||
![]() |
c419189ffa | ||
![]() |
aa2a2bf9fe | ||
![]() |
1fd231b96c | ||
![]() |
21cd1c4e40 | ||
![]() |
bdf46c5d96 | ||
![]() |
13726e1e8a | ||
![]() |
766c16dc3c | ||
![]() |
cd2df06a10 | ||
![]() |
9a7f2fadf3 | ||
![]() |
2a68f479ed | ||
![]() |
a486bd262b | ||
![]() |
a7247f16f7 | ||
![]() |
39a5483c96 | ||
![]() |
fc12649028 | ||
![]() |
b4b26979de | ||
![]() |
73e9b64926 | ||
![]() |
2307c68ab2 | ||
![]() |
2ce0eae82e | ||
![]() |
45b0e0a7ab | ||
![]() |
317dd69db3 | ||
![]() |
3435f06696 | ||
![]() |
dcfebe6595 | ||
![]() |
b9a759de53 | ||
![]() |
5135d1167c | ||
![]() |
51e30c6a13 | ||
![]() |
b464c0abc5 | ||
![]() |
7469230d59 | ||
![]() |
7ba7e7a319 | ||
![]() |
0dc41eedb0 | ||
![]() |
72a7a6b3c8 | ||
![]() |
533533b639 | ||
![]() |
0cd26250b9 | ||
![]() |
1d545c10c4 | ||
![]() |
d352fab5cd | ||
![]() |
1bb95040ff | ||
![]() |
c0d83be019 | ||
![]() |
1c3f55568b | ||
![]() |
15850f4302 | ||
![]() |
c328eaed0e | ||
![]() |
d42e647d50 | ||
![]() |
0e8f7e6fe3 | ||
![]() |
380f322eda | ||
![]() |
017462c4c1 | ||
![]() |
3e83ebc680 | ||
![]() |
989eca40ec | ||
![]() |
51bd1445a5 | ||
![]() |
0c8378e22a | ||
![]() |
5b219deae2 | ||
![]() |
a311328b38 | ||
![]() |
03fbfc8f7a | ||
![]() |
4bb43cb9b5 | ||
![]() |
e7ee77ad62 | ||
![]() |
d2d8d3d8c2 | ||
![]() |
d3875f5e36 | ||
![]() |
24fec75821 | ||
![]() |
dc4d1c6497 | ||
![]() |
d0fed20d28 | ||
![]() |
1e26314776 | ||
![]() |
448a072e8e | ||
![]() |
0f89478df6 | ||
![]() |
0b96093ae5 | ||
![]() |
52f85f9452 | ||
![]() |
c88dbd3f02 | ||
![]() |
b6b45165ca | ||
![]() |
f53843f9b0 | ||
![]() |
41f94f2be5 | ||
![]() |
23a1bc2595 | ||
![]() |
2afb9b1456 | ||
![]() |
a389621cf1 | ||
![]() |
aa72ea805f | ||
![]() |
a943b4ef6d | ||
![]() |
3642893618 | ||
![]() |
9e5758c905 | ||
![]() |
4f13432df4 | ||
![]() |
8f5d9f2d18 | ||
![]() |
9b2d1f853d | ||
![]() |
f484cb393a | ||
![]() |
a2f29cc817 | ||
![]() |
87976fc845 | ||
![]() |
819c818976 | ||
![]() |
87d6b55022 | ||
![]() |
f086bf9284 | ||
![]() |
144d7276ef | ||
![]() |
c5abd39116 | ||
![]() |
b42adebc39 | ||
![]() |
35c1ee5a79 | ||
![]() |
89c9823b5d | ||
![]() |
da2f87660f | ||
![]() |
19be833058 | ||
![]() |
3c08e16ef2 | ||
![]() |
d2b17fbc6d | ||
![]() |
e526cb462f | ||
![]() |
1237bbebcd | ||
![]() |
65e7a71dff | ||
![]() |
ef28b60bfc | ||
![]() |
f6c9ca0202 | ||
![]() |
403ca48661 | ||
![]() |
3d96420db7 | ||
![]() |
afc011c5c8 | ||
![]() |
681c4a0a0a | ||
![]() |
faac26138a | ||
![]() |
8a799e0971 | ||
![]() |
ec14d1f0fe | ||
![]() |
a6e289c21f | ||
![]() |
7ea0630973 | ||
![]() |
e86a8cee10 | ||
![]() |
1fa90eb865 | ||
![]() |
2cb16a8ad8 | ||
![]() |
f241bfb7b8 | ||
![]() |
075482b417 | ||
![]() |
2a76a50400 | ||
![]() |
9c3c64eb1d | ||
![]() |
bd2c676c31 | ||
![]() |
f6ef53b565 | ||
![]() |
3c496b5694 | ||
![]() |
50320d9d9c | ||
![]() |
d9748cb69b | ||
![]() |
842451c747 | ||
![]() |
cbcb5cfdd6 | ||
![]() |
433df89238 | ||
![]() |
598ede6b37 | ||
![]() |
78b32002d7 | ||
![]() |
579ef3db36 | ||
![]() |
255f8f8fbd | ||
![]() |
e9f03a5455 | ||
![]() |
f2423edb66 | ||
![]() |
44824761f8 | ||
![]() |
93f38ced01 | ||
![]() |
b08c58e6d2 | ||
![]() |
3bd356019f | ||
![]() |
70c0fff557 | ||
![]() |
59a84c3b98 | ||
![]() |
48fdde5640 | ||
![]() |
42175496be | ||
![]() |
dabbd693b6 | ||
![]() |
67556eba74 | ||
![]() |
d6411dc480 | ||
![]() |
86840ee0f5 | ||
![]() |
182de8ef6d | ||
![]() |
c52bffc619 | ||
![]() |
50a432b176 | ||
![]() |
c5a0ec3919 | ||
![]() |
9f18e58c69 | ||
![]() |
20c16af6d3 | ||
![]() |
a1debe45cf | ||
![]() |
80b2079c19 | ||
![]() |
9dfe3dcf79 | ||
![]() |
ea05cf02b4 | ||
![]() |
1b25275333 | ||
![]() |
f90bc04b1a | ||
![]() |
2a06601e3a | ||
![]() |
bcb5e3950b | ||
![]() |
a2478e68c6 | ||
![]() |
dd88086cc7 | ||
![]() |
40af655c39 | ||
![]() |
055decf0cc | ||
![]() |
1f1630dc65 | ||
![]() |
e9cf610299 | ||
![]() |
0f1101bf06 | ||
![]() |
2df51f8b73 | ||
![]() |
e003fa2a66 | ||
![]() |
4470dc1fc9 | ||
![]() |
234346e1d4 | ||
![]() |
65e4586f33 | ||
![]() |
ae4f9a2eb7 | ||
![]() |
a8eff76dd0 | ||
![]() |
afddadbab3 | ||
![]() |
5eb2349a04 | ||
![]() |
e4b7133ec2 | ||
![]() |
a83bfa7a45 | ||
![]() |
5b1d59e38d | ||
![]() |
31ce093a4a | ||
![]() |
e1cc55ff79 | ||
![]() |
076586ded7 | ||
![]() |
c3e30d4d05 | ||
![]() |
dd87882e0f | ||
![]() |
fce8d134a3 | ||
![]() |
7f9fd7ef06 | ||
![]() |
e5c554f947 | ||
![]() |
47922537b7 | ||
![]() |
c5ff01d528 | ||
![]() |
a5830ca15b | ||
![]() |
6d8673724d | ||
![]() |
4e1737c2f5 | ||
![]() |
a7b486de56 | ||
![]() |
1e927834b3 | ||
![]() |
1f2b08f870 | ||
![]() |
067a9a2ade | ||
![]() |
07dbc45d3f | ||
![]() |
482279d7ec | ||
![]() |
7d2a0e6d4e | ||
![]() |
c338a96d8f | ||
![]() |
d2ead4ccbe | ||
![]() |
23c5a0d8eb | ||
![]() |
b555b60b75 | ||
![]() |
3a04b465b1 | ||
![]() |
4ce646facc | ||
![]() |
c33deb446e | ||
![]() |
3f5ee4c6fb | ||
![]() |
7a0fcc3f35 | ||
![]() |
ae5c164179 | ||
![]() |
8f2429e61c | ||
![]() |
c0515c961e | ||
![]() |
47f66049d7 | ||
![]() |
929e7cbaab | ||
![]() |
461043a985 | ||
![]() |
c489a0b7cc | ||
![]() |
e0b125d762 | ||
![]() |
36dad75750 | ||
![]() |
237acbd9c0 | ||
![]() |
a0c017a4dc | ||
![]() |
e18e0dccc6 | ||
![]() |
9bb1ef14be | ||
![]() |
4e9e2db90c | ||
![]() |
4fe98931af | ||
![]() |
431de0dc25 | ||
![]() |
16d32c073d | ||
![]() |
7446f0f809 | ||
![]() |
b8bacef844 | ||
![]() |
09dbc30ace | ||
![]() |
77f26aafda | ||
![]() |
1ab4af5e9d | ||
![]() |
29e7df3575 | ||
![]() |
78edbd3830 | ||
![]() |
9f963a2360 | ||
![]() |
7bb91088f1 | ||
![]() |
df727b774c | ||
![]() |
1f99e2547a | ||
![]() |
bb8bab1a3a | ||
![]() |
3d0a4c9137 | ||
![]() |
108e4a603e | ||
![]() |
a84ec393dd | ||
![]() |
c5adf540a6 | ||
![]() |
947251534f | ||
![]() |
05a2a5d8cc | ||
![]() |
9f2fb18473 | ||
![]() |
0bd34061b9 | ||
![]() |
e1b43e71bb | ||
![]() |
f06ae08a10 | ||
![]() |
dc2cb4d91c | ||
![]() |
848091097e | ||
![]() |
a1cef01c22 | ||
![]() |
d43bbbd5ba | ||
![]() |
6c67aee8a4 | ||
![]() |
653875c02e | ||
![]() |
58b2ac9987 | ||
![]() |
c111d32934 | ||
![]() |
c5ed682c70 | ||
![]() |
c5ed5baf97 | ||
![]() |
c683b60571 | ||
![]() |
6a20805772 | ||
![]() |
de24cbd70b | ||
![]() |
dbdf154e42 | ||
![]() |
a5b67a4207 | ||
![]() |
8c983e1849 | ||
![]() |
d83f41eaf2 | ||
![]() |
584cf7fa57 | ||
![]() |
c5cbfb1a3c | ||
![]() |
0e09b2b12a | ||
![]() |
d3421270b1 | ||
![]() |
6c330fe4d2 | ||
![]() |
e31e18b3f3 | ||
![]() |
2a41e8c8b0 | ||
![]() |
7428568279 | ||
![]() |
df4ea8794f | ||
![]() |
a84af82740 | ||
![]() |
82b1dbb01b | ||
![]() |
8f9d2df8db | ||
![]() |
73c7ecf716 | ||
![]() |
8842f099ed | ||
![]() |
6ea43b65d3 | ||
![]() |
c077834553 | ||
![]() |
a35c0fc1a7 | ||
![]() |
37f5756ddb | ||
![]() |
701094596f | ||
![]() |
aa8165d81a | ||
![]() |
a9fb598134 | ||
![]() |
c67fc71069 | ||
![]() |
85028b060c | ||
![]() |
b652840090 | ||
![]() |
52a607d0fb | ||
![]() |
e5904584e7 | ||
![]() |
c45d415579 | ||
![]() |
92790287e1 | ||
![]() |
28e8caea54 | ||
![]() |
735d6bf85c | ||
![]() |
3a9a8d4e5b | ||
![]() |
37ff909c37 | ||
![]() |
009528255e | ||
![]() |
474af8b29b | ||
![]() |
1ea268df71 | ||
![]() |
30183d11dc | ||
![]() |
be16260c3c | ||
![]() |
f44544be0e | ||
![]() |
13ccd086b4 | ||
![]() |
7371d42e97 | ||
![]() |
3ea13893dd | ||
![]() |
188bb85fe8 | ||
![]() |
e7aab960ff | ||
![]() |
466b130ca5 | ||
![]() |
df352ec926 | ||
![]() |
37b0a87aae | ||
![]() |
f13a9a260e | ||
![]() |
0fc4914500 | ||
![]() |
657cfb6512 | ||
![]() |
15ff4f12ac | ||
![]() |
702e8543b8 | ||
![]() |
58ec0d0cdd | ||
![]() |
b9f7e592ab | ||
![]() |
900313bbef | ||
![]() |
20fa1de3ef | ||
![]() |
ada3aa410a | ||
![]() |
416472e515 | ||
![]() |
cb88b3355b | ||
![]() |
4bbc20e24b | ||
![]() |
34d93ac968 | ||
![]() |
ba984572c8 | ||
![]() |
eb1e00ef7b | ||
![]() |
5aecff2f1a | ||
![]() |
35f9d6f72a | ||
![]() |
6bc6b3e772 | ||
![]() |
74532116ab | ||
![]() |
5b1521672f | ||
![]() |
c676ed980d | ||
![]() |
0168f549d4 | ||
![]() |
703903faf4 | ||
![]() |
220f96ecb4 | ||
![]() |
8ebe7e74e8 | ||
![]() |
7e9153171a | ||
![]() |
6e930aeaa9 | ||
![]() |
f91e12d593 | ||
![]() |
484b828f9d | ||
![]() |
2169a930d2 | ||
![]() |
45b3898683 | ||
![]() |
0a58aff795 | ||
![]() |
7f1a817749 | ||
![]() |
5f512db55f | ||
![]() |
acdca8320b | ||
![]() |
857db43428 | ||
![]() |
12aa51c551 | ||
![]() |
f755ed9710 | ||
![]() |
53a6b8178a | ||
![]() |
359474e1ca | ||
![]() |
e7ed402b64 | ||
![]() |
13e431a6ac | ||
![]() |
4266cfdad6 | ||
![]() |
8128565367 | ||
![]() |
14f5c79229 | ||
![]() |
1bc17b1cb1 | ||
![]() |
42f8744594 | ||
![]() |
8d3e33e343 | ||
![]() |
f5fd5a22e9 | ||
![]() |
f6cbe1c4bc | ||
![]() |
3811d7739d | ||
![]() |
6902d5fb02 | ||
![]() |
df801995ff | ||
![]() |
c1a9034f3f | ||
![]() |
1a95a6c028 | ||
![]() |
54cb67b316 | ||
![]() |
802a82f335 | ||
![]() |
7112f77b7c | ||
![]() |
fad68a1bf0 | ||
![]() |
3b3dc28d42 | ||
![]() |
f06317f3d0 | ||
![]() |
97c18ef67c | ||
![]() |
92e1e08e1c | ||
![]() |
139ab630e0 | ||
![]() |
1440534513 | ||
![]() |
c993563185 | ||
![]() |
f029d50029 | ||
![]() |
067afaceda | ||
![]() |
52b1176464 | ||
![]() |
4f8cd7fe88 | ||
![]() |
eb781c54f8 | ||
![]() |
b988241b8b | ||
![]() |
b4d69de796 | ||
![]() |
0fde081db5 | ||
![]() |
c8e44703d5 | ||
![]() |
4b6f5282b4 | ||
![]() |
c66899741a | ||
![]() |
8b6cdd8ab8 | ||
![]() |
2836484d12 | ||
![]() |
a869e7a3bd | ||
![]() |
90fe7d8e03 | ||
![]() |
0fbd579cbb | ||
![]() |
0b42ee83bb | ||
![]() |
be92638cf2 | ||
![]() |
3e560ce43d | ||
![]() |
273d477938 | ||
![]() |
12afbcd03d | ||
![]() |
6d41232a3e | ||
![]() |
4561112fe1 | ||
![]() |
cbcac452c0 | ||
![]() |
c0da03cfe8 | ||
![]() |
98456b8dca | ||
![]() |
a02ae261cf | ||
![]() |
6ee110b88d | ||
![]() |
0d2a95190c | ||
![]() |
ca9b14696c | ||
![]() |
2bf6ff5604 | ||
![]() |
f35cc90ea4 | ||
![]() |
63a2ccf3da | ||
![]() |
eb72f81bf7 | ||
![]() |
66254e79d3 | ||
![]() |
a8831bfa73 | ||
![]() |
ec4e44fcf2 | ||
![]() |
583d55298e | ||
![]() |
83859c1925 | ||
![]() |
5664b6a271 | ||
![]() |
53c3deda16 | ||
![]() |
d28fe8730d | ||
![]() |
92de4022cb | ||
![]() |
c3ae2467ae | ||
![]() |
94445283ac | ||
![]() |
5a5440813e | ||
![]() |
32d89fe611 | ||
![]() |
26ccdf21f9 | ||
![]() |
fb2241339d | ||
![]() |
99b2babad4 | ||
![]() |
735f392663 | ||
![]() |
4fddfe4f6b | ||
![]() |
16080cf46d | ||
![]() |
59aa071095 | ||
![]() |
5c7e23252b | ||
![]() |
240b70ad4b | ||
![]() |
1422b3393f | ||
![]() |
c0df38c23d | ||
![]() |
c146fea519 | ||
![]() |
6f8a6e33fc | ||
![]() |
7b976c39e6 | ||
![]() |
d9b28a79f1 | ||
![]() |
78d10b4c1b | ||
![]() |
5497016015 | ||
![]() |
302a580847 | ||
![]() |
62ca724415 | ||
![]() |
a70dfce490 | ||
![]() |
cb6f3f9195 | ||
![]() |
a666e6c39b | ||
![]() |
5606dc505e | ||
![]() |
3bf7a477a6 | ||
![]() |
2a45071501 | ||
![]() |
15617953ab | ||
![]() |
99cf659742 | ||
![]() |
ab17f50339 | ||
![]() |
d06b0c0b69 | ||
![]() |
351b942860 | ||
![]() |
272ac594a8 | ||
![]() |
365c3a27e8 | ||
![]() |
cc5f813f5e | ||
![]() |
87cf878860 | ||
![]() |
ba1ac3434e | ||
![]() |
f3a78ec059 | ||
![]() |
95884e1215 | ||
![]() |
d427d8df2d | ||
![]() |
a98565285b | ||
![]() |
01be9b0132 | ||
![]() |
49059236cd | ||
![]() |
529f6f94a3 | ||
![]() |
eacac9f071 | ||
![]() |
f13c15365f | ||
![]() |
ca035e419a | ||
![]() |
699641977e | ||
![]() |
aea3734ca8 | ||
![]() |
5ca286db5b | ||
![]() |
f4b9d16497 | ||
![]() |
0578196839 | ||
![]() |
f49fdbe886 | ||
![]() |
0d460e32de | ||
![]() |
2ee8b3c111 | ||
![]() |
e1379e5cf3 | ||
![]() |
b14b84f58b | ||
![]() |
444c9138e0 | ||
![]() |
83e40daec1 | ||
![]() |
dd612bbc91 | ||
![]() |
3f58521db2 | ||
![]() |
065834567a | ||
![]() |
f23b4fbf59 | ||
![]() |
426a8e5b61 | ||
![]() |
6fcb95b9e1 | ||
![]() |
50c95b4291 | ||
![]() |
f24adec51f | ||
![]() |
cfe354a35b | ||
![]() |
20743f2b51 | ||
![]() |
4c3d6a72a1 | ||
![]() |
1cd3f5c615 | ||
![]() |
9abae121fc | ||
![]() |
0d582fde46 | ||
![]() |
ecdd92f08e | ||
![]() |
e56cd8f3bd | ||
![]() |
14c8079353 | ||
![]() |
878df5afe4 | ||
![]() |
7e4b49634f | ||
![]() |
61cb8cb0b2 | ||
![]() |
04fbca7fe5 | ||
![]() |
54a2c660ae | ||
![]() |
113a349b56 | ||
![]() |
55d5859382 | ||
![]() |
791f74286d | ||
![]() |
aba6cf50e1 | ||
![]() |
02ba1f7230 | ||
![]() |
e04486564d | ||
![]() |
b140f6dc9a | ||
![]() |
ea66bc7f40 | ||
![]() |
0554dceed7 | ||
![]() |
86c4ce6d9f | ||
![]() |
0fba5dc75c | ||
![]() |
c39253454a | ||
![]() |
bc54087161 | ||
![]() |
2393ff7c4c | ||
![]() |
6582e9c718 | ||
![]() |
10b9f03410 | ||
![]() |
6987d75bb3 | ||
![]() |
4640525785 | ||
![]() |
7c7c6c349c | ||
![]() |
a2d013cd51 | ||
![]() |
6de89958ad | ||
![]() |
01c8032f20 | ||
![]() |
245f477760 | ||
![]() |
47a8e8e9fd | ||
![]() |
30b14a619d | ||
![]() |
f3cf51f7ac | ||
![]() |
2f79e110c4 | ||
![]() |
38e09d84fd | ||
![]() |
bc49f3813f | ||
![]() |
37848357b3 | ||
![]() |
de81eeb2b2 | ||
![]() |
9b15886310 | ||
![]() |
aac1b25a2e | ||
![]() |
abb338fea3 | ||
![]() |
b094d8322a | ||
![]() |
721a8cf6e3 | ||
![]() |
1049277e17 | ||
![]() |
44a4ce44d4 | ||
![]() |
7e9f900f35 | ||
![]() |
ec681b841e | ||
![]() |
a4002a49cc | ||
![]() |
032954be2b | ||
![]() |
2e7840bfcd | ||
![]() |
b0afe6c828 | ||
![]() |
bf281c2e36 | ||
![]() |
95ff7afa98 | ||
![]() |
da30d196da | ||
![]() |
dd10987e3b | ||
![]() |
1b9ada13a2 | ||
![]() |
66b215b44b | ||
![]() |
88b1ea9d3b | ||
![]() |
597f7dbeb8 | ||
![]() |
62d5684435 | ||
![]() |
499781baf1 | ||
![]() |
1da6210617 | ||
![]() |
057d258660 | ||
![]() |
ec433fa852 | ||
![]() |
6185f421b8 | ||
![]() |
ab7ae3f89a | ||
![]() |
7048b94cc2 | ||
![]() |
c8c11b31c8 | ||
![]() |
6dd732e1c2 | ||
![]() |
693963b072 | ||
![]() |
bc7d0c7d71 | ||
![]() |
07ee4d5915 | ||
![]() |
bc45092e03 | ||
![]() |
4b6068e13b | ||
![]() |
a7db756c76 | ||
![]() |
9d328b3aff | ||
![]() |
14211536d8 | ||
![]() |
9a7351b1f9 | ||
![]() |
b323333bd1 | ||
![]() |
8724d6f836 | ||
![]() |
18ddbf986c | ||
![]() |
dc55574100 | ||
![]() |
98cce77e1d | ||
![]() |
38898ab45e | ||
![]() |
40267f32e5 | ||
![]() |
3277e06740 | ||
![]() |
c557a2daf0 | ||
![]() |
2798076bb1 | ||
![]() |
0e02cb14ec | ||
![]() |
9443169283 | ||
![]() |
259b25ab68 | ||
![]() |
c8e363d4f3 | ||
![]() |
8ecc8b2e74 | ||
![]() |
62d763e65a | ||
![]() |
d54a56e11b | ||
![]() |
73b24aa5ae | ||
![]() |
110279cf4c | ||
![]() |
ddc4341707 | ||
![]() |
47fdeada01 | ||
![]() |
c3fc7d792e | ||
![]() |
33ac29f269 | ||
![]() |
1c7c6b2a0f | ||
![]() |
5ab9ee7c34 | ||
![]() |
056de6fc13 | ||
![]() |
ded9ee3251 | ||
![]() |
dc4f8c6c98 | ||
![]() |
282c3fab8c | ||
![]() |
63a808b306 | ||
![]() |
ca7622027d | ||
![]() |
f923078445 | ||
![]() |
f81150ea31 | ||
![]() |
0d057ab60b | ||
![]() |
c5a7879c55 | ||
![]() |
d24a9a2583 | ||
![]() |
6a7ce1639a | ||
![]() |
e75f6f85e7 | ||
![]() |
9d4a8702cb | ||
![]() |
7a91ea7107 | ||
![]() |
0e818dfdc8 | ||
![]() |
2228f00c0a | ||
![]() |
e2e46d675e | ||
![]() |
14b8a1d8a2 | ||
![]() |
7ab07c69aa | ||
![]() |
e9e2e9a711 | ||
![]() |
84de31e85b | ||
![]() |
31cc0ce7a8 | ||
![]() |
5c7dc3097a | ||
![]() |
3a09999cca | ||
![]() |
cf1e468395 | ||
![]() |
871e529bf2 | ||
![]() |
5e9ccd440e | ||
![]() |
657bc32e9b | ||
![]() |
d7a48bd855 | ||
![]() |
d2746689f9 | ||
![]() |
f093228f71 | ||
![]() |
f3e054d15e | ||
![]() |
86a3ad4b1f | ||
![]() |
aa5a768ef0 | ||
![]() |
b6cb37db43 | ||
![]() |
3ca25590c7 | ||
![]() |
c3b902ae65 | ||
![]() |
014602266b | ||
![]() |
696a2148f0 | ||
![]() |
e086cf56fc | ||
![]() |
6d5dcbe89f | ||
![]() |
54f5042c3c | ||
![]() |
927f38e999 | ||
![]() |
638ec9c2ea | ||
![]() |
27c5119664 | ||
![]() |
8542000540 | ||
![]() |
9c5c53f4ae | ||
![]() |
a2ca9361e1 | ||
![]() |
9042baf13d | ||
![]() |
957cff3447 | ||
![]() |
fbd6d11a5c | ||
![]() |
6ccb766b2e | ||
![]() |
df7be136f8 | ||
![]() |
3abbb08e31 | ||
![]() |
715b6df2fb | ||
![]() |
a64fe45175 | ||
![]() |
f0690d0ac5 | ||
![]() |
3049bc8215 | ||
![]() |
4f9b59ed6d | ||
![]() |
d05e849299 | ||
![]() |
76f06e120c | ||
![]() |
fdf83eaef8 | ||
![]() |
b214364ee9 | ||
![]() |
adfcaa2f09 | ||
![]() |
bd3c8d19fa | ||
![]() |
7ae2d6d5bb | ||
![]() |
44e5a98188 | ||
![]() |
093722c7d6 | ||
![]() |
ca2dd38f9b | ||
![]() |
bf0342eb06 | ||
![]() |
cf7af8e3aa | ||
![]() |
19f8f58618 | ||
![]() |
649d82425a | ||
![]() |
1f45db0fac | ||
![]() |
49ceb6f6e5 | ||
![]() |
9d0eb9fb08 | ||
![]() |
ec65a69496 | ||
![]() |
f498a64413 | ||
![]() |
4b993c932e | ||
![]() |
5aed1d0e97 | ||
![]() |
4f70e6b881 | ||
![]() |
e3751f5a57 | ||
![]() |
46d9280490 | ||
![]() |
40c0a9bf51 | ||
![]() |
0ca828325d | ||
![]() |
aa74a68ca8 | ||
![]() |
419922a2aa | ||
![]() |
e970e6cbc5 | ||
![]() |
90b04ddd9b | ||
![]() |
96ce701f64 | ||
![]() |
b506c94d9a | ||
![]() |
d4962685d6 | ||
![]() |
24a6013195 | ||
![]() |
de3962412f | ||
![]() |
0603c57a60 | ||
![]() |
71464e6914 | ||
![]() |
2a96fd466f | ||
![]() |
d6e27ee9b5 | ||
![]() |
a21511b683 | ||
![]() |
984fa08f14 | ||
![]() |
fbc2f999bf | ||
![]() |
86cb96cd21 | ||
![]() |
9bc955a5d4 | ||
![]() |
49dc6ac30b | ||
![]() |
5b93ce3481 | ||
![]() |
369adbdfe9 | ||
![]() |
c5b6376980 | ||
![]() |
64c7bc78af | ||
![]() |
3a4873aa1b | ||
![]() |
e0a3b2d8c3 | ||
![]() |
10f6e4e751 | ||
![]() |
3a374dcdba | ||
![]() |
b6f4611994 | ||
![]() |
b58f7a0c4d | ||
![]() |
3b482b265b | ||
![]() |
f94b51e410 | ||
![]() |
6185336c3a | ||
![]() |
bd8829a432 | ||
![]() |
89d8d11db3 | ||
![]() |
644baca439 | ||
![]() |
3cc111e5dd | ||
![]() |
baa614c094 | ||
![]() |
95cb9460d4 | ||
![]() |
e433c5160a | ||
![]() |
440b7171b0 | ||
![]() |
cfd2e57950 | ||
![]() |
a5d4855530 | ||
![]() |
448a034766 | ||
![]() |
d228a96944 | ||
![]() |
51a3fb98e1 | ||
![]() |
04dd345ef4 | ||
![]() |
3ba221831d | ||
![]() |
b30a65015d | ||
![]() |
0ea71db628 | ||
![]() |
b64d007315 | ||
![]() |
88f954fc28 | ||
![]() |
f6acb174a4 | ||
![]() |
b8a927b163 | ||
![]() |
4e93b06772 | ||
![]() |
65934f5e00 | ||
![]() |
fb89aab252 | ||
![]() |
db9a0edce5 | ||
![]() |
a85baa5cca | ||
![]() |
7d6125c367 | ||
![]() |
2caeea2a14 | ||
![]() |
c3e2447924 | ||
![]() |
f12d888e42 | ||
![]() |
f92966d57a | ||
![]() |
245c75ab2c | ||
![]() |
ef0b6d947e | ||
![]() |
bd511d17e9 | ||
![]() |
b0b73b5d97 | ||
![]() |
a8d2773f5d | ||
![]() |
9749a79f7f | ||
![]() |
6a7cbf1a47 | ||
![]() |
ff1d1474d4 | ||
![]() |
2b18df8398 | ||
![]() |
d978d35533 | ||
![]() |
10cd70e858 | ||
![]() |
0552c2f245 | ||
![]() |
a08df8f9ef | ||
![]() |
1a906b746e | ||
![]() |
c916732f4e | ||
![]() |
22df6d5638 | ||
![]() |
4783f264df | ||
![]() |
64c3ff4573 | ||
![]() |
9c105c988c | ||
![]() |
c7bf92f20b | ||
![]() |
15548d9bb2 | ||
![]() |
441379b6e8 | ||
![]() |
6e5d117720 | ||
![]() |
c1aea93389 | ||
![]() |
e28af61ac2 | ||
![]() |
315180816d | ||
![]() |
fc94c9602b | ||
![]() |
25c8796888 | ||
![]() |
ea871aaa7b | ||
![]() |
be376ef2ac | ||
![]() |
0b77b93801 | ||
![]() |
9d5ee6291d | ||
![]() |
0476f0d367 | ||
![]() |
4a98a0da86 | ||
![]() |
9cb5e7809a | ||
![]() |
3a22456032 | ||
![]() |
0d609d9e2c | ||
![]() |
555313fc4c | ||
![]() |
8a609505f1 | ||
![]() |
cc0f792e60 | ||
![]() |
9f3e69dbf1 | ||
![]() |
7d42a41df4 | ||
![]() |
f7593002d1 | ||
![]() |
262a7797e7 | ||
![]() |
6364767d5a | ||
![]() |
4d285fe4b6 | ||
![]() |
cde46b77de | ||
![]() |
722ddfb736 | ||
![]() |
155c026e99 | ||
![]() |
44cb7e148b | ||
![]() |
3a517317a3 | ||
![]() |
b32cbe1651 | ||
![]() |
18b0a44ae3 | ||
![]() |
dd68943ae8 | ||
![]() |
f019490989 | ||
![]() |
4ee7fa2af7 | ||
![]() |
032a3f562f | ||
![]() |
9d438035cb | ||
![]() |
7f5d792ff4 | ||
![]() |
5d0c22c374 | ||
![]() |
e7a52289c8 | ||
![]() |
4997786b9f | ||
![]() |
5b51aa2b78 | ||
![]() |
5c565def63 | ||
![]() |
c4502c2762 | ||
![]() |
2ea79db343 | ||
![]() |
c92924db15 | ||
![]() |
45ce804ee9 | ||
![]() |
2e9c147c44 | ||
![]() |
24d09cc134 | ||
![]() |
e7109a0855 | ||
![]() |
b7964f7f12 | ||
![]() |
31bb92c398 | ||
![]() |
d95731e87b | ||
![]() |
bff3c47dc2 | ||
![]() |
94b32c38e4 | ||
![]() |
2214ab3a17 | ||
![]() |
8631adaaec | ||
![]() |
2cfada1fc8 | ||
![]() |
065e82534e | ||
![]() |
a6cbda63b1 | ||
![]() |
15ddd0f680 | ||
![]() |
841261a36e | ||
![]() |
f30a2dc43c | ||
![]() |
37132e8d3e | ||
![]() |
b9dd88e30f | ||
![]() |
e3ec2c22a2 | ||
![]() |
e36dbdead3 | ||
![]() |
4358574889 | ||
![]() |
bbdd6684fe | ||
![]() |
07cd774619 | ||
![]() |
83b077d5f3 | ||
![]() |
36104652cd | ||
![]() |
d75c797553 | ||
![]() |
3fa9e6d5b2 | ||
![]() |
bbb532b5aa | ||
![]() |
15621d76b9 | ||
![]() |
73eb4e3389 | ||
![]() |
3be0eb2ac6 | ||
![]() |
c195b1ecb9 | ||
![]() |
4c265a674e | ||
![]() |
634b4f392a | ||
![]() |
2cca7a8308 | ||
![]() |
ffc584e5e6 | ||
![]() |
9a73aba7fc | ||
![]() |
22adb293f7 | ||
![]() |
e8534e61cd | ||
![]() |
6168e4668c | ||
![]() |
aa0d1c27c8 | ||
![]() |
35859f566b | ||
![]() |
1ad7055fbe | ||
![]() |
2287aa9a06 | ||
![]() |
28d358aa43 | ||
![]() |
8744d1a9ec | ||
![]() |
68f9a32629 | ||
![]() |
2f5062b33e | ||
![]() |
57b624d2da | ||
![]() |
69539728ec | ||
![]() |
92b014a706 | ||
![]() |
a5ace90bd6 | ||
![]() |
8212ca3aee | ||
![]() |
0b9b0a39d8 | ||
![]() |
bcf6dad5de | ||
![]() |
3f0347bc18 | ||
![]() |
b401c225dd | ||
![]() |
721e6ba935 | ||
![]() |
fa342c42fb | ||
![]() |
c31e0d72b3 | ||
![]() |
f672b1b810 | ||
![]() |
4f324c7fd7 | ||
![]() |
0137664296 | ||
![]() |
69313054a2 | ||
![]() |
d6c4c3c66a | ||
![]() |
6d0753c5e9 | ||
![]() |
019efd6db7 | ||
![]() |
4b3d739774 | ||
![]() |
c345b1aa19 | ||
![]() |
d6d4d4a8a3 | ||
![]() |
85017433db | ||
![]() |
d03248c10f | ||
![]() |
b86cf5ac80 | ||
![]() |
abc36b6f9b | ||
![]() |
88fcce18f9 | ||
![]() |
7137481251 | ||
![]() |
842b4929e4 | ||
![]() |
c9a923bb34 | ||
![]() |
d68429b49b | ||
![]() |
38abd9e756 | ||
![]() |
0e35750741 | ||
![]() |
e3ef019995 | ||
![]() |
4486cdc14f | ||
![]() |
c7c453404b | ||
![]() |
546cac2b09 | ||
![]() |
86f537971c | ||
![]() |
4dd5e7c4b9 | ||
![]() |
3b850ae3b9 | ||
![]() |
361932cf7f | ||
![]() |
73f8225669 | ||
![]() |
f6d7170537 | ||
![]() |
35c1139293 | ||
![]() |
590ff474c7 | ||
![]() |
b384e2ee1d | ||
![]() |
6e7a2e4c9e | ||
![]() |
19e07f6785 | ||
![]() |
097f7c846e | ||
![]() |
01d6fdf080 | ||
![]() |
7023e0a800 | ||
![]() |
3ca94633cd | ||
![]() |
ac3e035af7 | ||
![]() |
538fd146fb | ||
![]() |
f1d438f3fd | ||
![]() |
49bb9cd398 | ||
![]() |
7d00a254da | ||
![]() |
ad9ad07cbd | ||
![]() |
598d60ab7e | ||
![]() |
d3f61027c7 | ||
![]() |
8ecbbd0719 | ||
![]() |
17943dcf1a | ||
![]() |
0150e6d689 | ||
![]() |
b5260051a0 | ||
![]() |
b1f17ff508 | ||
![]() |
f4b3f62a46 | ||
![]() |
519cbdd872 | ||
![]() |
28cc158a3f | ||
![]() |
c99bf518b3 | ||
![]() |
86d3244a22 | ||
![]() |
618859788c | ||
![]() |
8008633c02 | ||
![]() |
e840184e7f | ||
![]() |
5aa17208a5 | ||
![]() |
bd7d46f446 | ||
![]() |
013d14d723 | ||
![]() |
b87b9d3e26 | ||
![]() |
bdbce8a7da | ||
![]() |
f661ba7c40 | ||
![]() |
a87dc0346d | ||
![]() |
7470ff5437 | ||
![]() |
fe10ffc7d7 | ||
![]() |
1628b4ca3e | ||
![]() |
74bed8b30a | ||
![]() |
e4287ee7fb | ||
![]() |
71a2646c5b | ||
![]() |
39fbe69847 | ||
![]() |
aa8ef338c5 | ||
![]() |
b9f392da94 | ||
![]() |
40223ee48a | ||
![]() |
0d2ae948e8 | ||
![]() |
7a04307c32 | ||
![]() |
da5ae971e1 | ||
![]() |
d8bbb62081 | ||
![]() |
f5215c1f29 | ||
![]() |
54706e51af | ||
![]() |
2ee66b0b22 | ||
![]() |
2082079c7e | ||
![]() |
0c30803fdd | ||
![]() |
3745de490f | ||
![]() |
cf0e6b8f86 | ||
![]() |
e184e9a97c | ||
![]() |
4cd304b4c6 | ||
![]() |
8bcffb59e6 | ||
![]() |
f2058851d0 | ||
![]() |
3a2ad6e578 | ||
![]() |
45e751a8be | ||
![]() |
6d9e54043c | ||
![]() |
2b68cc481e | ||
![]() |
49f7a457cd | ||
![]() |
c18b3db621 | ||
![]() |
cf450d6d4a | ||
![]() |
93774f17c8 | ||
![]() |
349e8a9203 | ||
![]() |
150f092e9a | ||
![]() |
69020cc516 | ||
![]() |
a01a6d0f43 | ||
![]() |
52a15da966 | ||
![]() |
322d3dcab1 | ||
![]() |
234d05d044 | ||
![]() |
8b7953280a | ||
![]() |
0ba9eb2eeb | ||
![]() |
508a0c7815 | ||
![]() |
264eaa5cbf |
5
.dockerignore
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
node_modules
|
||||||
|
.git
|
||||||
|
.DS_Store
|
||||||
|
*.log
|
||||||
|
engine
|
12
.editorconfig
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
end_of_line = lf
|
||||||
|
charset = utf-8
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
insert_final_newline = true
|
||||||
|
|
||||||
|
[*.md]
|
||||||
|
trim_trailing_whitespace = false
|
12
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
@@ -4,12 +4,13 @@ body:
|
|||||||
- type: markdown
|
- type: markdown
|
||||||
attributes:
|
attributes:
|
||||||
value: |
|
value: |
|
||||||
Thank you for filing a bug report.
|
Thank you for filing a bug report!
|
||||||
|
|
||||||
## Important
|
## Important
|
||||||
- Please search existing issues to avoid creating duplicates.
|
- Please search existing issues to avoid creating duplicates.
|
||||||
- For enhancement requests, please use GitHub Discussions.
|
- For enhancement requests, please use GitHub Discussions.
|
||||||
- Please fill out the template below to the best of your ability.
|
- Please fill out the template below to the best of your ability.
|
||||||
|
- Please describe the issue as much as possible and provide steps to reproduce it along with visual aids if possible.
|
||||||
- type: checkboxes
|
- type: checkboxes
|
||||||
id: captchas
|
id: captchas
|
||||||
attributes:
|
attributes:
|
||||||
@@ -38,7 +39,7 @@ body:
|
|||||||
id: version
|
id: version
|
||||||
attributes:
|
attributes:
|
||||||
label: Version
|
label: Version
|
||||||
description: What version of our software are you running? Please DO NOT report Classic bugs.
|
description: What version of our software are you running? Please do not use "latest" or "newest" as version numbers. Go to `Help -> About Zen` to find the version number.
|
||||||
placeholder: 1.0.0
|
placeholder: 1.0.0
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
@@ -48,15 +49,18 @@ body:
|
|||||||
label: What platform are you seeing the problem on?
|
label: What platform are you seeing the problem on?
|
||||||
multiple: true
|
multiple: true
|
||||||
options:
|
options:
|
||||||
- Linux
|
- Linux (AppImage)
|
||||||
|
- Linux (Flatpak)
|
||||||
|
- Linux (Tarball)
|
||||||
- macOS - aarch64
|
- macOS - aarch64
|
||||||
- macOS - Intel
|
- macOS - Intel
|
||||||
- Windows
|
- Windows
|
||||||
|
- Other
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
- type: textarea
|
- type: textarea
|
||||||
id: logs
|
id: logs
|
||||||
attributes:
|
attributes:
|
||||||
label: Relevant log output
|
label: Relevant log output if applicable
|
||||||
description: Please copy and paste any relevant log output. This will be automatically formatted into code, so no need for backticks.
|
description: Please copy and paste any relevant log output. This will be automatically formatted into code, so no need for backticks.
|
||||||
render: shell
|
render: shell
|
||||||
|
4
.github/ISSUE_TEMPLATE/config.yml
vendored
@@ -1 +1,5 @@
|
|||||||
blank_issues_enabled: false
|
blank_issues_enabled: false
|
||||||
|
contact_links:
|
||||||
|
- name: Feature Request
|
||||||
|
url: https://github.com/zen-browser/desktop/discussions
|
||||||
|
about: Please use GitHub discussions for feature requests.
|
||||||
|
508
.github/workflows/build.yml
vendored
@@ -16,10 +16,10 @@ on:
|
|||||||
update_branch:
|
update_branch:
|
||||||
description: 'Update branch with new version'
|
description: 'Update branch with new version'
|
||||||
required: true
|
required: true
|
||||||
default: 'alpha'
|
default: 'release'
|
||||||
type: 'choice'
|
type: 'choice'
|
||||||
options:
|
options:
|
||||||
- 'alpha'
|
- 'release'
|
||||||
- 'twilight'
|
- 'twilight'
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
@@ -36,7 +36,7 @@ on:
|
|||||||
update_branch:
|
update_branch:
|
||||||
description: 'Update branch with new version'
|
description: 'Update branch with new version'
|
||||||
required: true
|
required: true
|
||||||
default: 'alpha'
|
default: 'release'
|
||||||
type: 'string'
|
type: 'string'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
@@ -54,52 +54,111 @@ jobs:
|
|||||||
echo "GITHUB_REPOSITORY_OWNER: ${{ github.repository_owner }}"
|
echo "GITHUB_REPOSITORY_OWNER: ${{ github.repository_owner }}"
|
||||||
echo "GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}"
|
echo "GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}"
|
||||||
|
|
||||||
|
buildid:
|
||||||
|
name: Generate build ID
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
buildids: ${{ steps.get.outputs.bid }}
|
||||||
|
steps:
|
||||||
|
- id: get
|
||||||
|
shell: bash -xe {0}
|
||||||
|
run: |
|
||||||
|
bdat=`date +"%Y%m%d%I%M%S"`
|
||||||
|
echo "bid=${bdat}" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
start-self-host:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: debug-inputs
|
||||||
|
steps:
|
||||||
|
- name: Download aws-cli
|
||||||
|
run: |
|
||||||
|
curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
|
||||||
|
unzip awscliv2.zip
|
||||||
|
sudo ./aws/install --update
|
||||||
|
|
||||||
|
- name: Start self-hosted runner
|
||||||
|
if: ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
|
run: |
|
||||||
|
echo "Starting self-hosted runner"
|
||||||
|
echo "${{ secrets.SELF_HOSTED_RUNNER_START_SCRIPT }}" | base64 -d > start.sh
|
||||||
|
sudo chmod +x start.sh
|
||||||
|
bash ./start.sh
|
||||||
|
|
||||||
|
- name: Remove self-hosted runner script
|
||||||
|
if: always() && ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
|
run: |
|
||||||
|
echo "Removing self-hosted runner script"
|
||||||
|
rm start.sh || true
|
||||||
|
|
||||||
|
check-build-is-correct:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: [debug-inputs]
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Check if correct branch
|
||||||
|
if: ${{ inputs.create_release }}
|
||||||
|
run: |
|
||||||
|
echo "Checking if we are on the correct branch"
|
||||||
|
git branch
|
||||||
|
git status
|
||||||
|
git branch --show-current
|
||||||
|
branch="${{ inputs.update_branch }}"
|
||||||
|
if [[ $branch == "twilight" ]]; then
|
||||||
|
branch="dev"
|
||||||
|
elif [[ $branch == "release" ]]; then
|
||||||
|
branch="stable"
|
||||||
|
fi
|
||||||
|
if [[ $(git branch --show-current) != $branch ]]; then
|
||||||
|
echo ">>> Branch mismatch"
|
||||||
|
# exit 1
|
||||||
|
else
|
||||||
|
echo ">>> Branch matches"
|
||||||
|
fi
|
||||||
|
|
||||||
build-data:
|
build-data:
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
name: Generate build data
|
name: Generate build data
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: debug-inputs
|
needs: check-build-is-correct
|
||||||
outputs:
|
outputs:
|
||||||
build_date: ${{ steps.data.outputs.builddate }}
|
build_date: ${{ steps.data.outputs.builddate }}
|
||||||
version: ${{ steps.data.outputs.version }}
|
version: ${{ steps.data.outputs.version }}
|
||||||
build_time: ${{ steps.data.outputs.buildtime }}
|
build_time: ${{ steps.data.outputs.buildtime }}
|
||||||
steps:
|
steps:
|
||||||
- name: Install Node.js
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Install pnpm
|
- name: Setup Node.js
|
||||||
run: npm install -g pnpm
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
- name: Get pnpm store directory
|
node-version-file: '.nvmrc'
|
||||||
id: pnpm-cache
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: pnpm install
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
- name: Setup Surfer
|
- name: Setup Surfer
|
||||||
run: |
|
run: |
|
||||||
npm i -g @zen-browser/surfer
|
npm i -g @zen-browser/surfer
|
||||||
|
|
||||||
- name: Bump version
|
- name: Bump version
|
||||||
if: ${{ inputs.update_version && inputs.update_branch == 'alpha' }}
|
if: ${{ inputs.update_version && inputs.update_branch == 'release' }}
|
||||||
run: |
|
run: |
|
||||||
pnpm surfer ci --brand ${{ inputs.update_branch }} --bump prerelease
|
npm run surfer -- ci --brand ${{ inputs.update_branch }} --bump prerelease
|
||||||
|
|
||||||
- name: Bump version without new version
|
- name: Bump version without new version
|
||||||
if: ${{ !inputs.update_version || inputs.update_branch == 'twilight' }}
|
if: ${{ !inputs.update_version || inputs.update_branch == 'twilight' }}
|
||||||
run: |
|
run: |
|
||||||
pnpm surfer ci --brand ${{ inputs.update_branch }}
|
npm run surfer -- ci --brand ${{ inputs.update_branch }}
|
||||||
|
|
||||||
- name: Debug
|
- name: Debug
|
||||||
run: |
|
run: |
|
||||||
@@ -115,54 +174,52 @@ jobs:
|
|||||||
echo "version=$(surfer get version | xargs)" >> $GITHUB_OUTPUT
|
echo "version=$(surfer get version | xargs)" >> $GITHUB_OUTPUT
|
||||||
echo "buildtime=$(date +"%H:%M:%S")" >> $GITHUB_OUTPUT
|
echo "buildtime=$(date +"%H:%M:%S")" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- uses: stefanzweifel/git-auto-commit-action@v4
|
- name: Commit
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
if: ${{ inputs.update_version }}
|
if: ${{ inputs.update_version }}
|
||||||
with:
|
with:
|
||||||
commit_message: 🔖 Update version to ${{ steps.data.outputs.version }}
|
commit_message: 🔖 Update version to ${{ steps.data.outputs.version }}
|
||||||
commit_user_name: Zen Browser Robot
|
commit_user_name: Zen Browser Robot
|
||||||
commit_user_email: zen-browser-bot@users.noreply.github.com
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
||||||
|
|
||||||
|
lint:
|
||||||
|
uses: ./.github/workflows/code-linter.yml
|
||||||
|
needs: [build-data]
|
||||||
|
name: Lint
|
||||||
|
|
||||||
check-release:
|
check-release:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [build-data]
|
needs: [build-data, lint]
|
||||||
steps:
|
steps:
|
||||||
- name: Install Node.js
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Install pnpm
|
- name: Setup Node.js
|
||||||
run: npm install -g pnpm
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
- name: Get pnpm store directory
|
node-version-file: '.nvmrc'
|
||||||
id: pnpm-cache
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: pnpm install
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
- name: Setup surfer
|
- name: Setup Surfer
|
||||||
run: |
|
run: |
|
||||||
npm i -g @zen-browser/surfer
|
npm i -g @zen-browser/surfer
|
||||||
|
|
||||||
- name: Activate surfer CLI
|
- name: Activate Surfer CLI
|
||||||
run: |
|
run: |
|
||||||
echo "There's a bug in the surfer CLI, we run this so that surfer sets everything up correctly"
|
npm run surfer -- ci --brand ${{ inputs.update_branch }} --display-version ${{ needs.build-data.outputs.version }}
|
||||||
pnpm surfer ci --brand ${{ inputs.update_branch }} --display-version ${{ needs.build-data.outputs.version }}
|
|
||||||
|
|
||||||
- name: Check version
|
- name: Check version
|
||||||
run: |
|
run: |
|
||||||
echo "$(pwd)"
|
echo "$(pwd)"
|
||||||
ls .
|
echo $(npm run --silent surfer -- get version | xargs)
|
||||||
echo "version=$(pnpm surfer get version | xargs)" >> $GITHUB_OUTPUT
|
echo "version=$(npm run --silent surfer -- get version | xargs)" >> $GITHUB_OUTPUT
|
||||||
if [[ $(pnpm surfer get version | xargs) == ${{ needs.build-data.outputs.version }} ]]; then
|
if [[ $(npm run --silent surfer -- get version | xargs) == ${{ needs.build-data.outputs.version }} ]]; then
|
||||||
echo ">>> Version matches"
|
echo ">>> Version matches"
|
||||||
else
|
else
|
||||||
echo ">>> Version mismatch"
|
echo ">>> Version mismatch"
|
||||||
@@ -174,69 +231,63 @@ jobs:
|
|||||||
contents: write
|
contents: write
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [build-data, check-release]
|
needs: [build-data, check-release]
|
||||||
environment: production
|
|
||||||
steps:
|
|
||||||
- name: Install Node.js
|
|
||||||
uses: actions/setup-node@v3
|
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email "mauro-balades@users.noreply.github.com"
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
git config --global user.name "mauro-balades"
|
git config --global user.name "mauro-balades"
|
||||||
|
|
||||||
- name: Install pnpm
|
|
||||||
run: npm install -g pnpm
|
|
||||||
|
|
||||||
- name: Get pnpm store directory
|
|
||||||
id: pnpm-cache
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: pnpm install
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
- name: Load surfer CI setup
|
- name: Load Surfer CI setup
|
||||||
run: pnpm surfer ci --brand ${{ inputs.update_branch }} --display-version ${{ needs.build-data.outputs.version }}
|
run: npm run surfer -- ci --brand ${{ inputs.update_branch }} --display-version ${{ needs.build-data.outputs.version }}
|
||||||
|
|
||||||
- name: Download firefox source and dependancies
|
- name: Download Firefox source and dependencies
|
||||||
run: pnpm surfer download --verbose
|
run: npm run download --verbose
|
||||||
|
|
||||||
- name: Import
|
- name: Import
|
||||||
run: pnpm surfer import --verbose
|
run: npm run import -- --verbose
|
||||||
|
|
||||||
- name: Compress
|
- name: Compress
|
||||||
run: |
|
run: |
|
||||||
cd engine
|
cd engine
|
||||||
# -h is used to dereference symlinks
|
tar --use-compress-program=zstd -hcf ../zen.source.tar.zst *
|
||||||
tar --use-compress-program=zstd -hcf ../zen.source.tar.gz *
|
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.source.tar.gz
|
retention-days: 5
|
||||||
path: ./zen.source.tar.gz
|
name: zen.source.tar.zst
|
||||||
|
path: ./zen.source.tar.zst
|
||||||
|
|
||||||
windows-step-1:
|
windows-step-1:
|
||||||
name: Windows build step 1 (PGO build)
|
name: Windows build step 1 (PGO build)
|
||||||
uses: ./.github/workflows/windows-release-build.yml
|
uses: ./.github/workflows/windows-release-build.yml
|
||||||
needs: [build-data]
|
needs: [build-data, buildid]
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
secrets: inherit
|
secrets: inherit
|
||||||
with:
|
with:
|
||||||
build-version: ${{ needs.build-data.outputs.version }}
|
build-version: ${{ needs.build-data.outputs.version }}
|
||||||
generate-gpo: true
|
generate-gpo: true
|
||||||
profile-data-path-archive: zen-windows-x86_64-profile-data-and-jarlog.zip
|
profile-data-path-archive: zen-windows-profile-data-and-jarlog.zip
|
||||||
release-branch: ${{ inputs.update_branch }}
|
release-branch: ${{ inputs.update_branch }}
|
||||||
|
MOZ_BUILD_DATE: ${{needs.buildid.outputs.buildids}}
|
||||||
|
|
||||||
windows-step-2:
|
windows-step-2:
|
||||||
name: Windows build step 2 (Generate profile data)
|
name: Windows build step 2 (Generate profile data)
|
||||||
@@ -256,11 +307,12 @@ jobs:
|
|||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
secrets: inherit
|
secrets: inherit
|
||||||
needs: [build-data, windows-step-2]
|
needs: [build-data, windows-step-2, start-self-host, buildid]
|
||||||
with:
|
with:
|
||||||
build-version: ${{ needs.build-data.outputs.version }}
|
build-version: ${{ needs.build-data.outputs.version }}
|
||||||
generate-gpo: false
|
generate-gpo: false
|
||||||
release-branch: ${{ inputs.update_branch }}
|
release-branch: ${{ inputs.update_branch }}
|
||||||
|
MOZ_BUILD_DATE: ${{needs.buildid.outputs.buildids}}
|
||||||
|
|
||||||
linux:
|
linux:
|
||||||
name: Linux build
|
name: Linux build
|
||||||
@@ -268,10 +320,11 @@ jobs:
|
|||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
secrets: inherit
|
secrets: inherit
|
||||||
needs: [build-data]
|
needs: [build-data, start-self-host, buildid]
|
||||||
with:
|
with:
|
||||||
build-version: ${{ needs.build-data.outputs.version }}
|
build-version: ${{ needs.build-data.outputs.version }}
|
||||||
release-branch: ${{ inputs.update_branch }}
|
release-branch: ${{ inputs.update_branch }}
|
||||||
|
MOZ_BUILD_DATE: ${{needs.buildid.outputs.buildids}}
|
||||||
|
|
||||||
mac:
|
mac:
|
||||||
name: macOS build
|
name: macOS build
|
||||||
@@ -279,41 +332,54 @@ jobs:
|
|||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
secrets: inherit
|
secrets: inherit
|
||||||
needs: [build-data]
|
needs: [build-data, buildid]
|
||||||
|
with:
|
||||||
|
build-version: ${{ needs.build-data.outputs.version }}
|
||||||
|
release-branch: ${{ inputs.update_branch }}
|
||||||
|
MOZ_BUILD_DATE: ${{needs.buildid.outputs.buildids}}
|
||||||
|
|
||||||
|
mac-uni:
|
||||||
|
name: macOS build (Universal)
|
||||||
|
uses: ./.github/workflows/macos-universal-release-build.yml
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
secrets: inherit
|
||||||
|
needs: [build-data, mac]
|
||||||
with:
|
with:
|
||||||
build-version: ${{ needs.build-data.outputs.version }}
|
build-version: ${{ needs.build-data.outputs.version }}
|
||||||
release-branch: ${{ inputs.update_branch }}
|
release-branch: ${{ inputs.update_branch }}
|
||||||
|
|
||||||
appimage:
|
appimage:
|
||||||
name: AppImage build - Linux ${{ matrix.generic == true && 'generic' || 'specific' }}
|
name: AppImage build - Linux ${{ matrix.arch }}
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
generic: [true, false]
|
arch: [x86_64, aarch64]
|
||||||
needs: [linux]
|
needs: [linux]
|
||||||
steps:
|
steps:
|
||||||
- name: Install Node.js
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: |
|
run: |
|
||||||
npm install -g pnpm
|
npm install
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get -y install libfuse2 desktop-file-utils
|
sudo apt-get -y install libfuse2 desktop-file-utils appstream
|
||||||
|
|
||||||
- name: Download linux build
|
- name: Download Linux build
|
||||||
uses: actions/download-artifact@v4
|
uses: actions/download-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.linux-${{ matrix.generic == true && 'generic' || 'specific' }}.tar.bz2
|
name: zen.linux-${{ matrix.arch }}.tar.xz
|
||||||
|
|
||||||
- name: Execute AppImage build
|
- name: Execute AppImage build
|
||||||
run: |
|
run: |
|
||||||
@@ -322,6 +388,11 @@ jobs:
|
|||||||
cp configs/branding/${{ inputs.update_branch }}/logo128.png AppDir/usr/share/icons/hicolor/128x128/apps/zen.png
|
cp configs/branding/${{ inputs.update_branch }}/logo128.png AppDir/usr/share/icons/hicolor/128x128/apps/zen.png
|
||||||
cp configs/branding/${{ inputs.update_branch }}/logo128.png AppDir/zen.png && ln -s zen.png AppDir/.DirIcon
|
cp configs/branding/${{ inputs.update_branch }}/logo128.png AppDir/zen.png && ln -s zen.png AppDir/.DirIcon
|
||||||
|
|
||||||
|
if [ "${{ inputs.update_branch }}" = "twilight" ]; then
|
||||||
|
sed -i -e 's/Name=Zen Browser/Name=Zen Twilight/g' AppDir/zen.desktop
|
||||||
|
sed -i -e 's/StartupWMClass=zen/StartupWMClass=zen-twilight/g' AppDir/zen.desktop
|
||||||
|
fi
|
||||||
|
|
||||||
APPDIR=AppDir
|
APPDIR=AppDir
|
||||||
tar -xvf *.tar.* && rm -rf *.tar.*
|
tar -xvf *.tar.* && rm -rf *.tar.*
|
||||||
mv zen/* $APPDIR/
|
mv zen/* $APPDIR/
|
||||||
@@ -332,153 +403,182 @@ jobs:
|
|||||||
ls -al
|
ls -al
|
||||||
find .
|
find .
|
||||||
ls -al "$APPDIR"
|
ls -al "$APPDIR"
|
||||||
ARCH=x86_64 ./appimagetool-x86_64.AppImage --comp zstd --mksquashfs-opt -Xcompression-level --mksquashfs-opt 10 \
|
ARCH=${{ matrix.arch }} ./appimagetool-x86_64.AppImage --comp zstd --mksquashfs-opt -Xcompression-level --mksquashfs-opt 10 \
|
||||||
-u "gh-releases-zsync|$GITHUB_REPOSITORY_OWNER|desktop|latest|zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage.zsync" \
|
-u "gh-releases-zsync|$GITHUB_REPOSITORY_OWNER|desktop|latest|zen-${{ matrix.arch }}.AppImage.zsync" \
|
||||||
"$APPDIR" zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage
|
"$APPDIR" zen-${{ matrix.arch }}.AppImage
|
||||||
mkdir dist
|
mkdir dist
|
||||||
mv zen*AppImage* dist/.
|
mv zen*AppImage* dist/.
|
||||||
|
|
||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage
|
retention-days: 5
|
||||||
path: ./dist/zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage
|
name: zen-${{ matrix.arch }}.AppImage
|
||||||
|
path: ./dist/zen-${{ matrix.arch }}.AppImage
|
||||||
|
|
||||||
- name: Upload artifact (ZSync)
|
- name: Upload artifact (ZSync)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage.zsync
|
retention-days: 5
|
||||||
path: ./dist/zen-${{ matrix.generic == true && 'generic' || 'specific' }}.AppImage.zsync
|
name: zen-${{ matrix.arch }}.AppImage.zsync
|
||||||
|
path: ./dist/zen-${{ matrix.arch }}.AppImage.zsync
|
||||||
|
|
||||||
|
stop-self-hosted:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: [windows-step-3, linux]
|
||||||
|
if: always()
|
||||||
|
steps:
|
||||||
|
- name: Download aws-cli
|
||||||
|
run: |
|
||||||
|
curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
|
||||||
|
unzip awscliv2.zip
|
||||||
|
sudo ./aws/install --update
|
||||||
|
|
||||||
|
- name: Stop self-hosted runner
|
||||||
|
if: ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
|
run: |
|
||||||
|
echo "Stopping self-hosted runner"
|
||||||
|
echo "${{ secrets.SELF_HOSTED_RUNNER_STOP_SCRIPT }}" | base64 -d > stop.sh
|
||||||
|
sudo chmod +x stop.sh
|
||||||
|
bash ./stop.sh > /dev/null
|
||||||
|
|
||||||
|
- name: Remove self-hosted runner script
|
||||||
|
if: always() && ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
|
run: |
|
||||||
|
echo "Removing self-hosted runner script"
|
||||||
|
rm stop.sh || true
|
||||||
|
|
||||||
release:
|
release:
|
||||||
if: ${{ inputs.create_release || inputs.update_branch == 'twilight' }}
|
if: ${{ inputs.create_release || inputs.update_branch == 'twilight' }}
|
||||||
permissions: write-all
|
permissions: write-all
|
||||||
name: Release
|
name: Release
|
||||||
needs: [build-data, linux, windows-step-3, check-release, mac, appimage, source]
|
needs: [build-data, linux, windows-step-3, check-release, mac-uni, appimage, source, lint, stop-self-hosted]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
environment:
|
environment:
|
||||||
name: ${{ inputs.update_branch == 'alpha' && 'Deploy-Release' || 'Deploy-Twilight' }}
|
name: ${{ inputs.update_branch == 'release' && 'Deploy-Release' || 'Deploy-Twilight' }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Git Pull
|
- name: Git pull
|
||||||
run: |
|
run: |
|
||||||
git pull
|
git pull
|
||||||
|
|
||||||
- uses: actions/download-artifact@v4
|
- name: Download artifact
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
|
||||||
- name: List
|
- name: List
|
||||||
run: find .
|
run: find .
|
||||||
|
|
||||||
- name: Clone updates repo
|
- name: Checkout updates repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
repository: zen-browser/updates-server
|
repository: zen-browser/updates-server
|
||||||
path: updates-server
|
path: updates-server
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Download object files
|
||||||
|
run: |
|
||||||
|
git clone https://github.com/zen-browser/windows-binaries.git .github/workflows/object
|
||||||
|
|
||||||
- name: Copy update manifests
|
- name: Copy update manifests
|
||||||
env:
|
env:
|
||||||
RELEASE_BRANCH: ${{ inputs.update_branch }}
|
RELEASE_BRANCH: ${{ inputs.update_branch }}
|
||||||
run: |
|
run: |
|
||||||
cd updates-server
|
cd updates-server
|
||||||
mkdir -p updates
|
mkdir -p updates
|
||||||
cp -a ../linux_update_manifest_generic/. updates/
|
cp -a ../linux_update_manifest_x86_64/. updates/
|
||||||
cp -a ../linux_update_manifest_specific/. updates/
|
cp -a ../linux_update_manifest_aarch64/. updates/
|
||||||
|
|
||||||
if [[ $RELEASE_BRANCH == 'alpha' ]]; then
|
if [[ $RELEASE_BRANCH == 'release' ]]; then
|
||||||
cp -a ../.github/workflows/object/windows-x64-signed-generic/update_manifest/. updates/
|
cp -a ../.github/workflows/object/windows-x64-signed-x86_64/update_manifest/. updates/
|
||||||
cp -a ../.github/workflows/object/windows-x64-signed-specific/update_manifest/. updates/
|
cp -a ../.github/workflows/object/windows-x64-signed-arm64/update_manifest/. updates/
|
||||||
else
|
else
|
||||||
cp -a ../windows_update_manifest_generic/. updates/
|
cp -a ../windows_update_manifest_x86_64/. updates/
|
||||||
cp -a ../windows_update_manifest_specific/. updates/
|
cp -a ../windows_update_manifest_arm64/. updates/
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cp -a ../macos_update_manifest_aarch64/. updates/
|
cp -a ../macos_update_manifest/. updates/
|
||||||
cp -a ../macos_update_manifest_x64/. updates/
|
|
||||||
|
|
||||||
- uses: stefanzweifel/git-auto-commit-action@v4
|
- name: Commit
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
with:
|
with:
|
||||||
commit_message: 🚀 Update update manifests
|
commit_message: 🚀 Update update manifests
|
||||||
commit_user_name: Zen Browser Robot
|
commit_user_name: Zen Browser Robot
|
||||||
commit_user_email: zen-browser-bot@users.noreply.github.com
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
||||||
repository: ./updates-server
|
repository: ./updates-server
|
||||||
|
|
||||||
# If we are on twilight, we want to just update the twilight tag's release
|
# If we are on Twilight, we want to just update the Twilight tag's release
|
||||||
- name: Update twilight tag
|
- name: Update Twilight tag
|
||||||
if: ${{ inputs.update_branch == 'twilight' }}
|
if: ${{ inputs.update_branch == 'twilight' }}
|
||||||
uses: 'marvinpinto/action-automatic-releases@latest'
|
uses: marvinpinto/action-automatic-releases@master
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
zen.source.tar.gz
|
zen.source.tar.zst
|
||||||
zen.linux-generic.tar.bz2
|
zen.linux-x86_64.tar.xz
|
||||||
zen.linux-specific.tar.bz2
|
zen.linux-aarch64.tar.xz
|
||||||
zen-generic.AppImage
|
zen-x86_64.AppImage
|
||||||
zen-generic.AppImage.zsync
|
zen-x86_64.AppImage.zsync
|
||||||
zen-specific.AppImage
|
zen-aarch64.AppImage
|
||||||
zen-specific.AppImage.zsync
|
zen-aarch64.AppImage.zsync
|
||||||
zen.win-generic.zip
|
zen.win-x86_64.zip
|
||||||
zen.win-specific.zip
|
zen.win-arm64.zip
|
||||||
linux.mar
|
linux.mar
|
||||||
linux-generic.mar
|
linux-aarch64.mar
|
||||||
windows-generic.mar
|
|
||||||
windows.mar
|
windows.mar
|
||||||
macos-x64.mar
|
windows-arm64.mar
|
||||||
macos-aarch64.mar
|
macos.mar
|
||||||
zen.installer.exe
|
zen.installer.exe
|
||||||
zen.installer-generic.exe
|
zen.installer-arm64.exe
|
||||||
zen.macos-x64.dmg
|
zen.macos-universal.dmg
|
||||||
zen.macos-aarch64.dmg
|
|
||||||
automatic_release_tag: 'twilight'
|
automatic_release_tag: 'twilight'
|
||||||
title: 'Twilight build - ${{ needs.build-data.outputs.version }} (${{ needs.build-data.outputs.build_date }} at ${{ needs.build-data.outputs.build_time }})'
|
title: 'Twilight build - ${{ needs.build-data.outputs.version }} (${{ needs.build-data.outputs.build_date }} at ${{ needs.build-data.outputs.build_time }})'
|
||||||
draft: false
|
draft: false
|
||||||
prerelease: true
|
prerelease: true
|
||||||
repo_token: ${{ github.token }}
|
repo_token: ${{ secrets.DEPLOY_KEY }}
|
||||||
env:
|
env:
|
||||||
GITHUB_REPOSITORY: ${{ github.repository }}
|
GITHUB_REPOSITORY: ${{ github.repository }}
|
||||||
|
|
||||||
- name: release-github
|
- name: Release
|
||||||
uses: 'marvinpinto/action-automatic-releases@latest'
|
uses: marvinpinto/action-automatic-releases@master
|
||||||
if: ${{ inputs.update_branch == 'alpha' }}
|
if: ${{ inputs.update_branch == 'release' }}
|
||||||
with:
|
with:
|
||||||
repo_token: '${{ secrets.DEPLOY_KEY }}'
|
repo_token: '${{ secrets.DEPLOY_KEY }}'
|
||||||
automatic_release_tag: ${{ needs.build-data.outputs.version }}
|
automatic_release_tag: ${{ needs.build-data.outputs.version }}
|
||||||
prerelease: false
|
prerelease: false
|
||||||
title: 'Alpha build - ${{ needs.build-data.outputs.version }} (${{ needs.build-data.outputs.build_date }})'
|
title: 'Release build - ${{ needs.build-data.outputs.version }} (${{ needs.build-data.outputs.build_date }})'
|
||||||
files: |
|
files: |
|
||||||
zen.source.tar.gz
|
zen.source.tar.zst
|
||||||
zen.linux-generic.tar.bz2
|
zen.linux-x86_64.tar.xz
|
||||||
zen.linux-specific.tar.bz2
|
zen.linux-aarch64.tar.xz
|
||||||
zen-generic.AppImage
|
zen-x86_64.AppImage
|
||||||
zen-generic.AppImage.zsync
|
zen-x86_64.AppImage.zsync
|
||||||
zen-specific.AppImage
|
zen-aarch64.AppImage
|
||||||
zen-specific.AppImage.zsync
|
zen-aarch64.AppImage.zsync
|
||||||
.github/workflows/object/windows-x64-signed-generic/zen.win-generic.zip
|
.github/workflows/object/windows-x64-signed-x86_64/zen.win-x86_64.zip
|
||||||
.github/workflows/object/windows-x64-signed-specific/zen.win-specific.zip
|
.github/workflows/object/windows-x64-signed-arm64/zen.win-arm64.zip
|
||||||
linux.mar
|
linux.mar
|
||||||
linux-generic.mar
|
linux-aarch64.mar
|
||||||
.github/workflows/object/windows-x64-signed-generic/windows-generic.mar
|
.github/workflows/object/windows-x64-signed-x86_64/windows.mar
|
||||||
.github/workflows/object/windows-x64-signed-specific/windows.mar
|
.github/workflows/object/windows-x64-signed-arm64/windows-arm64.mar
|
||||||
macos-x64.mar
|
macos.mar
|
||||||
macos-aarch64.mar
|
.github/workflows/object/windows-x64-signed-x86_64/zen.installer.exe
|
||||||
.github/workflows/object/windows-x64-signed-specific/zen.installer.exe
|
.github/workflows/object/windows-x64-signed-arm64/zen.installer-arm64.exe
|
||||||
.github/workflows/object/windows-x64-signed-generic/zen.installer-generic.exe
|
zen.macos-universal.dmg
|
||||||
zen.macos-x64.dmg
|
|
||||||
zen.macos-aarch64.dmg
|
|
||||||
|
|
||||||
prepare-flatpak:
|
prepare-flatpak:
|
||||||
if: ${{ inputs.create_release && inputs.update_branch == 'alpha' }}
|
if: ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
permissions: write-all
|
permissions: write-all
|
||||||
name: Prepare Flatpak
|
name: Prepare Flatpak
|
||||||
needs: [release, linux, build-data]
|
needs: [release, linux, build-data]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Clone flatpak repo
|
- name: Checkout Flatpak repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
repository: zen-browser/release-utils
|
repository: zen-browser/release-utils
|
||||||
@@ -490,18 +590,19 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
npm install
|
npm install
|
||||||
|
|
||||||
- name: Generate new flatpak release
|
- name: Generate new Flatpak release
|
||||||
run: |
|
run: |
|
||||||
npm run build-flatpak -- \
|
npm run build-flatpak -- \
|
||||||
--version ${{ needs.build-data.outputs.version }}
|
--version ${{ needs.build-data.outputs.version }}
|
||||||
|
|
||||||
- uses: stefanzweifel/git-auto-commit-action@v4
|
- name: Commit
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
with:
|
with:
|
||||||
commit_message: 🚀 Update releases for flatpak
|
commit_message: 🚀 Update releases for Flatpak
|
||||||
commit_user_name: Zen Browser Robot
|
commit_user_name: Zen Browser Robot
|
||||||
commit_user_email: zen-browser-bot@users.noreply.github.com
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
||||||
|
|
||||||
- name: Clone flatpak repo
|
- name: Checkout Flatpak repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
repository: zen-browser/flatpak
|
repository: zen-browser/flatpak
|
||||||
@@ -513,82 +614,90 @@ jobs:
|
|||||||
pwd
|
pwd
|
||||||
ls .
|
ls .
|
||||||
ls ..
|
ls ..
|
||||||
mv releases.xml ./flatpak/io.github.zen_browser.zen.metainfo.xml
|
mv releases.xml ./flatpak/app.zen_browser.zen.metainfo.xml
|
||||||
# output the version to the file
|
# output the version to the file
|
||||||
echo -n ${{ needs.build-data.outputs.version }} > ./flatpak/version
|
echo -n ${{ needs.build-data.outputs.version }} > ./flatpak/version
|
||||||
|
|
||||||
- uses: stefanzweifel/git-auto-commit-action@v4
|
- name: Commit
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
with:
|
with:
|
||||||
commit_message: '[release]: Update flatpak manifest'
|
commit_message: '[release]: Update Flatpak manifest'
|
||||||
commit_user_name: Zen Browser Robot
|
commit_user_name: Zen Browser Robot
|
||||||
commit_user_email: zen-browser-bot@users.noreply.github.com
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
||||||
repository: ./flatpak
|
repository: ./flatpak
|
||||||
|
|
||||||
- name: Wait 4 minutes for the flatpak repo to update
|
- name: Wait 2 minutes for the Flatpak repo to update
|
||||||
run: sleep 240
|
run: sleep 120
|
||||||
|
|
||||||
release-flatpak:
|
release-flatpak:
|
||||||
if: ${{ inputs.create_release && inputs.update_branch == 'alpha' }}
|
if: ${{ inputs.create_release && inputs.update_branch == 'release' }}
|
||||||
permissions: write-all
|
permissions: write-all
|
||||||
name: Release Flatpak
|
name: Release Flatpak
|
||||||
needs: [prepare-flatpak, build-data]
|
needs: [prepare-flatpak, build-data]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Clone flatpak repo
|
- name: Checkout Flatpak repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
repository: flathub/io.github.zen_browser.zen
|
repository: flathub/app.zen_browser.zen
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Download linux generic build
|
- name: Download Linux x86_64 build
|
||||||
uses: actions/download-artifact@v4
|
uses: actions/download-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.linux-generic.tar.bz2
|
name: zen.linux-x86_64.tar.xz
|
||||||
|
|
||||||
- name: Update repo
|
- name: Download Linux aarch64 build
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: zen.linux-aarch64.tar.xz
|
||||||
|
|
||||||
|
- name: Update repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
path: zen-browser
|
path: zen-browser
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Download flatpak archive
|
- name: Download Flatpak archive
|
||||||
run: |
|
run: |
|
||||||
wget https://github.com/zen-browser/flatpak/releases/latest/download/archive.tar -O archive.tar
|
wget https://github.com/zen-browser/flatpak/releases/latest/download/archive.tar -O archive.tar
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.name "github-actions[bot]"
|
git config --global user.name "github-actions[bot]"
|
||||||
git config --global user.email "github-actions[bot]@users.noreply.github.com"
|
git config --global user.email "github-actions[bot]@users.noreply.github.com"
|
||||||
|
|
||||||
- name: Prepare flatpak manifest
|
- name: Prepare Flatpak manifest
|
||||||
run: |
|
run: |
|
||||||
python3 ./zen-browser/scripts/prepare-flatpak-release.py \
|
python3 ./zen-browser/scripts/prepare-flatpak-release.py \
|
||||||
--flatpak-archive archive.tar \
|
--flatpak-archive archive.tar \
|
||||||
--version ${{ needs.build-data.outputs.version }} \
|
--version ${{ needs.build-data.outputs.version }} \
|
||||||
--linux-archive zen.linux-generic.tar.bz2 \
|
--linux-archive zen.linux-x86_64.tar.xz \
|
||||||
--output io.github.zen_browser.zen.yml \
|
--linux-aarch64-archive zen.linux-aarch64.tar.xz \
|
||||||
|
--output app.zen_browser.zen.yml \
|
||||||
--template-root ./zen-browser/flatpak
|
--template-root ./zen-browser/flatpak
|
||||||
|
|
||||||
- name: Commit changes
|
- name: Commit changes
|
||||||
run: |
|
run: |
|
||||||
git add io.github.zen_browser.zen.yml
|
git add app.zen_browser.zen.yml
|
||||||
git commit -m "Update to version ${{ needs.build-data.outputs.version }}"
|
git commit -m "Update to version ${{ needs.build-data.outputs.version }}"
|
||||||
|
|
||||||
- name: Clean up
|
- name: Clean up
|
||||||
run: |
|
run: |
|
||||||
rm -rf zen-browser
|
rm -rf zen-browser
|
||||||
rm -rf archive.tar
|
rm -rf archive.tar
|
||||||
rm -rf zen.linux-generic.tar.bz2
|
rm -rf zen.linux-x86_64.tar.xz
|
||||||
|
|
||||||
- name: Upload flatpak manifest
|
- name: Upload Flatpak manifest
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: io.github.zen_browser.zen.yml
|
retention-days: 5
|
||||||
path: ./io.github.zen_browser.zen.yml
|
name: app.zen_browser.zen.yml
|
||||||
|
path: ./app.zen_browser.zen.yml
|
||||||
|
|
||||||
- name: Create pull request
|
- name: Create pull request
|
||||||
uses: peter-evans/create-pull-request@v6
|
uses: peter-evans/create-pull-request@v7
|
||||||
env:
|
env:
|
||||||
GIT_TRACE: 1
|
GIT_TRACE: 1
|
||||||
GIT_CURL_VERBOSE: 1
|
GIT_CURL_VERBOSE: 1
|
||||||
@@ -604,28 +713,3 @@ jobs:
|
|||||||
base: master
|
base: master
|
||||||
git-token: ${{ secrets.DEPLOY_KEY }}
|
git-token: ${{ secrets.DEPLOY_KEY }}
|
||||||
delete-branch: true
|
delete-branch: true
|
||||||
|
|
||||||
release-homebrew:
|
|
||||||
if: ${{ inputs.create_release && inputs.update_branch == 'alpha' }}
|
|
||||||
permissions: write-all
|
|
||||||
name: Homebrew release
|
|
||||||
needs: [release, mac, build-data]
|
|
||||||
runs-on: macos-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Set up Homebrew
|
|
||||||
uses: Homebrew/actions/setup-homebrew@master
|
|
||||||
with:
|
|
||||||
cask: true
|
|
||||||
test-bot: false
|
|
||||||
|
|
||||||
- name: Setup git
|
|
||||||
uses: Homebrew/actions/git-user-config@master
|
|
||||||
with:
|
|
||||||
username: zen-browser-bot
|
|
||||||
|
|
||||||
- name: Bump zen-browser
|
|
||||||
uses: Homebrew/actions/bump-packages@master
|
|
||||||
with:
|
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
|
||||||
casks: zen-browser
|
|
||||||
|
21
.github/workflows/check-candidate-release.yml
vendored
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
name: Check Firefox Candidate Release
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '59 4 * * 2'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
check_candidates:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Check out repository
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Check for any updates
|
||||||
|
env:
|
||||||
|
DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }}
|
||||||
|
DISCORD_PING_IDS: ${{ secrets.DISCORD_PING_IDS }}
|
||||||
|
run: |
|
||||||
|
python3 scripts/check_rc_response.py
|
7
.github/workflows/clear-cache.yml
vendored
@@ -9,9 +9,10 @@ permissions:
|
|||||||
jobs:
|
jobs:
|
||||||
clear-cache:
|
clear-cache:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Clear cache
|
- name: Clear cache
|
||||||
uses: actions/github-script@v6
|
uses: actions/github-script@v7
|
||||||
with:
|
with:
|
||||||
script: |
|
script: |
|
||||||
console.log("About to clear")
|
console.log("About to clear")
|
||||||
@@ -19,12 +20,14 @@ jobs:
|
|||||||
owner: context.repo.owner,
|
owner: context.repo.owner,
|
||||||
repo: context.repo.repo,
|
repo: context.repo.repo,
|
||||||
})
|
})
|
||||||
|
|
||||||
for (const cache of caches.data.actions_caches) {
|
for (const cache of caches.data.actions_caches) {
|
||||||
console.log(cache)
|
console.log(cache)
|
||||||
github.rest.actions.deleteActionsCacheById({
|
await github.rest.actions.deleteActionsCacheById({
|
||||||
owner: context.repo.owner,
|
owner: context.repo.owner,
|
||||||
repo: context.repo.repo,
|
repo: context.repo.repo,
|
||||||
cache_id: cache.id,
|
cache_id: cache.id,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log("Clear completed")
|
console.log("Clear completed")
|
||||||
|
34
.github/workflows/code-linter.yml
vendored
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
name: Code Linter
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- dev
|
||||||
|
workflow_dispatch:
|
||||||
|
workflow_call:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- dev
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
pr-test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Setup autopep8
|
||||||
|
run: sudo apt install python3-autopep8
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: npm install
|
||||||
|
|
||||||
|
- name: Lint
|
||||||
|
run: npm run lint
|
64
.github/workflows/issue-metrics.yml
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
name: Monthly issue metrics
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
schedule:
|
||||||
|
- cron: '3 2 1 * *'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
name: issue metrics
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Get dates for last month
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
# Get the current date
|
||||||
|
current_date=$(date +'%Y-%m-%d')
|
||||||
|
|
||||||
|
# Calculate the previous month
|
||||||
|
previous_date=$(date -d "$current_date -1 month" +'%Y-%m-%d')
|
||||||
|
|
||||||
|
# Extract the year and month from the previous date
|
||||||
|
previous_year=$(date -d "$previous_date" +'%Y')
|
||||||
|
previous_month=$(date -d "$previous_date" +'%m')
|
||||||
|
|
||||||
|
# Calculate the first day of the previous month
|
||||||
|
first_day=$(date -d "$previous_year-$previous_month-01" +'%Y-%m-%d')
|
||||||
|
|
||||||
|
# Calculate the last day of the previous month
|
||||||
|
last_day=$(date -d "$first_day +1 month -1 day" +'%Y-%m-%d')
|
||||||
|
|
||||||
|
echo "$first_day..$last_day"
|
||||||
|
echo "last_month=$first_day..$last_day" >> "$GITHUB_ENV"
|
||||||
|
echo "last_month_year=$previous_year" >> "$GITHUB_ENV"
|
||||||
|
|
||||||
|
- name: Run issue-metrics tool
|
||||||
|
uses: github/issue-metrics@v2
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
HIDE_AUTHOR: true
|
||||||
|
HIDE_TIME_TO_ANSWER: true
|
||||||
|
SEARCH_QUERY: 'repo:zen-browser/desktop is:issue created:${{ env.last_month }}'
|
||||||
|
|
||||||
|
- name: Move metrics to docs folder
|
||||||
|
run: |
|
||||||
|
mkdir -p docs/issue-metrics
|
||||||
|
rm -f docs/issue-metrics/${{ env.last_month_year }}_${{ env.last_month }}.md
|
||||||
|
mv issue_metrics.md docs/issue-metrics/${{ env.last_month_year }}_${{ env.last_month }}.md
|
||||||
|
|
||||||
|
- name: Remove metrisc JSON
|
||||||
|
run: |
|
||||||
|
rm -f issue_metrics.json
|
||||||
|
|
||||||
|
- name: Commit changes
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
|
with:
|
||||||
|
commit_message: 'Update monthly issue metrics'
|
||||||
|
commit_user_name: Zen Browser Robot
|
||||||
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
121
.github/workflows/linux-release-build.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: Linux Release Build
|
name: Linux Release Build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
@@ -10,38 +11,41 @@ on:
|
|||||||
description: 'The branch to build'
|
description: 'The branch to build'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
MOZ_BUILD_DATE:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
default: ''
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-linux:
|
build-linux:
|
||||||
environment: production
|
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
runs-on: ubuntu-latest
|
# aarch64 does not need full 16x
|
||||||
|
runs-on: ${{ (inputs.release-branch == 'release' && matrix.arch == 'x86_64') && 'self-hosted' || 'ubuntu-latest' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
generic: [true, false]
|
arch: [x86_64, aarch64]
|
||||||
name: Build Linux - ${{ matrix.generic == true && 'Generic' || 'Specific' }}
|
name: Build Linux - ${{ matrix.arch }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Free Disk Space (Ubuntu)
|
- name: Free Disk Space (Ubuntu)
|
||||||
uses: jlumbroso/free-disk-space@main
|
uses: jlumbroso/free-disk-space@main
|
||||||
with:
|
with:
|
||||||
# this might remove tools that are actually needed,
|
|
||||||
# if set to "true" but frees about 6 GB
|
|
||||||
tool-cache: false
|
tool-cache: false
|
||||||
|
|
||||||
- name: Install Node.js
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email "mauro-balades@users.noreply.github.com"
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
git config --global user.name "mauro-balades"
|
git config --global user.name "mauro-balades"
|
||||||
@@ -51,7 +55,7 @@ jobs:
|
|||||||
set -x
|
set -x
|
||||||
sudo apt-get update --fix-missing
|
sudo apt-get update --fix-missing
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install dos2unix yasm nasm build-essential libgtk2.0-dev libpython3-dev m4 uuid libasound2-dev libcurl4-openssl-dev libdbus-1-dev libdrm-dev libdbus-glib-1-dev libdbus-glib-1-dev libgtk-3-dev libpulse-dev libx11-xcb-dev libxt-dev xvfb lld llvm
|
sudo apt-get install -y python3 python3-pip dos2unix yasm nasm build-essential libgtk2.0-dev libpython3-dev m4 uuid libasound2-dev libcurl4-openssl-dev libdbus-1-dev libdrm-dev libdbus-glib-1-dev libgtk-3-dev libpulse-dev libx11-xcb-dev libxt-dev xvfb lld llvm
|
||||||
|
|
||||||
- name: Configure sccache
|
- name: Configure sccache
|
||||||
uses: actions/github-script@v7
|
uses: actions/github-script@v7
|
||||||
@@ -60,7 +64,7 @@ jobs:
|
|||||||
core.exportVariable('ACTIONS_CACHE_URL', process.env.ACTIONS_CACHE_URL || '');
|
core.exportVariable('ACTIONS_CACHE_URL', process.env.ACTIONS_CACHE_URL || '');
|
||||||
core.exportVariable('ACTIONS_RUNTIME_TOKEN', process.env.ACTIONS_RUNTIME_TOKEN || '');
|
core.exportVariable('ACTIONS_RUNTIME_TOKEN', process.env.ACTIONS_RUNTIME_TOKEN || '');
|
||||||
|
|
||||||
- name: Install sccache
|
- name: Setup sccache
|
||||||
env:
|
env:
|
||||||
LINK: https://github.com/mozilla/sccache/releases/download
|
LINK: https://github.com/mozilla/sccache/releases/download
|
||||||
SCCACHE_VERSION: 0.2.13
|
SCCACHE_VERSION: 0.2.13
|
||||||
@@ -72,34 +76,37 @@ jobs:
|
|||||||
echo "$HOME/.local/bin" >> $GITHUB_PATH
|
echo "$HOME/.local/bin" >> $GITHUB_PATH
|
||||||
|
|
||||||
- name: Save sccache
|
- name: Save sccache
|
||||||
uses: actions/cache@v3
|
uses: actions/cache@v4
|
||||||
continue-on-error: false
|
|
||||||
with:
|
with:
|
||||||
path: /home/runner/.cache/sccache
|
path: /home/runner/.cache/sccache
|
||||||
key: ${{ runner.os }}-sccache
|
key: ${{ runner.os }}-sccache
|
||||||
|
|
||||||
- name: Install pnpm
|
|
||||||
run: npm install -g pnpm
|
|
||||||
|
|
||||||
- name: Get pnpm store directory
|
|
||||||
id: pnpm-cache
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: pnpm install
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
- name: Load surfer CI setup
|
- name: Load Surfer CI setup
|
||||||
run: pnpm surfer ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
run: npm run surfer -- ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
||||||
|
|
||||||
- name: Download firefox source and dependencies
|
- name: Download Firefox source and dependencies
|
||||||
run: pnpm surfer download
|
run: npm run download
|
||||||
|
|
||||||
|
- name: Fix Rust version
|
||||||
|
run: |
|
||||||
|
# Install a rust version compatible with LLVM 18
|
||||||
|
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain 1.79
|
||||||
|
source $HOME/.cargo/env
|
||||||
|
|
||||||
|
if test "${{ matrix.arch }}" = "aarch64"; then
|
||||||
|
rustup target add aarch64-unknown-linux-gnu
|
||||||
|
else
|
||||||
|
rustup target add x86_64-unknown-linux-gnu
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Import
|
- name: Import
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
run: pnpm surfer import
|
run: npm run import
|
||||||
|
|
||||||
- name: Build language packs
|
- name: Build language packs
|
||||||
run: sh scripts/download-language-packs.sh
|
run: sh scripts/download-language-packs.sh
|
||||||
@@ -107,45 +114,53 @@ jobs:
|
|||||||
- name: Bootstrap
|
- name: Bootstrap
|
||||||
run: |
|
run: |
|
||||||
cd engine
|
cd engine
|
||||||
|
export SURFER_PLATFORM="linux"
|
||||||
./mach --no-interactive bootstrap --application-choice browser
|
./mach --no-interactive bootstrap --application-choice browser
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
|
ZEN_RELEASE_BRANCH: ${{ inputs.release-branch }}
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
run: sh .github/workflows/src/release-build.sh
|
run: |
|
||||||
|
export SURFER_PLATFORM="linux"
|
||||||
- name: Build again if it failed
|
if [[ -n ${{ inputs.MOZ_BUILD_DATE }} ]];then
|
||||||
if: failure()
|
export MOZ_BUILD_DATE=${{ inputs.MOZ_BUILD_DATE }}
|
||||||
env:
|
fi
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
bash .github/workflows/src/release-build.sh
|
||||||
run: sh .github/workflows/src/release-build.sh
|
|
||||||
|
|
||||||
- name: Package
|
- name: Package
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
run: pnpm package
|
ZEN_GA_DISABLE_PGO: true
|
||||||
|
run: |
|
||||||
|
export SURFER_PLATFORM="linux"
|
||||||
|
export ZEN_RELEASE=1
|
||||||
|
npm run package
|
||||||
|
|
||||||
- name: Rename artifacts
|
- name: Rename artifacts
|
||||||
run: |
|
run: |
|
||||||
mv dist/zen-*.tar.bz2 "zen.linux-${{ matrix.generic == true && 'generic' || 'specific' }}.tar.bz2"
|
mv dist/zen-*.tar.xz "zen.linux-${{ matrix.arch }}.tar.xz"
|
||||||
mv dist/output.mar linux${{ matrix.generic == true && '-generic' || '' }}.mar
|
mv dist/output.mar linux${{ matrix.arch == 'aarch64' && '-aarch64' || '' }}.mar
|
||||||
|
|
||||||
- name: Upload binary
|
- name: Upload build artifact (binary)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.linux-${{ matrix.generic == true && 'generic' || 'specific' }}.tar.bz2
|
retention-days: 5
|
||||||
path: ./zen.linux-${{ matrix.generic == true && 'generic' || 'specific' }}.tar.bz2
|
name: zen.linux-${{ matrix.arch }}.tar.xz
|
||||||
|
path: ./zen.linux-${{ matrix.arch }}.tar.xz
|
||||||
|
|
||||||
- name: Upload mar
|
- name: Upload build artifact (.mar)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: linux${{ matrix.generic == true && '-generic' || '' }}.mar
|
retention-days: 5
|
||||||
path: ./linux${{ matrix.generic == true && '-generic' || '' }}.mar
|
name: linux${{ matrix.arch == 'aarch64' && '-aarch64' || '' }}.mar
|
||||||
|
path: ./linux${{ matrix.arch == 'aarch64' && '-aarch64' || '' }}.mar
|
||||||
|
|
||||||
- name: Upload update manifests
|
- name: Upload build artifact (update manifests)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: linux_update_manifest_${{ matrix.generic == true && 'generic' || 'specific' }}
|
retention-days: 5
|
||||||
|
name: linux_update_manifest_${{ matrix.arch }}
|
||||||
path: ./dist/update
|
path: ./dist/update
|
||||||
|
168
.github/workflows/macos-release-build.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: macOS Release Build
|
name: macOS Release Build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
@@ -10,166 +11,149 @@ on:
|
|||||||
description: 'The branch to build'
|
description: 'The branch to build'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
MOZ_BUILD_DATE:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
default: ''
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
mac-build:
|
mac-build:
|
||||||
name: Build macOS - ${{ matrix.arch }}
|
name: Build macOS - ${{ matrix.arch }}
|
||||||
environment: production
|
runs-on: ${{ inputs.release-branch == 'release' && 'macos-14' || 'macos-14' }}
|
||||||
runs-on: ${{ matrix.os }}
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
arch: [x86_64, aarch64]
|
||||||
- arch: aarch64
|
|
||||||
os: macos-14
|
|
||||||
- arch: x64
|
|
||||||
os: macos-13
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install Node.js
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/setup-python@v5
|
|
||||||
with:
|
|
||||||
python-version: '3.11'
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v5
|
||||||
|
# note: This will use the version defined in '.python-version' by default
|
||||||
|
|
||||||
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email "mauro-balades@users.noreply.github.com"
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
git config --global user.name "mauro-balades"
|
git config --global user.name "mauro-balades"
|
||||||
|
|
||||||
- name: Install system dependencies
|
- name: Install system dependencies
|
||||||
run: |
|
run: |
|
||||||
|
brew update
|
||||||
brew install cairo sccache gnu-tar mercurial
|
brew install cairo sccache gnu-tar mercurial
|
||||||
sudo pip install setuptools
|
sudo pip install setuptools
|
||||||
|
|
||||||
# completly uninstall python3 and python3.12
|
|
||||||
brew uninstall --ignore-dependencies python3.12 -f
|
brew uninstall --ignore-dependencies python3.12 -f
|
||||||
|
|
||||||
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
||||||
python3 -m pip install --user mercurial
|
python3 -m pip install --user mercurial
|
||||||
|
|
||||||
rm '/usr/local/bin/2to3-3.11' # fix Could not symlink bin/2to3-3.11
|
rm '/usr/local/bin/2to3-3.11' '/usr/local/bin/2to3-3.12' '/usr/local/bin/2to3'
|
||||||
rm '/usr/local/bin/2to3-3.12' # fix Could not symlink bin/2to3-3.12
|
rm '/usr/local/bin/idle3.11' '/usr/local/bin/idle3.12' '/usr/local/bin/idle3'
|
||||||
rm /usr/local/bin/2to3 # fix Could not symlink bin/2to3
|
rm '/usr/local/bin/pydoc3.11' '/usr/local/bin/pydoc3.12' '/usr/local/bin/pydoc3'
|
||||||
rm '/usr/local/bin/idle3.11' #fix Could not symlink bin/idle3.11
|
rm '/usr/local/bin/python3.11' '/usr/local/bin/python3.12' '/usr/local/bin/python3'
|
||||||
rm '/usr/local/bin/idle3.12' # fix Could not symlink bin/idle3.12
|
rm '/usr/local/bin/python3.11-config' '/usr/local/bin/python3.12-config' '/usr/local/bin/python3-config'
|
||||||
rm '/usr/local/bin/idle3' # fix Could not symlink bin/idle3
|
|
||||||
rm '/usr/local/bin/pydoc3.11' # fix Could not symlink bin/pydoc3.11
|
|
||||||
rm '/usr/local/bin/pydoc3.12' # fix Could not symlink bin/pydoc3.12
|
|
||||||
rm '/usr/local/bin/pydoc3' # fix Could not symlink bin/pydoc3
|
|
||||||
rm '/usr/local/bin/python3.11' # fix Could not symlink bin/python3.11
|
|
||||||
rm '/usr/local/bin/python3.12' # fix Could not symlink bin/python3.12
|
|
||||||
rm '/usr/local/bin/python3' # fix Could not symlink bin/python3
|
|
||||||
rm '/usr/local/bin/python3.11-config' # fix Could not symlink bin/python3.11-config
|
|
||||||
rm '/usr/local/bin/python3.12-config' # fix Could not symlink bin/python3.12-config
|
|
||||||
rm '/usr/local/bin/python3-config' # fix Could not symlink bin/python3-config
|
|
||||||
|
|
||||||
brew install watchman
|
brew install watchman
|
||||||
|
|
||||||
- name: Force usage fo gnu-tar
|
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain 1.79
|
||||||
|
source $HOME/.cargo/env
|
||||||
|
|
||||||
|
if test "${{ matrix.arch }}" = "aarch64"; then
|
||||||
|
rustup target add aarch64-apple-darwin
|
||||||
|
else
|
||||||
|
rustup target add x86_64-apple-darwin
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Force usage of gnu-tar
|
||||||
run: |
|
run: |
|
||||||
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.bash_profile
|
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.bash_profile
|
||||||
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.zsh
|
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.zsh
|
||||||
source ~/.bash_profile
|
source ~/.bash_profile
|
||||||
|
|
||||||
- name: Install pnpm
|
|
||||||
run: npm install -g pnpm
|
|
||||||
|
|
||||||
- name: Get pnpm store directory
|
|
||||||
id: pnpm-cache
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: pnpm install
|
run: |
|
||||||
- name: Load surfer CI setup
|
npm install
|
||||||
run: pnpm surfer ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
|
||||||
|
|
||||||
- name: Download firefox source and dependancies
|
- name: Load surfer CI setup
|
||||||
run: pnpm surfer download
|
run: npm run surfer -- ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
||||||
|
|
||||||
|
- name: Download Firefox source and dependencies
|
||||||
|
run: npm run download
|
||||||
|
|
||||||
- name: Bootstrap
|
- name: Bootstrap
|
||||||
run: |
|
run: |
|
||||||
cd engine
|
cd engine
|
||||||
|
export SURFER_PLATFORM="darwin"
|
||||||
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
||||||
./mach --no-interactive bootstrap --application-choice browser --no-system-changes
|
./mach --no-interactive bootstrap --application-choice browser --no-system-changes
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
- name: Import
|
- name: Import
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.arch == 'x64' }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
run: |
|
run: npm run import -- --verbose
|
||||||
pnpm surfer import --verbose
|
|
||||||
|
|
||||||
- name: Build language packs
|
- name: Build language packs
|
||||||
run: sh scripts/download-language-packs.sh
|
run: sh scripts/download-language-packs.sh
|
||||||
|
|
||||||
- name: build Zen
|
- name: Build Zen
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.arch == 'x64' }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
|
ZEN_RELEASE_BRANCH: ${{ inputs.release-branch }}
|
||||||
run: |
|
run: |
|
||||||
if test "${{ matrix.arch }}" = "x64"; then
|
export SURFER_PLATFORM="darwin"
|
||||||
export ZEN_DISABLE_LTO=1
|
if [[ -n ${{ inputs.MOZ_BUILD_DATE }} ]];then
|
||||||
|
export MOZ_BUILD_DATE=${{ inputs.MOZ_BUILD_DATE }}
|
||||||
fi
|
fi
|
||||||
sh .github/workflows/src/release-build.sh
|
bash .github/workflows/src/release-build.sh
|
||||||
|
|
||||||
- name: Rebuild Zen if failed
|
|
||||||
if: failure()
|
|
||||||
run: sh .github/workflows/src/release-build.sh
|
|
||||||
|
|
||||||
- name: import APPLE DEVELOPER ID CERTIFICATE for .app
|
|
||||||
uses: apple-actions/import-codesign-certs@v3
|
|
||||||
with:
|
|
||||||
p12-file-base64: ${{ secrets.macOS_CERTIFICATES_P12_For_App_BASE64 }}
|
|
||||||
p12-password: ${{ secrets.macOS_CERTIFICATES_P12_PASSWORD }}
|
|
||||||
|
|
||||||
- name: Package
|
- name: Package
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.arch == 'x64' }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
|
ZEN_GA_DISABLE_PGO: true
|
||||||
run: |
|
run: |
|
||||||
export MACOS_APPLE_DEVELOPER_ID="${{ secrets.macOS_AppleDeveloperId }}"
|
export SURFER_PLATFORM="darwin"
|
||||||
pnpm package
|
export ZEN_RELEASE=1
|
||||||
|
npm run package
|
||||||
|
|
||||||
- name: Rename artifacts
|
- name: Rename artifacts
|
||||||
run: |
|
run: |
|
||||||
mv ./dist/output.mar macos-${{ matrix.arch }}.mar
|
echo "Tarballing DMG"
|
||||||
|
|
||||||
- name: Sign to .dmg
|
|
||||||
run: |
|
|
||||||
set -ex
|
set -ex
|
||||||
hdiutil convert ./dist/*.dmg -format UDZO -imagekey zlib-level=9 -o zen.macos-${{ matrix.arch }}.dmg
|
mv ./dist/*.dmg ./zen-${{ matrix.arch }}-apple-darwin-dist.dmg
|
||||||
xattr -cr zen.macos-${{ matrix.arch }}.dmg
|
mv ./engine/obj-${{ matrix.arch }}-apple-darwin/dist/host/bin/mar ./zen-macos-host-mar
|
||||||
codesign -s "${{ secrets.macOS_AppleDeveloperId }}" zen.macos-${{ matrix.arch }}.dmg
|
mv ./engine/obj-${{ matrix.arch }}-apple-darwin/dist/bin/platform.ini ./platform.ini
|
||||||
xcrun notarytool submit "zen.macos-${{ matrix.arch }}.dmg" \
|
|
||||||
--apple-id "${{ secrets.macOS_AppleAccountId }}" \
|
|
||||||
--team-id "${{ secrets.macOS_AppleDeveloperIdTeamId }}" \
|
|
||||||
--password "${{ secrets.macOS_AppleDeveloperIdPassword }}" \
|
|
||||||
--wait
|
|
||||||
xcrun stapler staple "zen.macos-${{ matrix.arch }}.dmg"
|
|
||||||
|
|
||||||
- name: Upload artifact
|
- name: Upload dist dmg
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.macos-${{ matrix.arch }}.dmg
|
retention-days: 1
|
||||||
path: ./zen.macos-${{ matrix.arch }}.dmg
|
name: zen-${{ matrix.arch }}-apple-darwin-dist.dmg
|
||||||
|
path: ./zen-${{ matrix.arch }}-apple-darwin-dist.dmg
|
||||||
|
|
||||||
- name: Upload mar
|
- name: Upload host mar
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
|
if: matrix.arch == 'aarch64'
|
||||||
with:
|
with:
|
||||||
name: macos-${{ matrix.arch }}.mar
|
retention-days: 1
|
||||||
path: ./macos-${{ matrix.arch }}.mar
|
name: zen-macos-host-mar
|
||||||
|
path: ./zen-macos-host-mar
|
||||||
|
|
||||||
- name: Upload update manifests
|
- name: Upload platform.ini
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
|
if: matrix.arch == 'x86_64'
|
||||||
with:
|
with:
|
||||||
name: macos_update_manifest_${{ matrix.arch }}
|
retention-days: 1
|
||||||
path: ./dist/update
|
name: platform.ini
|
||||||
|
path: ./platform.ini
|
||||||
|
261
.github/workflows/macos-universal-release-build.yml
vendored
Normal file
@@ -0,0 +1,261 @@
|
|||||||
|
name: macOS Release Build
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
build-version:
|
||||||
|
description: 'The version to build'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
release-branch:
|
||||||
|
description: 'The branch to build'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
mac-build:
|
||||||
|
name: Unify macOS (Universal)
|
||||||
|
runs-on: 'macos-14'
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Setup Python
|
||||||
|
uses: actions/setup-python@v5
|
||||||
|
# note: This will use the version defined in '.python-version' by default
|
||||||
|
|
||||||
|
- name: Setup Git
|
||||||
|
run: |
|
||||||
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
|
git config --global user.name "mauro-balades"
|
||||||
|
|
||||||
|
- name: Install system dependencies
|
||||||
|
run: |
|
||||||
|
brew update
|
||||||
|
brew install cairo sccache gnu-tar mercurial
|
||||||
|
sudo pip install setuptools
|
||||||
|
|
||||||
|
brew uninstall --ignore-dependencies python3.12 -f
|
||||||
|
|
||||||
|
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
||||||
|
python3 -m pip install --user mercurial
|
||||||
|
|
||||||
|
rm '/usr/local/bin/2to3-3.11' '/usr/local/bin/2to3-3.12' '/usr/local/bin/2to3'
|
||||||
|
rm '/usr/local/bin/idle3.11' '/usr/local/bin/idle3.12' '/usr/local/bin/idle3'
|
||||||
|
rm '/usr/local/bin/pydoc3.11' '/usr/local/bin/pydoc3.12' '/usr/local/bin/pydoc3'
|
||||||
|
rm '/usr/local/bin/python3.11' '/usr/local/bin/python3.12' '/usr/local/bin/python3'
|
||||||
|
rm '/usr/local/bin/python3.11-config' '/usr/local/bin/python3.12-config' '/usr/local/bin/python3-config'
|
||||||
|
|
||||||
|
brew install watchman
|
||||||
|
|
||||||
|
cargo install apple-codesign
|
||||||
|
|
||||||
|
- name: Force usage of gnu-tar
|
||||||
|
run: |
|
||||||
|
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.bash_profile
|
||||||
|
echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.zsh
|
||||||
|
source ~/.bash_profile
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: |
|
||||||
|
npm install
|
||||||
|
|
||||||
|
- name: Load surfer CI setup
|
||||||
|
run: npm run surfer -- ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
||||||
|
|
||||||
|
- name: Download Firefox source and dependencies
|
||||||
|
run: npm run download
|
||||||
|
|
||||||
|
- name: Bootstrap
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
export SURFER_PLATFORM="darwin"
|
||||||
|
export PATH="$(python3 -m site --user-base)/bin":$PATH
|
||||||
|
./mach --no-interactive bootstrap --application-choice browser --no-system-changes
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
- name: Import
|
||||||
|
run: npm run import
|
||||||
|
|
||||||
|
- name: Populate mozconfig
|
||||||
|
env:
|
||||||
|
SURFER_MOZCONFIG_ONLY: true
|
||||||
|
run: |
|
||||||
|
npm run build
|
||||||
|
cd engine
|
||||||
|
./mach configure
|
||||||
|
|
||||||
|
- name: Download x86_64 DMG from artifacts
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: zen-x86_64-apple-darwin-dist.dmg
|
||||||
|
|
||||||
|
- name: Download aarch64 DMG from artifacts
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: zen-aarch64-apple-darwin-dist.dmg
|
||||||
|
|
||||||
|
- name: Remove any existing .app folders
|
||||||
|
run: |
|
||||||
|
set -x
|
||||||
|
cd engine
|
||||||
|
rm -rf "./obj-x86_64-apple-darwin/" || true
|
||||||
|
rm -rf "./obj-aarch64-apple-darwin/" || true
|
||||||
|
|
||||||
|
- name: Extract .app from dmg
|
||||||
|
run: |
|
||||||
|
set -ex
|
||||||
|
cd engine
|
||||||
|
echo "Extracting x86_64 .app from dmg"
|
||||||
|
mkdir -p ./obj-x86_64-apple-darwin/dist
|
||||||
|
mkdir -p ./obj-aarch64-apple-darwin/dist
|
||||||
|
./mach python -m mozbuild.action.unpack_dmg \
|
||||||
|
../zen-x86_64-apple-darwin-dist.dmg \
|
||||||
|
./obj-x86_64-apple-darwin/dist
|
||||||
|
echo "Extracting aarch64 .app from dmg"
|
||||||
|
./mach python -m mozbuild.action.unpack_dmg \
|
||||||
|
../zen-aarch64-apple-darwin-dist.dmg \
|
||||||
|
./obj-aarch64-apple-darwin/dist
|
||||||
|
|
||||||
|
- name: Find first .app folder name
|
||||||
|
run: |
|
||||||
|
cd engine/obj-x86_64-apple-darwin/dist
|
||||||
|
export APP_NAME=$(basename "$(find . -maxdepth 1 -name "Zen *.app" -type d | head -n 1)" .app)
|
||||||
|
echo "APP_NAME=$APP_NAME" >> $GITHUB_ENV
|
||||||
|
echo "APP_NAME=$APP_NAME"
|
||||||
|
|
||||||
|
- name: List .app folders
|
||||||
|
run: |
|
||||||
|
ls engine/
|
||||||
|
echo "--------------------"
|
||||||
|
cd engine/obj-x86_64-apple-darwin/dist
|
||||||
|
find . -maxdepth 1 -name "*.app" -type d
|
||||||
|
cd ../..
|
||||||
|
|
||||||
|
- name: create .p12 for codesign 🖊️
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
echo "${{ secrets.macOS_CERTIFICATES_P12_For_App_BASE64 }}" > cert.txt
|
||||||
|
base64 --decode -i cert.txt -o zenCert.p12
|
||||||
|
echo "${{ secrets.macOS_CERTIFICATES_P12_PASSWORD }}" > zenpCertPassword.passwd
|
||||||
|
|
||||||
|
- name: Remove certificate sensitive information
|
||||||
|
run: |
|
||||||
|
rm engine/cert.txt || true
|
||||||
|
|
||||||
|
- name: Import provisioning profile for .app
|
||||||
|
run: |
|
||||||
|
echo "${{ secrets.macOS_PROVISIONING_PROFILE }}" | base64 --decode > ./engine/Zen_Browser.provisionprofile
|
||||||
|
ls -la
|
||||||
|
|
||||||
|
- name: Unify architectures
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
./mach python "./toolkit/mozapps/installer/unify.py" "./obj-x86_64-apple-darwin/dist/${{ env.APP_NAME }}.app" "./obj-aarch64-apple-darwin/dist/${{ env.APP_NAME }}.app"
|
||||||
|
echo "Merged aaarch64 into x86_64!"
|
||||||
|
|
||||||
|
- name: Import APPLE DEVELOPER ID CERTIFICATE for .app
|
||||||
|
uses: Apple-Actions/import-codesign-certs@v3
|
||||||
|
with:
|
||||||
|
p12-file-base64: ${{ secrets.macOS_CERTIFICATES_P12_For_App_BASE64 }}
|
||||||
|
p12-password: ${{ secrets.macOS_CERTIFICATES_P12_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Copy provisioning profile for .app (embedded in .app)
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
echo "Copying provisioning profile for .app on both architectures (${{ env.APP_NAME }})"
|
||||||
|
cp ./Zen_Browser.provisionprofile "./embedded.provisionprofile"
|
||||||
|
|
||||||
|
- name: Sign .app
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
# TODO: Change it to "production" once we figure out the issue with the webauth
|
||||||
|
./mach macos-sign -v -r -c "release" -e "production-without-restricted" -a "./obj-x86_64-apple-darwin/dist/${{ env.APP_NAME }}.app" --rcodesign-p12-file zenCert.p12 --rcodesign-p12-password-file zenpCertPassword.passwd
|
||||||
|
|
||||||
|
- name: Create DMG
|
||||||
|
run: |
|
||||||
|
cd engine
|
||||||
|
./mach python -m mozbuild.action.make_dmg \
|
||||||
|
--volume-name "${{ env.APP_NAME }}" \
|
||||||
|
--background ./browser/branding/${{ inputs.release-branch }}/background.png \
|
||||||
|
--icon ./browser/branding/${{ inputs.release-branch }}/firefox.icns \
|
||||||
|
--dsstore ./browser/branding/${{ inputs.release-branch }}/dsstore \
|
||||||
|
./obj-x86_64-apple-darwin/dist/ ../zen-macOS-universal-temp.dmg
|
||||||
|
|
||||||
|
- name: Remove sensitive information
|
||||||
|
run: |
|
||||||
|
rm -f ./engine/Zen_Browser.provisionprofile
|
||||||
|
|
||||||
|
- name: Sign .dmg
|
||||||
|
run: |
|
||||||
|
set -ex
|
||||||
|
hdiutil convert zen-macOS-universal-temp.dmg -format UDZO -imagekey zlib-level=9 -o zen.macos-universal.dmg
|
||||||
|
codesign -s "${{ secrets.macOS_AppleDeveloperId }}" zen.macos-universal.dmg
|
||||||
|
xcrun notarytool submit "zen.macos-universal.dmg" \
|
||||||
|
--apple-id "${{ secrets.macOS_AppleAccountId }}" \
|
||||||
|
--team-id "${{ secrets.macOS_AppleDeveloperIdTeamId }}" \
|
||||||
|
--password "${{ secrets.macOS_AppleDeveloperIdPassword }}" \
|
||||||
|
--no-s3-acceleration \
|
||||||
|
--wait
|
||||||
|
xcrun stapler staple "zen.macos-universal.dmg"
|
||||||
|
|
||||||
|
- name: Download host mar
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: zen-macos-host-mar
|
||||||
|
|
||||||
|
- name: Upload build artifact
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
retention-days: 5
|
||||||
|
name: zen.macos-universal.dmg
|
||||||
|
path: ./zen.macos-universal.dmg
|
||||||
|
|
||||||
|
- name: Download platform.ini
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: platform.ini
|
||||||
|
|
||||||
|
- name: Package for mar
|
||||||
|
env:
|
||||||
|
JUST_MAR: true
|
||||||
|
run: |
|
||||||
|
# we don't need it anymore
|
||||||
|
set -ex
|
||||||
|
rm -rf ./engine/obj-aarch64-apple-darwin
|
||||||
|
mkdir -p ./engine/obj-x86_64-apple-darwin/dist/bin
|
||||||
|
mv ./platform.ini ./engine/obj-x86_64-apple-darwin/dist/bin/platform.ini
|
||||||
|
export SURFER_PLATFORM="darwin"
|
||||||
|
export ZEN_RELEASE=1
|
||||||
|
# full path to zen-macos-host-mar
|
||||||
|
export MAR=$(pwd)/zen-macos-host-mar
|
||||||
|
chmod +x $MAR
|
||||||
|
echo "MAR=$MAR"
|
||||||
|
npm run package -- --verbose
|
||||||
|
mv ./dist/output.mar ./macos.mar
|
||||||
|
|
||||||
|
- name: Upload build artifact (.mar)
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
retention-days: 5
|
||||||
|
name: macos.mar
|
||||||
|
path: ./macos.mar
|
||||||
|
|
||||||
|
- name: Upload build artifact (update manifests)
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
retention-days: 5
|
||||||
|
name: macos_update_manifest
|
||||||
|
path: ./dist/update
|
@@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<updates>
|
|
||||||
<update type="minor" displayVersion="1.0.1-a.7" appVersion="1.0.1-a.7" platformVersion="130.0.1" buildID="20240930174115">
|
|
||||||
<patch type="complete" URL="https://github.com/zen-browser/desktop/releases/download/1.0.1-a.7/windows-generic.mar" hashFunction="sha512" hashValue="ec9d34b84fd7e2fce56f5df376993ced4e4c6e9e597f15db6ff872fe9a8503bea1545752cf957a8615e3623c6c062ae9883d71659f7c1e71c2f142fb0b97febc" size="72392464"/>
|
|
||||||
</update>
|
|
||||||
</updates>
|
|
@@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<updates>
|
|
||||||
<update type="minor" displayVersion="1.0.1-a.7" appVersion="1.0.1-a.7" platformVersion="130.0.1" buildID="20240930174115">
|
|
||||||
<patch type="complete" URL="https://github.com/zen-browser/desktop/releases/download/1.0.1-a.7/windows-generic.mar" hashFunction="sha512" hashValue="ec9d34b84fd7e2fce56f5df376993ced4e4c6e9e597f15db6ff872fe9a8503bea1545752cf957a8615e3623c6c062ae9883d71659f7c1e71c2f142fb0b97febc" size="72392464"/>
|
|
||||||
</update>
|
|
||||||
</updates>
|
|
@@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<updates>
|
|
||||||
<update type="minor" displayVersion="1.0.1-a.7" appVersion="1.0.1-a.7" platformVersion="130.0.1" buildID="20240930174542">
|
|
||||||
<patch type="complete" URL="https://github.com/zen-browser/desktop/releases/download/1.0.1-a.7/windows.mar" hashFunction="sha512" hashValue="3489df92ea8f25a36fa72f91097b48c6934a8988e291e828380660d60b2e763db2b20281889c60c471437f570342fabec439c8cd33e3594ef0e8a50050544c57" size="72415792"/>
|
|
||||||
</update>
|
|
||||||
</updates>
|
|
@@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<updates>
|
|
||||||
<update type="minor" displayVersion="1.0.1-a.7" appVersion="1.0.1-a.7" platformVersion="130.0.1" buildID="20240930174542">
|
|
||||||
<patch type="complete" URL="https://github.com/zen-browser/desktop/releases/download/1.0.1-a.7/windows.mar" hashFunction="sha512" hashValue="3489df92ea8f25a36fa72f91097b48c6934a8988e291e828380660d60b2e763db2b20281889c60c471437f570342fabec439c8cd33e3594ef0e8a50050544c57" size="72415792"/>
|
|
||||||
</update>
|
|
||||||
</updates>
|
|
32
.github/workflows/pr-test.yml
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
name: Pull request test
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- dev
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
pr-test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
|
- name: Install Surfer
|
||||||
|
run: npm i -g @zen-browser/surfer
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: npm install
|
||||||
|
|
||||||
|
- name: Download Firefox and dependencies
|
||||||
|
run: surfer download
|
||||||
|
|
||||||
|
- name: Import patches
|
||||||
|
run: surfer i
|
20
.github/workflows/src/release-build.sh
vendored
@@ -1,26 +1,28 @@
|
|||||||
set -ex
|
#!/bin/bash
|
||||||
|
|
||||||
if command -v apt-get &> /dev/null
|
set -xe
|
||||||
then
|
|
||||||
|
if command -v apt-get &> /dev/null; then
|
||||||
|
sudo add-apt-repository ppa:kisak/kisak-mesa
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y xvfb
|
sudo apt-get install -y xvfb libnvidia-egl-wayland1 mesa-utils libgl1-mesa-dri
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ulimit -n 4096
|
ulimit -n 4096
|
||||||
|
|
||||||
# Check if xfvb is installed
|
if command -v Xvfb &> /dev/null; then
|
||||||
if ! command -v Xvfb &> /dev/null; then
|
|
||||||
if ! test "$ZEN_CROSS_COMPILING"; then
|
if ! test "$ZEN_CROSS_COMPILING"; then
|
||||||
Xvfb :2 -screen 0 1024x768x24 &
|
Xvfb :2 -nolisten tcp -noreset -screen 0 1024x768x24 &
|
||||||
export LLVM_PROFDATA=$HOME/.mozbuild/clang/bin/llvm-profdata
|
export LLVM_PROFDATA=$HOME/.mozbuild/clang/bin/llvm-profdata
|
||||||
export DISPLAY=:2
|
export DISPLAY=:2
|
||||||
fi
|
fi
|
||||||
export ZEN_RELEASE=1
|
export ZEN_RELEASE=1
|
||||||
pnpm build
|
npm run build
|
||||||
else
|
else
|
||||||
echo "Xvfb could not be found, running without it"
|
echo "Xvfb could not be found, running without it"
|
||||||
echo "ASSUMING YOU ARE RUNNING THIS ON MACOS"
|
echo "ASSUMING YOU ARE RUNNING THIS ON MACOS"
|
||||||
|
|
||||||
set -v
|
set -v
|
||||||
export ZEN_RELEASE=1
|
export ZEN_RELEASE=1
|
||||||
pnpm build
|
npm run build
|
||||||
fi
|
fi
|
||||||
|
29
.github/workflows/stale.yml
vendored
@@ -1,29 +0,0 @@
|
|||||||
name: Close inactive issues
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '0 0 * * *'
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
close-issues:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
permissions:
|
|
||||||
issues: write
|
|
||||||
pull-requests: write
|
|
||||||
steps:
|
|
||||||
- uses: actions/stale@v5
|
|
||||||
with:
|
|
||||||
days-before-issue-stale: 30
|
|
||||||
days-before-issue-close: 14
|
|
||||||
stale-issue-label: 'stale'
|
|
||||||
stale-issue-message: |
|
|
||||||
This issue is stale because it has been open for 30 days with no activity.
|
|
||||||
|
|
||||||
Please close this issue if you feel it is no longer relevant, or comment if you have more information to share.
|
|
||||||
close-issue-message: |
|
|
||||||
This issue was closed because it has been inactive for 14 days since being marked as stale.
|
|
||||||
|
|
||||||
If you think this issue should remain open, please comment with a request for it to be re-opened or open a new issue.
|
|
||||||
days-before-pr-stale: -1
|
|
||||||
days-before-pr-close: -1
|
|
||||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
|
15
.github/workflows/staler.yml
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
name: 'Close stale issues and PRs'
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '30 1 * * *'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
stale:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/stale@v9
|
||||||
|
with:
|
||||||
|
stale-issue-message: 'This issue is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days.'
|
||||||
|
days-before-stale: 65
|
||||||
|
days-before-close: 10
|
21
.github/workflows/twilight-release-schedule.yml
vendored
@@ -1,8 +1,15 @@
|
|||||||
name: Zen Twilight Scheduled Releases
|
name: Zen Twilight Scheduled Releases
|
||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 0 * * *'
|
- cron: '0 23 * * *'
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
create_release:
|
||||||
|
description: 'Whether to do a release'
|
||||||
|
required: false
|
||||||
|
type: boolean
|
||||||
|
default: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
twilight-release-schedule:
|
twilight-release-schedule:
|
||||||
@@ -11,7 +18,7 @@ jobs:
|
|||||||
secrets: inherit
|
secrets: inherit
|
||||||
uses: ./.github/workflows/build.yml
|
uses: ./.github/workflows/build.yml
|
||||||
with:
|
with:
|
||||||
create_release: true
|
create_release: ${{ github.event_name != 'workflow_dispatch' && true || inputs.create_release }}
|
||||||
update_branch: twilight
|
update_branch: twilight
|
||||||
update_version: false
|
update_version: false
|
||||||
|
|
||||||
@@ -20,12 +27,10 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: twilight-release-schedule
|
needs: twilight-release-schedule
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install Node.js and pnpm
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
node-version: 20
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
# TODO:
|
|
||||||
|
31
.github/workflows/update-submodules.yml
vendored
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
name: Update Components Submodules
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- dev
|
||||||
|
workflow_dispatch:
|
||||||
|
workflow_call:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
update-submodules:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
if: "!contains(github.event.head_commit.message, '[skip ci]')"
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
|
- name: Update submodules
|
||||||
|
run: |
|
||||||
|
git submodule update --remote --merge
|
||||||
|
|
||||||
|
- name: Commit
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
|
with:
|
||||||
|
commit_message: '[skip ci] 📦 Update submodules'
|
||||||
|
commit_user_name: Zen Browser Robot
|
||||||
|
commit_user_email: zen-browser-auto@users.noreply.github.com
|
64
.github/workflows/windows-profile-build.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: Windows PGO Builds
|
name: Windows PGO Builds
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
@@ -17,53 +18,69 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
windows-profile-build:
|
windows-profile-build:
|
||||||
name: Windows Profile Build - ${{ matrix.generic == true && 'generic' || 'specific' }}
|
name: |
|
||||||
|
Windows Profile Build - ${{ matrix.arch }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
generic: [true, false]
|
arch: [x86_64, aarch64]
|
||||||
runs-on: windows-latest
|
|
||||||
# Script edited from https://github.com/Floorp-Projects/Floorp/blob/ESR115/.github/workflows/window-generate-profile-data-and-jarlog.yml
|
runs-on: ${{ inputs.release-branch == 'release' && 'windows-latest' || 'windows-latest' }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Install Node.js and pnpm
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
node-version: 20
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email "mauro-balades@users.noreply.github.com"
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
git config --global user.name "mauro-balades"
|
git config --global user.name "mauro-balades"
|
||||||
- name: Install pnpm
|
|
||||||
run: npm install -g pnpm
|
|
||||||
|
|
||||||
- name: Install Surfer
|
- name: Install Surfer
|
||||||
run: |
|
run: npm i -g @zen-browser/surfer
|
||||||
npm i -g @zen-browser/surfer
|
|
||||||
- uses: actions/download-artifact@v4
|
- name: Load Surfer CI setup
|
||||||
name: Download artifact
|
run: npm run surfer -- ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
||||||
|
|
||||||
|
- name: Download artifact
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
with:
|
with:
|
||||||
path: C:\artifact
|
path: C:\artifact
|
||||||
name: ${{ matrix.generic == true && 'generic' || 'specific' }}-zen-windows-x86_64-profile-data-and-jarlog.zip
|
name: ${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}-zen-windows-profile-data-and-jarlog.zip
|
||||||
|
|
||||||
- name: Unpack artifact
|
- name: Unpack artifact
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
cd C:\artifact
|
cd C:\artifact
|
||||||
ls
|
ls
|
||||||
Expand-Archive -Path .\${{ inputs.profile-data-path-archive }} -DestinationPath C:\artifact
|
Expand-Archive -Path .\${{ inputs.profile-data-path-archive }} -DestinationPath C:\artifact
|
||||||
ls
|
ls
|
||||||
|
|
||||||
- name: Setup
|
- name: Setup
|
||||||
run: |
|
run: |
|
||||||
(New-Object System.Net.WebClient).DownloadFile("https://ftp.mozilla.org/pub/mozilla/libraries/win32/MozillaBuildSetup-Latest.exe", "C:\MozillaBuildSetup-Latest.exe")
|
(New-Object System.Net.WebClient).DownloadFile("https://ftp.mozilla.org/pub/mozilla/libraries/win32/MozillaBuildSetup-Latest.exe", "C:\MozillaBuildSetup-Latest.exe")
|
||||||
C:\MozillaBuildSetup-Latest.exe /S | out-null
|
C:\MozillaBuildSetup-Latest.exe /S | out-null
|
||||||
- name: Download firefox
|
|
||||||
|
- name: Download Firefox and dependencies
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
git config --global core.safecrlf false
|
git config --global core.safecrlf false
|
||||||
pnpm surfer download
|
npm run download
|
||||||
|
|
||||||
|
- name: Import patches
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
|
env:
|
||||||
|
SURFER_NO_BRANDING_PATCH: true
|
||||||
|
run: npm run import
|
||||||
|
|
||||||
- name: Generate
|
- name: Generate
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
ls
|
ls
|
||||||
$Env:USE_MINTTY = "0"
|
$Env:USE_MINTTY = "0"
|
||||||
@@ -77,22 +94,25 @@ jobs:
|
|||||||
echo 'LLVM_PROFDATA=/c/Users/runneradmin/.mozbuild/clang/bin/llvm-profdata.exe JARLOG_FILE=en-US.log ./mach python build/pgo/profileserver.py --binary /c/artifact/zen/zen.exe' '' >> mozilla-build-run.sh
|
echo 'LLVM_PROFDATA=/c/Users/runneradmin/.mozbuild/clang/bin/llvm-profdata.exe JARLOG_FILE=en-US.log ./mach python build/pgo/profileserver.py --binary /c/artifact/zen/zen.exe' '' >> mozilla-build-run.sh
|
||||||
C:\mozilla-build\start-shell.bat $workspace_dir_current\mozilla-build-run.sh
|
C:\mozilla-build\start-shell.bat $workspace_dir_current\mozilla-build-run.sh
|
||||||
|
|
||||||
- name: 🐛 Debug Session
|
- name: Debug session
|
||||||
if: ${{ failure() }}
|
if: ${{ failure() }}
|
||||||
uses: Warpbuilds/gha-debug@v1.3
|
uses: WarpBuilds/action-debugger@v1.3
|
||||||
timeout-minutes: 15
|
timeout-minutes: 15
|
||||||
|
|
||||||
- name: Move profile data
|
- name: Move profile data
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
dir
|
dir
|
||||||
dir engine
|
dir engine
|
||||||
mv engine/merged.profdata merged.profdata
|
mv engine/merged.profdata merged.profdata
|
||||||
mv engine/en-US.log en-US.log
|
mv engine/en-US.log en-US.log
|
||||||
|
|
||||||
- name: Publish artifacts
|
- name: Upload artifacts
|
||||||
|
if: ${{ matrix.arch == 'x86_64' }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
|
retention-days: 1
|
||||||
path: |
|
path: |
|
||||||
merged.profdata
|
merged.profdata
|
||||||
en-US.log
|
en-US.log
|
||||||
name: windows-profdata-${{ matrix.generic == true && 'generic' || 'specific' }}
|
name: windows-profdata-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}
|
||||||
|
215
.github/workflows/windows-release-build.yml
vendored
@@ -1,4 +1,5 @@
|
|||||||
name: Windows Release Build
|
name: Windows Release Build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
@@ -17,53 +18,59 @@ on:
|
|||||||
description: 'The branch to build'
|
description: 'The branch to build'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
MOZ_BUILD_DATE:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
default: ''
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
windows-build:
|
windows-build:
|
||||||
name: Build Windows - ${{ matrix.generic == true && 'Generic' || 'Specific' }}
|
name: Build Windows - ${{ matrix.arch }}
|
||||||
runs-on: ubuntu-latest
|
# aarch64 does not need full 16x, and we also dont use full LTO when generating GPO
|
||||||
|
runs-on: ${{ (inputs.release-branch == 'release' && !inputs.generate-gpo && matrix.arch == 'x86_64') && 'self-hosted' || 'ubuntu-latest' }}
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
generic: [true, false]
|
arch: [x86_64, aarch64]
|
||||||
environment: production
|
|
||||||
steps:
|
steps:
|
||||||
- name: Free Disk Space (Ubuntu)
|
- name: Free Disk Space (Ubuntu)
|
||||||
uses: jlumbroso/free-disk-space@main
|
uses: jlumbroso/free-disk-space@main
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
with:
|
with:
|
||||||
# this might remove tools that are actually needed,
|
|
||||||
# if set to "true" but frees about 6 GB
|
|
||||||
tool-cache: false
|
tool-cache: false
|
||||||
|
|
||||||
- name: Install Node.js and pnpm
|
- name: Checkout repository
|
||||||
uses: actions/setup-node@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
with:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
token: ${{ secrets.DEPLOY_KEY }}
|
token: ${{ secrets.DEPLOY_KEY }}
|
||||||
|
|
||||||
- name: Install pnpm
|
- name: Setup Node.js
|
||||||
run: npm install -g pnpm
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
|
||||||
- name: Setup git
|
- name: Setup Git
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email "mauro-balades@users.noreply.github.com"
|
git config --global user.email "mauro-balades@users.noreply.github.com"
|
||||||
git config --global user.name "mauro-balades"
|
git config --global user.name "mauro-balades"
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: |
|
run: |
|
||||||
pnpm i
|
npm install
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y python3 python3-pip dos2unix yasm nasm build-essential libgtk2.0-dev libpython3-dev m4 uuid libasound2-dev libcurl4-openssl-dev libdbus-1-dev libdrm-dev libdbus-glib-1-dev libgtk-3-dev libpulse-dev libx11-xcb-dev libxt-dev xvfb lld llvm --fix-missing
|
||||||
|
|
||||||
- name: Load surfer CI setup
|
- name: Load Surfer CI setup
|
||||||
run: pnpm surfer ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
run: npm run surfer -- ci --brand ${{ inputs.release-branch }} --display-version ${{ inputs.build-version }}
|
||||||
|
|
||||||
- name: Download
|
- name: Download Firefox and dependencies
|
||||||
run: pnpm surfer download
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
|
run: npm run download
|
||||||
|
|
||||||
- name: 'win-cross Cache'
|
- name: win-cross Cache
|
||||||
env:
|
env:
|
||||||
SEGMENT_DOWNLOAD_TIMEOUT_MINS: 5
|
SEGMENT_DOWNLOAD_TIMEOUT_MINS: 5
|
||||||
id: cache-win-cross
|
id: cache-win-cross
|
||||||
@@ -79,89 +86,128 @@ jobs:
|
|||||||
core.exportVariable('ACTIONS_CACHE_URL', process.env.ACTIONS_CACHE_URL || '');
|
core.exportVariable('ACTIONS_CACHE_URL', process.env.ACTIONS_CACHE_URL || '');
|
||||||
core.exportVariable('ACTIONS_RUNTIME_TOKEN', process.env.ACTIONS_RUNTIME_TOKEN || '');
|
core.exportVariable('ACTIONS_RUNTIME_TOKEN', process.env.ACTIONS_RUNTIME_TOKEN || '');
|
||||||
|
|
||||||
- name: Setup For Windows
|
- name: Setup for Windows
|
||||||
if: steps.cache-win-cross.outputs.cache-hit != 'true'
|
if: steps.cache-win-cross.outputs.cache-hit != 'true' && !(inputs.generate-gpo && matrix.arch == 'aarch64')
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
mkdir -p ~/win-cross
|
mkdir -p ~/win-cross
|
||||||
cd engine/
|
cd engine/
|
||||||
|
sudo add-apt-repository ppa:savoury1/backports
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y python3-pip autoconf \
|
||||||
|
autoconf2.13 \
|
||||||
|
automake \
|
||||||
|
bison \
|
||||||
|
build-essential \
|
||||||
|
cabextract \
|
||||||
|
curl \
|
||||||
|
cmake \
|
||||||
|
flex \
|
||||||
|
gawk \
|
||||||
|
gcc-multilib \
|
||||||
|
git \
|
||||||
|
gnupg \
|
||||||
|
jq \
|
||||||
|
libbz2-dev \
|
||||||
|
libexpat1-dev \
|
||||||
|
libffi-dev \
|
||||||
|
libncursesw5-dev \
|
||||||
|
libsqlite3-dev \
|
||||||
|
libssl-dev \
|
||||||
|
libtool \
|
||||||
|
libucl-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
msitools \
|
||||||
|
ninja-build \
|
||||||
|
openssh-client \
|
||||||
|
p7zip-full \
|
||||||
|
pkg-config \
|
||||||
|
procps \
|
||||||
|
python3-requests \
|
||||||
|
python3-toml \
|
||||||
|
scons \
|
||||||
|
subversion \
|
||||||
|
tar \
|
||||||
|
unzip \
|
||||||
|
uuid \
|
||||||
|
uuid-dev \
|
||||||
|
wget \
|
||||||
|
zip \
|
||||||
|
zlib1g-dev \
|
||||||
|
aria2
|
||||||
echo Setup wine
|
echo Setup wine
|
||||||
aria2c "https://firefox-ci-tc.services.mozilla.com/api/index/v1/task/gecko.cache.level-1.toolchains.v3.linux64-wine.latest/artifacts/public%2Fbuild%2Fwine.tar.zst" -o wine.tar.zst
|
aria2c "https://firefox-ci-tc.services.mozilla.com/api/index/v1/task/gecko.cache.level-1.toolchains.v3.linux64-wine.latest/artifacts/public%2Fbuild%2Fwine.tar.zst" -o wine.tar.zst
|
||||||
tar --zstd -xvf wine.tar.zst -C ~/win-cross
|
tar --zstd -xvf wine.tar.zst -C ~/win-cross
|
||||||
rm wine.tar.zst
|
rm wine.tar.zst
|
||||||
|
|
||||||
echo Setup Visual Studio
|
echo Setup Visual Studio
|
||||||
sudo apt install -y msitools python3-pip
|
|
||||||
./mach python --virtualenv build taskcluster/scripts/misc/get_vs.py build/vs/vs2022.yaml ~/win-cross/vs2022
|
./mach python --virtualenv build taskcluster/scripts/misc/get_vs.py build/vs/vs2022.yaml ~/win-cross/vs2022
|
||||||
|
|
||||||
- name: Bootstrap
|
- name: Bootstrap
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
cd engine/
|
cd engine/
|
||||||
|
|
||||||
chmod -R +x "$(echo ~)/win-cross/vs2022" || true
|
chmod -R +x "$(echo ~)/win-cross/vs2022" || true
|
||||||
|
|
||||||
cd ..
|
cd ..
|
||||||
npm install -g pnpm
|
|
||||||
export SURFER_PLATFORM="win32"
|
export SURFER_PLATFORM="win32"
|
||||||
pnpm surfer bootstrap
|
npm run bootstrap
|
||||||
|
|
||||||
cd engine/
|
cd engine/
|
||||||
ls ~/.mozbuild/clang/lib/clang/
|
ls ~/.mozbuild/clang/lib/clang/
|
||||||
echo "export LIB=\"$(cd ~/.mozbuild/clang/lib/clang/* && cd lib/windows && pwd)\"" >> ../configs/common/mozconfig
|
echo "export LIB=\"$(cd ~/.mozbuild/clang/lib/clang/* && cd lib/windows && pwd)\"" >> ../configs/common/mozconfig
|
||||||
cat ../configs/common/mozconfig
|
cat ../configs/common/mozconfig
|
||||||
|
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install dos2unix
|
sudo apt-get install dos2unix
|
||||||
|
|
||||||
ls ~/win-cross/wine || true
|
ls ~/win-cross/wine || true
|
||||||
ls ~/win-cross/vs2022 || true
|
ls ~/win-cross/vs2022 || true
|
||||||
|
|
||||||
- name: setup Rust
|
- name: Setup Rust
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
run: |
|
run: |
|
||||||
cd engine/
|
cd engine/
|
||||||
# Install a rust version compatible with 17
|
|
||||||
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain 1.79
|
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain 1.79
|
||||||
source $HOME/.cargo/env
|
source $HOME/.cargo/env
|
||||||
|
if test "${{ matrix.arch }}" = "aarch64"; then
|
||||||
|
rustup target add aarch64-pc-windows-msvc
|
||||||
|
else
|
||||||
rustup target add x86_64-pc-windows-msvc
|
rustup target add x86_64-pc-windows-msvc
|
||||||
|
fi
|
||||||
cargo install cargo-download
|
cargo install cargo-download
|
||||||
cargo download -x windows=0.58.0
|
cargo download -x windows=0.58.0
|
||||||
#? https://github.com/mozilla/sccache#known-caveats
|
|
||||||
export CARGO_INCREMENTAL=0
|
export CARGO_INCREMENTAL=0
|
||||||
|
|
||||||
echo "" >> ../configs/common/mozconfig
|
echo "" >> ../configs/common/mozconfig
|
||||||
echo "export MOZ_WINDOWS_RS_DIR=$(pwd)/windows-0.58.0" >> ../configs/common/mozconfig
|
echo "export MOZ_WINDOWS_RS_DIR=$(pwd)/windows-0.58.0" >> ../configs/common/mozconfig
|
||||||
|
|
||||||
- name: Import
|
- name: Import
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
run: pnpm surfer import --verbose
|
run: npm run import -- --verbose
|
||||||
|
|
||||||
- name: Build language packs
|
- name: Build language packs
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
run: sh scripts/download-language-packs.sh
|
run: sh scripts/download-language-packs.sh
|
||||||
|
|
||||||
- uses: actions/download-artifact@v4
|
- name: Download artifact (if use profdata)
|
||||||
name: Download artifact if use profdata
|
uses: actions/download-artifact@v4
|
||||||
if: ${{ !inputs.generate-gpo }}
|
if: ${{ !inputs.generate-gpo && matrix.arch == 'x86_64' }}
|
||||||
with:
|
with:
|
||||||
path: ~/artifact
|
path: ~/artifact
|
||||||
name: windows-profdata-${{ matrix.generic == true && 'generic' || 'specific' }}
|
name: windows-profdata-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}
|
||||||
|
|
||||||
- name: Show artifact info
|
- name: Show artifact info
|
||||||
if: ${{ !inputs.generate-gpo }}
|
if: ${{ !inputs.generate-gpo && matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
ls ~/artifact
|
ls ~/artifact
|
||||||
ls ~/artifact/en-US.log
|
ls ~/artifact/en-US.log
|
||||||
ls ~/artifact/merged.profdata
|
ls ~/artifact/merged.profdata
|
||||||
|
|
||||||
chmod +x ~/artifact/en-US.log
|
chmod +x ~/artifact/en-US.log
|
||||||
chmod +x ~/artifact/merged.profdata
|
chmod +x ~/artifact/merged.profdata
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
|
ZEN_RELEASE_BRANCH: ${{ inputs.release-branch }}
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
dos2unix configs/windows/mozconfig
|
dos2unix configs/windows/mozconfig
|
||||||
@@ -170,26 +216,33 @@ jobs:
|
|||||||
if test ${{ inputs.generate-gpo }} = true; then
|
if test ${{ inputs.generate-gpo }} = true; then
|
||||||
export ZEN_GA_GENERATE_PROFILE=1
|
export ZEN_GA_GENERATE_PROFILE=1
|
||||||
fi
|
fi
|
||||||
sh .github/workflows/src/release-build.sh
|
if [[ -n ${{ inputs.MOZ_BUILD_DATE }} ]];then
|
||||||
|
export MOZ_BUILD_DATE=${{ inputs.MOZ_BUILD_DATE }}
|
||||||
|
fi
|
||||||
|
bash .github/workflows/src/release-build.sh
|
||||||
|
|
||||||
- name: Package
|
- name: Package
|
||||||
|
if: ${{ !(inputs.generate-gpo && matrix.arch == 'aarch64') }}
|
||||||
env:
|
env:
|
||||||
SURFER_COMPAT: ${{ matrix.generic == true }}
|
SURFER_COMPAT: ${{ matrix.arch }}
|
||||||
|
ZEN_GA_DISABLE_PGO: true
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
export SURFER_PLATFORM="win32"
|
export SURFER_PLATFORM="win32"
|
||||||
pnpm package
|
export ZEN_CROSS_COMPILING=1
|
||||||
mv ./dist/zen-$(pnpm surfer get version | xargs).en-US.win64.zip zen.win64.zip
|
export ZEN_RELEASE=1
|
||||||
|
npm run package
|
||||||
|
mv ./dist/zen-$(npm run --silent surfer -- get version | xargs).en-US.win64${{ matrix.arch == 'aarch64' && '-aarch64' || '' }}.zip zen.win64.zip
|
||||||
ls ./dist
|
ls ./dist
|
||||||
ls .
|
ls .
|
||||||
|
|
||||||
- name: 🐛 Debug Session
|
- name: Debug session
|
||||||
if: ${{ failure() }}
|
if: ${{ failure() }}
|
||||||
uses: Warpbuilds/gha-debug@v1.3
|
uses: WarpBuilds/action-debugger@v1.3
|
||||||
timeout-minutes: 15
|
timeout-minutes: 15
|
||||||
|
|
||||||
- name: Move package for PGO upload
|
- name: Move package for PGO upload
|
||||||
if: ${{ inputs.generate-gpo }}
|
if: ${{ inputs.generate-gpo && matrix.arch == 'x86_64' }}
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
mv ./zen.win64.zip ./zen.win64-pgo-stage-1.zip
|
mv ./zen.win64.zip ./zen.win64-pgo-stage-1.zip
|
||||||
@@ -197,54 +250,66 @@ jobs:
|
|||||||
- name: Rename artifacts
|
- name: Rename artifacts
|
||||||
if: ${{ !inputs.generate-gpo }}
|
if: ${{ !inputs.generate-gpo }}
|
||||||
run: |
|
run: |
|
||||||
mv ./zen.win64.zip zen.win-${{ matrix.generic == true && 'generic' || 'specific' }}.zip
|
mv ./zen.win64.zip zen.win-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}.zip
|
||||||
mv ./dist/output.mar windows${{ matrix.generic == true && '-generic' || '' }}.mar
|
mv ./dist/output.mar windows${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.mar
|
||||||
mv ./dist/zen.installer.exe ./zen.installer${{ matrix.generic == true && '-generic' || '' }}.exe
|
mv ./dist/zen.installer.exe ./zen.installer${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.exe
|
||||||
|
|
||||||
- name: Upload PGO build
|
- name: Upload artifact (PGO)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
if: ${{ inputs.generate-gpo }}
|
if: ${{ inputs.generate-gpo && matrix.arch == 'x86_64' }}
|
||||||
with:
|
with:
|
||||||
name: ${{ matrix.generic == true && 'generic' || 'specific' }}-${{ inputs.profile-data-path-archive }}
|
retention-days: 5
|
||||||
|
name: ${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}-${{ inputs.profile-data-path-archive }}
|
||||||
path: ./zen.win64-pgo-stage-1.zip
|
path: ./zen.win64-pgo-stage-1.zip
|
||||||
|
|
||||||
- name: Remove symlinks from obj folder
|
- name: Remove unnecessary files from obj
|
||||||
if: ${{ !inputs.generate-gpo }}
|
if: ${{ !inputs.generate-gpo }}
|
||||||
run: |
|
run: |
|
||||||
set -x
|
set -x
|
||||||
find engine/obj-x86_64-pc-windows-msvc/ -type l -delete
|
if test "${{ matrix.arch }}" = "aarch64"; then
|
||||||
|
find engine/obj-aarch64-pc-windows-msvc/ -mindepth 1 -maxdepth 1 -type d -not -name 'dist' -exec rm -rf {} \;
|
||||||
|
find engine/obj-aarch64-pc-windows-msvc/ -mindepth 1 -maxdepth 1 -type f -not -name 'dist' -exec rm -f {} \;
|
||||||
|
else
|
||||||
|
find engine/obj-x86_64-pc-windows-msvc/ -mindepth 1 -maxdepth 1 -type d -not -name 'dist' -exec rm -rf {} \;
|
||||||
|
find engine/obj-x86_64-pc-windows-msvc/ -mindepth 1 -maxdepth 1 -type f -not -name 'dist' -exec rm -f {} \;
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Upload dist object
|
- name: Upload dist object
|
||||||
if: ${{ !inputs.generate-gpo }}
|
if: ${{ !inputs.generate-gpo }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: windows-x64-obj-${{ matrix.generic == true && 'generic' || 'specific' }}
|
retention-days: 5
|
||||||
path: engine/obj-x86_64-pc-windows-msvc/
|
name: windows-x64-obj-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}
|
||||||
|
path: engine/obj-${{ matrix.arch == 'aarch64' && 'aarch64' || 'x86_64' }}-pc-windows-msvc/
|
||||||
|
|
||||||
- name: Upload zip file if twilight branch
|
- name: Upload artifact (if Twilight branch, binary)
|
||||||
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.win-${{ matrix.generic == true && 'generic' || 'specific' }}.zip
|
retention-days: 5
|
||||||
path: ./zen.win-${{ matrix.generic == true && 'generic' || 'specific' }}.zip
|
name: zen.win-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}.zip
|
||||||
|
path: ./zen.win-${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}.zip
|
||||||
|
|
||||||
- name: Upload installer if twilight branch
|
- name: Upload artifact (if Twilight branch, installer)
|
||||||
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: zen.installer${{ matrix.generic == true && '-generic' || '' }}.exe
|
retention-days: 5
|
||||||
path: ./zen.installer${{ matrix.generic == true && '-generic' || '' }}.exe
|
name: zen.installer${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.exe
|
||||||
|
path: ./zen.installer${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.exe
|
||||||
|
|
||||||
- name: Upload mar if twilight branch
|
- name: Upload artifact (if Twilight branch, .mar)
|
||||||
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: windows${{ matrix.generic == true && '-generic' || '' }}.mar
|
retention-days: 5
|
||||||
path: ./windows${{ matrix.generic == true && '-generic' || '' }}.mar
|
name: windows${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.mar
|
||||||
|
path: ./windows${{ matrix.arch == 'aarch64' && '-arm64' || '' }}.mar
|
||||||
|
|
||||||
- name: Upload update manifests if twilight branch
|
- name: Upload artifact (if Twilight branch, update manifests)
|
||||||
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
if: ${{ inputs.release-branch == 'twilight' && !inputs.generate-gpo }}
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: windows_update_manifest_${{ matrix.generic == true && 'generic' || 'specific' }}
|
retention-days: 5
|
||||||
|
name: windows_update_manifest_${{ matrix.arch == 'aarch64' && 'arm64' || matrix.arch }}
|
||||||
path: ./dist/update
|
path: ./dist/update
|
||||||
|
4
.gitignore
vendored
@@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
.dotbuild/
|
.dotbuild/
|
||||||
engine/
|
engine/
|
||||||
firefox-*/
|
firefox-*/
|
||||||
@@ -9,3 +8,6 @@ __pycache__/
|
|||||||
dist/
|
dist/
|
||||||
|
|
||||||
windsign-temp/
|
windsign-temp/
|
||||||
|
venv/
|
||||||
|
|
||||||
|
!firefox-cache/
|
||||||
|
3
.gitmodules
vendored
@@ -1,6 +1,3 @@
|
|||||||
[submodule "src/browser/base/content/zen-components"]
|
|
||||||
path = src/browser/base/content/zen-components
|
|
||||||
url = https://github.com/zen-browser/components
|
|
||||||
[submodule "l10n"]
|
[submodule "l10n"]
|
||||||
path = l10n
|
path = l10n
|
||||||
url = https://github.com/zen-browser/l10n-packs
|
url = https://github.com/zen-browser/l10n-packs
|
||||||
|
@@ -1 +1 @@
|
|||||||
# npx lint-staged
|
npx lint-staged
|
||||||
|
@@ -3,10 +3,26 @@ engine/
|
|||||||
**/*.html
|
**/*.html
|
||||||
**/*.xhtml
|
**/*.xhtml
|
||||||
**/*.inc.xhtml
|
**/*.inc.xhtml
|
||||||
|
**/*.bundle.min.js
|
||||||
|
**/*.min.js
|
||||||
|
**/*.min.mjs
|
||||||
|
|
||||||
**/*.svg
|
**/*.svg
|
||||||
|
|
||||||
|
surfer.json
|
||||||
|
|
||||||
src/browser/app/profile/*.js
|
src/browser/app/profile/*.js
|
||||||
pnpm-lock.yaml
|
pnpm-lock.yaml
|
||||||
|
|
||||||
**/engine/
|
**/engine/
|
||||||
|
|
||||||
|
docs/issue-metrics/*.md
|
||||||
|
|
||||||
|
.husky/
|
||||||
|
|
||||||
|
# Some CSS files are preprocessed and prettier doesn't handle them well
|
||||||
|
# We also dont want to format the CSS files that are generated by the build
|
||||||
|
src/browser/base/content/zen-styles/zen-tabs/vertical-tabs.css
|
||||||
|
src/browser/base/content/zen-styles/zen-compact-mode.css
|
||||||
|
src/browser/base/zen-components/ZenEmojies.mjs
|
||||||
|
build/codesign/codesign.bash
|
||||||
|
@@ -8,5 +8,5 @@
|
|||||||
"jsxSingleQuote": false,
|
"jsxSingleQuote": false,
|
||||||
"semi": true,
|
"semi": true,
|
||||||
"printWidth": 128,
|
"printWidth": 128,
|
||||||
"plugins": []
|
"plugins": ["prettier-plugin-sh"]
|
||||||
}
|
}
|
||||||
|
1
.python-version
Normal file
@@ -0,0 +1 @@
|
|||||||
|
3.11
|
@@ -5,7 +5,7 @@ Exec=zen %u
|
|||||||
Icon=zen
|
Icon=zen
|
||||||
Type=Application
|
Type=Application
|
||||||
MimeType=text/html;text/xml;application/xhtml+xml;x-scheme-handler/http;x-scheme-handler/https;application/x-xpinstall;application/pdf;application/json;
|
MimeType=text/html;text/xml;application/xhtml+xml;x-scheme-handler/http;x-scheme-handler/https;application/x-xpinstall;application/pdf;application/json;
|
||||||
StartupWMClass=zen-alpha
|
StartupWMClass=zen
|
||||||
Categories=Network;WebBrowser;
|
Categories=Network;WebBrowser;
|
||||||
StartupNotify=true
|
StartupNotify=true
|
||||||
Terminal=false
|
Terminal=false
|
||||||
|
@@ -17,23 +17,23 @@ diverse, inclusive, and healthy community.
|
|||||||
Examples of behavior that contributes to a positive environment for our
|
Examples of behavior that contributes to a positive environment for our
|
||||||
community include:
|
community include:
|
||||||
|
|
||||||
* Demonstrating empathy and kindness toward other people
|
- Demonstrating empathy and kindness toward other people
|
||||||
* Being respectful of differing opinions, viewpoints, and experiences
|
- Being respectful of differing opinions, viewpoints, and experiences
|
||||||
* Giving and gracefully accepting constructive feedback
|
- Giving and gracefully accepting constructive feedback
|
||||||
* Accepting responsibility and apologizing to those affected by our mistakes,
|
- Accepting responsibility and apologizing to those affected by our mistakes,
|
||||||
and learning from the experience
|
and learning from the experience
|
||||||
* Focusing on what is best not just for us as individuals, but for the
|
- Focusing on what is best not just for us as individuals, but for the
|
||||||
overall community
|
overall community
|
||||||
|
|
||||||
Examples of unacceptable behavior include:
|
Examples of unacceptable behavior include:
|
||||||
|
|
||||||
* The use of sexualized language or imagery, and sexual attention or
|
- The use of sexualized language or imagery, and sexual attention or
|
||||||
advances of any kind
|
advances of any kind
|
||||||
* Trolling, insulting or derogatory comments, and personal or political attacks
|
- Trolling, insulting or derogatory comments, and personal or political attacks
|
||||||
* Public or private harassment
|
- Public or private harassment
|
||||||
* Publishing others' private information, such as a physical or email
|
- Publishing others' private information, such as a physical or email
|
||||||
address, without their explicit permission
|
address, without their explicit permission
|
||||||
* Other conduct which could reasonably be considered inappropriate in a
|
- Other conduct which could reasonably be considered inappropriate in a
|
||||||
professional setting
|
professional setting
|
||||||
|
|
||||||
## Enforcement Responsibilities
|
## Enforcement Responsibilities
|
||||||
|
205
README.md
@@ -1,64 +1,83 @@
|
|||||||
<div align="center">
|
<img src="./docs/assets/zen-dark.svg" width="100px" align="left">
|
||||||
<picture>
|
|
||||||
<img src="./docs/assets/zen-black.svg" width="128px">
|
|
||||||
</picture>
|
|
||||||
</div>
|
|
||||||
<h1 align="center">
|
|
||||||
Zen Browser
|
|
||||||
</h1>
|
|
||||||
|
|
||||||
Experience tranquillity while browsing the web without people tracking you!
|
### `Zen Browser`
|
||||||
|
|
||||||
- [Website](https://zen-browser.app)
|
|
||||||
- [Download](https://zen-browser.app/download)
|
|
||||||
- [Release Notes](https://zen-browser.app/release-notes/latest)
|
|
||||||
|
|
||||||
[](https://github.com/zen-browser/desktop/releases)
|
[](https://github.com/zen-browser/desktop/releases)
|
||||||
[](https://crowdin.com/project/zen-browser)
|
[](https://crowdin.com/project/zen-browser)
|
||||||
|
[](https://github.com/zen-browser/desktop/actions/workflows/build.yml)
|
||||||
|
|
||||||
[](https://flathub.org/apps/io.github.zen_browser.zen)
|
✨ Experience tranquillity while browsing the web without people tracking you! Zen is a privacy-focused browser that blocks trackers, ads, and other unwanted content while offering the best browsing experience!
|
||||||
|
|
||||||
[](https://www.patreon.com/zen_browser)
|
<div flex="true">
|
||||||
|
<a href="https://zen-browser.app/download">
|
||||||
|
Download
|
||||||
|
</a>
|
||||||
|
•
|
||||||
|
<a href="https://zen-browser.app">
|
||||||
|
Website
|
||||||
|
</a>
|
||||||
|
•
|
||||||
|
<a href="https://docs.zen-browser.app">
|
||||||
|
Documentation
|
||||||
|
</a>
|
||||||
|
•
|
||||||
|
<a href="https://zen-browser.app/release-notes/latest">
|
||||||
|
Release Notes
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
[](https://ko-fi.com/zen_browser)
|
## 🖥️ Compatibility
|
||||||
|
|
||||||
# Compatibility
|
Zen is currently built using firefox version `135.0`! 🚀
|
||||||
|
|
||||||
Zen is currently built using firefox version `131.0.2`!
|
|
||||||
|
|
||||||
|
- [`Zen Twilight`](https://zen-browser.app/download?twilight) - Is currently built using firefox version `RC 135.0`!
|
||||||
- Check out the latest [release notes](https://zen-browser.app/release-notes)!
|
- Check out the latest [release notes](https://zen-browser.app/release-notes)!
|
||||||
|
- Part of our mission is to keep Zen up-to-date with the latest version of Firefox, so you can enjoy the latest features and security updates!
|
||||||
|
|
||||||
# Performance
|
## 🤝 Contribution
|
||||||
|
|
||||||
Zen is built with performance in mind, and we have optimized the browser to be as fast as possible!
|
Zen is an open-source project, and we welcome contributions from the community! Please take a look at the [contribution guidelines](./docs/contribute.md) before getting started!
|
||||||
|
|
||||||
- Checkout the latest [performance benchmarks](https://docs.zen-browser.app/benchmarks)!
|
### Issue metrics
|
||||||
|
|
||||||
# Installation
|
We keep track of how many issues are closed at the end of the month in [docs/issue-metrics](./docs/issue-metrics). This is to keep track of how many issues are being closed, because who doesn't like to see progress? 📈
|
||||||
|
|
||||||
## Supported Operating Systems
|
### Versioning
|
||||||
|
|
||||||
|
Zen uses [Semantic Versioning](https://semver.org/) for versioning. Meaning, versions are displayed as `a.bc.d` where:
|
||||||
|
|
||||||
|
- `a` is the major version
|
||||||
|
- `b` is the minor version
|
||||||
|
- `c` is the branch prefix
|
||||||
|
- `d` is the patch version
|
||||||
|
|
||||||
|
### Branches
|
||||||
|
|
||||||
|
Zen is divided into 2 main branches. We use `dev` for development and `stable` for stable releases. The `dev` branch is where all the new features are added and where `twilight` builds are generated. The `stable` branch is where the stable releases are generated.
|
||||||
|
|
||||||
|
We divide into 2 branches in case there's any really important security update (for example) that needs to be released before the next stable release. This allows us to do patches without releasing unstable versions to the public.
|
||||||
|
|
||||||
|
## ⚡ Performance
|
||||||
|
|
||||||
|
Zen is built with performance in mind, and we have optimized the browser to be as fast as possible! Checkout the latest [performance benchmarks](https://docs.zen-browser.app/benchmarks)!
|
||||||
|
|
||||||
|
## 📥 Installation
|
||||||
|
|
||||||
|
### Supported Operating Systems
|
||||||
|
|
||||||
Zen is available for Linux, macOS, and Windows. You can download the latest version from the official website at [zen-browser.app](https://zen-browser.app/download), or from the [GitHub Releases](https://github.com/zen-browser/desktop/releases) page.
|
Zen is available for Linux, macOS, and Windows. You can download the latest version from the official website at [zen-browser.app](https://zen-browser.app/download), or from the [GitHub Releases](https://github.com/zen-browser/desktop/releases) page.
|
||||||
|
|
||||||
### Windows
|
If you dont see your OS listed below, that's because we already have it in our [downloads page](https://zen-browser.app/download)! Make sure to check it out!
|
||||||
|
|
||||||
#### Winget
|
#### Windows
|
||||||
|
|
||||||
- Generic
|
##### Winget
|
||||||
|
|
||||||
```
|
```ps
|
||||||
winget install --id Zen-Team.Zen-Browser
|
winget install --id Zen-Team.Zen-Browser
|
||||||
```
|
```
|
||||||
|
|
||||||
- Optimized
|
#### macOS
|
||||||
|
|
||||||
```
|
|
||||||
winget install --id Zen-Team.Zen-Browser.Optimized
|
|
||||||
```
|
|
||||||
|
|
||||||
####
|
|
||||||
|
|
||||||
### macOS
|
|
||||||
|
|
||||||
- Requires macOS 10.15 or later
|
- Requires macOS 10.15 or later
|
||||||
- Available for ARM and Intel architectures
|
- Available for ARM and Intel architectures
|
||||||
@@ -69,109 +88,55 @@ You can also install Zen using Homebrew:
|
|||||||
brew install --cask zen-browser
|
brew install --cask zen-browser
|
||||||
```
|
```
|
||||||
|
|
||||||
### Linux
|
#### Linux
|
||||||
|
|
||||||
#### AppImage
|
##### Arch-based distributions
|
||||||
|
|
||||||
|
```sh
|
||||||
|
yay -S zen-browser-bin
|
||||||
|
```
|
||||||
|
|
||||||
|
##### Other Linux distributions (AppImage with automated system integration)
|
||||||
|
|
||||||
|
- `native` tarball install:
|
||||||
|
`bash <(curl -s https://updates.zen-browser.app/install.sh)`
|
||||||
|
|
||||||
- `zsync` is required for the Update feature of the script below
|
- `zsync` is required for the Update feature of the script below
|
||||||
|
|
||||||
```
|
```sh
|
||||||
bash <(curl https://updates.zen-browser.app/appimage.sh)
|
bash <(curl https://updates.zen-browser.app/appimage.sh)
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Flatpak
|
- Again, if you don't see your OS listed above, that's because we already have it in our [downloads page](https://zen-browser.app/download)! 🔄
|
||||||
|
|
||||||
```
|
|
||||||
flatpak install flathub io.github.zen_browser.zen
|
|
||||||
```
|
|
||||||
|
|
||||||
#### CachyOS
|
|
||||||
##### Generic
|
|
||||||
```
|
|
||||||
sudo pacman -S zen-browser-bin
|
|
||||||
```
|
|
||||||
|
|
||||||
##### Optimized
|
|
||||||
```
|
|
||||||
sudo pacman -S zen-browser-avx2-bin
|
|
||||||
```
|
|
||||||
|
|
||||||
To upgrade the browser to a newer version, use the embedded update functionality in `About Zen`.
|
To upgrade the browser to a newer version, use the embedded update functionality in `About Zen`.
|
||||||
|
|
||||||
# Core Components
|
## 👨💻 Development and Contributing
|
||||||
|
|
||||||
Some components used by @zen-browser as an attempt to make firefox forks a better place. You can find them [here](https://github.com/zen-browser/components).
|
Some components used by @zen-browser as an attempt to make firefox forks a better place, and for other to enjoy the beauty of OSS. You can find them [here](https://github.com/zen-browser/desktop/tree/dev/src/browser/base/zen-components).
|
||||||
|
|
||||||
## 🚀 Run Locally
|
#### `Run Locally`
|
||||||
|
|
||||||
Clone the project
|
In order to download and run zen locally, please follow [these instructions](https://docs.zen-browser.app/building).
|
||||||
|
|
||||||
```bash
|
#### `Special Thanks`
|
||||||
git clone https://github.com/zen-browser/desktop.git --recurse-submodules
|
|
||||||
cd desktop
|
|
||||||
```
|
|
||||||
|
|
||||||
Install dependencies
|
Special thanks to... EVERYONE 🎉! Checkout the team and contributors page [here](https://zen-browser.app/about)
|
||||||
|
|
||||||
```bash
|
#### `Third Party Code`
|
||||||
pnpm install
|
|
||||||
```
|
|
||||||
|
|
||||||
Download and bootstrap the browser
|
Zen couldn't be in its current state without the help of these amazing projects! 🙏
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm run init
|
|
||||||
```
|
|
||||||
|
|
||||||
Copy a language pack
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sh scripts/update-en-US-packs.sh
|
|
||||||
```
|
|
||||||
|
|
||||||
Start building the browser
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm run build
|
|
||||||
```
|
|
||||||
|
|
||||||
Finally, run the browser!
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm start
|
|
||||||
```
|
|
||||||
|
|
||||||
### Development
|
|
||||||
|
|
||||||
To view changes you've made, run
|
|
||||||
|
|
||||||
```bash
|
|
||||||
pnpm build:ui && pnpm start
|
|
||||||
```
|
|
||||||
|
|
||||||
## Special Thanks
|
|
||||||
|
|
||||||
- [IAmJafeth](https://github.com/IAmJafeth) (For sponsoring the domain)
|
|
||||||
- [Donno 🐒](https://www.onnno.nl/) (For making the logo)
|
|
||||||
- [ptr1337](https://github.com/ptr1337) (AUR Packages and optimization flags)
|
|
||||||
- [nitro](https://github.com/n7itro) (For the amazing work on the browser)
|
|
||||||
|
|
||||||
## Third Party Code
|
|
||||||
|
|
||||||
Zen couldn't be in its current state without the help of these amazing projects!
|
|
||||||
|
|
||||||
- Zen's default preferences are based on [BetterFox](https://github.com/yokoffing/Betterfox)
|
- Zen's default preferences are based on [BetterFox](https://github.com/yokoffing/Betterfox)
|
||||||
|
- Gradient image extracted from [Arc Palette](https://github.com/neurokitti/Arc_Palette)
|
||||||
|
- `icons.css` has been modified from [Edge Firefox](https://github.com/bmFtZQ/edge-frfox) (MIT licensed file).
|
||||||
|
|
||||||
## License
|
### 🖥️ Comparison with other browsers
|
||||||
|
|
||||||
[MPL LICENSE](./LICENSE)
|
Thanks everyone for making zen stand out among these giants!
|
||||||
|
|
||||||
## Star History
|
[](https://star-history.com/#zen-browser/desktop&chromium/chromium&brave/brave-browser&Date)
|
||||||
|
|
||||||
<a href="https://star-history.com/#zen-browser/desktop&Date">
|
## 📄 License
|
||||||
<picture>
|
|
||||||
<source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/svg?repos=zen-browser/desktop&type=Date&theme=dark" />
|
Zen browser is under the [MPL LICENSE](./LICENSE). All the code is open-source and free to use! Attributions are appreciated but not required.
|
||||||
<source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/svg?repos=zen-browser/desktop&type=Date" />
|
|
||||||
<img alt="Star History Chart" src="https://api.star-history.com/svg?repos=zen-browser/desktop&type=Date" />
|
|
||||||
</picture>
|
|
||||||
</a>
|
|
||||||
|
@@ -1,32 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<!--
|
|
||||||
Entitlements to apply to the main browser process executable during
|
|
||||||
codesigning of production channel builds.
|
|
||||||
-->
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<!-- Firefox needs to create executable pages (without MAP_JIT) -->
|
|
||||||
<key>com.apple.security.cs.allow-unsigned-executable-memory</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to create executable pages with MAP_JIT on aarch64 -->
|
|
||||||
<key>com.apple.security.cs.allow-jit</key><true/>
|
|
||||||
|
|
||||||
<!-- Allow loading third party libraries. Needed for Flash and CDMs -->
|
|
||||||
<key>com.apple.security.cs.disable-library-validation</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the microphone on sites the user allows -->
|
|
||||||
<key>com.apple.security.device.audio-input</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the camera on sites the user allows -->
|
|
||||||
<key>com.apple.security.device.camera</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the location on sites the user allows -->
|
|
||||||
<key>com.apple.security.personal-information.location</key><true/>
|
|
||||||
|
|
||||||
<!-- Allow Firefox to send Apple events to other applications. Needed
|
|
||||||
for native messaging webextension helper applications launched by
|
|
||||||
Firefox which rely on Apple Events to signal other processes. -->
|
|
||||||
<key>com.apple.security.automation.apple-events</key><true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@@ -1,169 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
||||||
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
||||||
# file, You can obtain one at https://mozilla.org/MPL/2.0/.
|
|
||||||
#
|
|
||||||
# Runs codesign commands to codesign a Firefox .app bundle and enable macOS
|
|
||||||
# Hardened Runtime. Intended to be manually run by developers working on macOS
|
|
||||||
# 10.14+ who want to enable Hardened Runtime for manual testing. This is
|
|
||||||
# provided as a stop-gap until automated build tooling is available that signs
|
|
||||||
# binaries with a certificate generated during builds (bug 1522409). This
|
|
||||||
# script requires macOS 10.14 because Hardened Runtime is only available for
|
|
||||||
# applications running on 10.14 despite support for the codesign "-o runtime"
|
|
||||||
# option being available in 10.13.6 and newer.
|
|
||||||
#
|
|
||||||
# The script requires an identity string (-i option) from an Apple Developer
|
|
||||||
# ID certificate. This can be found in the macOS KeyChain after configuring an
|
|
||||||
# Apple Developer ID certificate.
|
|
||||||
#
|
|
||||||
# Example usage on macOS 10.14:
|
|
||||||
#
|
|
||||||
# $ ./mach build
|
|
||||||
# $ ./mach build package
|
|
||||||
# $ open </PATH/TO/DMG/FILE.dmg>
|
|
||||||
# <Drag Nightly.app to ~>
|
|
||||||
# $ ./security/mac/hardenedruntime/codesign.bash \
|
|
||||||
# -a ~/Nightly.app \
|
|
||||||
# -i <MY-IDENTITY-STRING> \
|
|
||||||
# -b security/mac/hardenedruntime/browser.developer.entitlements.xml
|
|
||||||
# -p security/mac/hardenedruntime/plugin-container.developer.entitlements.xml
|
|
||||||
# $ open ~/Nightly.app
|
|
||||||
#
|
|
||||||
|
|
||||||
usage ()
|
|
||||||
{
|
|
||||||
echo "Usage: $0 "
|
|
||||||
echo " -a <PATH-TO-BROWSER.app>"
|
|
||||||
echo " -i <IDENTITY>"
|
|
||||||
echo " -b <ENTITLEMENTS-FILE>"
|
|
||||||
echo " -p <CHILD-ENTITLEMENTS-FILE>"
|
|
||||||
echo " [-o <OUTPUT-DMG-FILE>]"
|
|
||||||
exit -1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Make sure we are running on macOS with the sw_vers command available.
|
|
||||||
SWVERS=/usr/bin/sw_vers
|
|
||||||
if [ ! -x ${SWVERS} ]; then
|
|
||||||
echo "ERROR: macOS 10.14 or later is required"
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Require macOS 10.14 or newer.
|
|
||||||
#OSVERSION=`${SWVERS} -productVersion|sed -En 's/[0-9]+\.([0-9]+)\.[0-9]+/\1/p'`;
|
|
||||||
#if [ ${OSVERSION} \< 14 ]; then
|
|
||||||
# echo "ERROR: macOS 10.14 or later is required"
|
|
||||||
# exit -1
|
|
||||||
#fi
|
|
||||||
|
|
||||||
while getopts "a:i:b:o:p:" opt; do
|
|
||||||
case ${opt} in
|
|
||||||
a ) BUNDLE=$OPTARG ;;
|
|
||||||
i ) IDENTITY=$OPTARG ;;
|
|
||||||
b ) BROWSER_ENTITLEMENTS_FILE=$OPTARG ;;
|
|
||||||
p ) PLUGINCONTAINER_ENTITLEMENTS_FILE=$OPTARG ;;
|
|
||||||
o ) OUTPUT_DMG_FILE=$OPTARG ;;
|
|
||||||
\? ) usage; exit -1 ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if [ -z "${BUNDLE}" ] ||
|
|
||||||
[ -z "${IDENTITY}" ] ||
|
|
||||||
[ -z "${PLUGINCONTAINER_ENTITLEMENTS_FILE}" ] ||
|
|
||||||
[ -z "${BROWSER_ENTITLEMENTS_FILE}" ]; then
|
|
||||||
usage
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -d "${BUNDLE}" ]; then
|
|
||||||
echo "Invalid bundle. Bundle should be a .app directory"
|
|
||||||
usage
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -e "${PLUGINCONTAINER_ENTITLEMENTS_FILE}" ]; then
|
|
||||||
echo "Invalid entitlements file"
|
|
||||||
usage
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -e "${BROWSER_ENTITLEMENTS_FILE}" ]; then
|
|
||||||
echo "Invalid entitlements file"
|
|
||||||
usage
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# DMG file output flag is optional
|
|
||||||
if [ ! -z "${OUTPUT_DMG_FILE}" ] &&
|
|
||||||
[ -e "${OUTPUT_DMG_FILE}" ]; then
|
|
||||||
echo "Output dmg file ${OUTPUT_DMG_FILE} exists. Please delete it first."
|
|
||||||
usage
|
|
||||||
exit -1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "-------------------------------------------------------------------------"
|
|
||||||
echo "bundle: $BUNDLE"
|
|
||||||
echo "identity: $IDENTITY"
|
|
||||||
echo "browser entitlements file: $BROWSER_ENTITLEMENTS_FILE"
|
|
||||||
echo "plugin-container entitlements file: $PLUGINCONTAINER_ENTITLEMENTS_FILE"
|
|
||||||
echo "output dmg file (optional): $OUTPUT_DMG_FILE"
|
|
||||||
echo "-------------------------------------------------------------------------"
|
|
||||||
|
|
||||||
set -x
|
|
||||||
|
|
||||||
# Clear extended attributes which cause codesign to fail
|
|
||||||
xattr -cr "${BUNDLE}"
|
|
||||||
|
|
||||||
# Sign these binaries first. Signing of some binaries has an ordering
|
|
||||||
# requirement where other binaries must be signed first.
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" \
|
|
||||||
"${BUNDLE}/Contents/Library/LaunchServices/org.mozilla.updater" \
|
|
||||||
"${BUNDLE}/Contents/MacOS/XUL" \
|
|
||||||
"${BUNDLE}/Contents/MacOS/pingsender" \
|
|
||||||
"${BUNDLE}/Contents/MacOS/*.dylib" \
|
|
||||||
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" --deep \
|
|
||||||
"${BUNDLE}"/Contents/MacOS/updater.app
|
|
||||||
|
|
||||||
# Sign zen main executable
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" --deep \
|
|
||||||
--entitlements ${BROWSER_ENTITLEMENTS_FILE} \
|
|
||||||
"${BUNDLE}"/Contents/MacOS/zen
|
|
||||||
|
|
||||||
# Sign Library/LaunchServices
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" --deep \
|
|
||||||
"${BUNDLE}"/Contents/Library/LaunchServices/org.mozilla.updater
|
|
||||||
|
|
||||||
# Sign gmp-clearkey files
|
|
||||||
find "${BUNDLE}"/Contents/Resources/gmp-clearkey -type f -exec \
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" {} \;
|
|
||||||
|
|
||||||
# Sign the main bundle
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" \
|
|
||||||
--entitlements ${BROWSER_ENTITLEMENTS_FILE} "${BUNDLE}"
|
|
||||||
|
|
||||||
# Sign the plugin-container bundle with deep
|
|
||||||
codesign --force -o runtime --verbose --sign "$IDENTITY" --deep \
|
|
||||||
--entitlements ${PLUGINCONTAINER_ENTITLEMENTS_FILE} \
|
|
||||||
"${BUNDLE}"/Contents/MacOS/plugin-container.app
|
|
||||||
|
|
||||||
# Validate
|
|
||||||
codesign -vvv --deep --strict "${BUNDLE}"
|
|
||||||
|
|
||||||
# Create a DMG
|
|
||||||
if [ ! -z "${OUTPUT_DMG_FILE}" ]; then
|
|
||||||
DISK_IMAGE_DIR=`mktemp -d`
|
|
||||||
TEMP_FILE=`mktemp`
|
|
||||||
TEMP_DMG=${TEMP_FILE}.dmg
|
|
||||||
NAME=`basename "${BUNDLE}"`
|
|
||||||
|
|
||||||
ditto "${BUNDLE}" "${DISK_IMAGE_DIR}/${NAME}"
|
|
||||||
hdiutil create -size 400m -fs HFS+ \
|
|
||||||
-volname Firefox -srcfolder "${DISK_IMAGE_DIR}" "${TEMP_DMG}"
|
|
||||||
hdiutil convert -format UDZO \
|
|
||||||
-o "${OUTPUT_DMG_FILE}" "${TEMP_DMG}"
|
|
||||||
|
|
||||||
rm ${TEMP_FILE}
|
|
||||||
rm ${TEMP_DMG}
|
|
||||||
rm -rf "${DISK_IMAGE_DIR}"
|
|
||||||
fi
|
|
@@ -1,32 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<!--
|
|
||||||
Entitlements to apply to the plugin-container.app bundle during
|
|
||||||
codesigning of production channel builds.
|
|
||||||
-->
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<!-- Firefox needs to create executable pages (without MAP_JIT) -->
|
|
||||||
<key>com.apple.security.cs.allow-unsigned-executable-memory</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to create executable pages with MAP_JIT on aarch64 -->
|
|
||||||
<key>com.apple.security.cs.allow-jit</key><true/>
|
|
||||||
|
|
||||||
<!-- Allow loading third party libraries. Needed for Flash and CDMs -->
|
|
||||||
<key>com.apple.security.cs.disable-library-validation</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the microphone on sites the user allows -->
|
|
||||||
<key>com.apple.security.device.audio-input</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the camera on sites the user allows -->
|
|
||||||
<key>com.apple.security.device.camera</key><true/>
|
|
||||||
|
|
||||||
<!-- Firefox needs to access the location on sites the user allows -->
|
|
||||||
<key>com.apple.security.personal-information.location</key><true/>
|
|
||||||
|
|
||||||
<!-- Allow Firefox to send Apple events to other applications. Needed
|
|
||||||
for native messaging webextension helper applications launched by
|
|
||||||
Firefox which rely on Apple Events to signal other processes. -->
|
|
||||||
<key>com.apple.security.automation.apple-events</key><true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
@@ -1,5 +1,6 @@
|
|||||||
param(
|
param(
|
||||||
[string][Parameter(Mandatory=$true)]$SignIdentity
|
[string][Parameter(Mandatory=$true)]$SignIdentity,
|
||||||
|
[string][Parameter(Mandatory=$true)]$GithubRunId
|
||||||
)
|
)
|
||||||
|
|
||||||
$ErrorActionPreference = "Stop"
|
$ErrorActionPreference = "Stop"
|
||||||
@@ -8,15 +9,27 @@ echo "Preparing environment"
|
|||||||
git pull --recurse-submodules
|
git pull --recurse-submodules
|
||||||
mkdir windsign-temp -ErrorAction SilentlyContinue
|
mkdir windsign-temp -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
echo "Please UNZIP the generic and specific artifacts into windsign-temp"
|
# Download in parallel
|
||||||
echo "With the following filenames:"
|
|
||||||
echo " - $pwd\windsign-temp\windows-x64-obj-specific"
|
|
||||||
echo " - $pwd\windsign-temp\windows-x64-obj-generic"
|
|
||||||
Read-Host "Press Enter to continue when ready"
|
|
||||||
mkdir engine\obj-x86_64-pc-windows-msvc\ -ErrorAction SilentlyContinue
|
|
||||||
mkdir .\.github\workflows\object\ -ErrorAction SilentlyContinue
|
|
||||||
|
|
||||||
pnpm surfer ci --brand alpha
|
#show output too
|
||||||
|
#Start-Job -Name "DownloadGitObjectsRepo" -ScriptBlock {
|
||||||
|
# param($PWD)
|
||||||
|
# echo "Downloading git objects repo to $PWD\windsign-temp\windows-binaries"
|
||||||
|
# git clone https://github.com/zen-browser/windows-binaries.git $PWD\windsign-temp\windows-binaries
|
||||||
|
# echo "Downloaded git objects repo to"
|
||||||
|
#} -Verbose -ArgumentList $PWD -Debug
|
||||||
|
|
||||||
|
gh run download $GithubRunId --name windows-x64-obj-arm64 -D windsign-temp\windows-x64-obj-arm64
|
||||||
|
echo "Downloaded arm64 artifacts"
|
||||||
|
gh run download $GithubRunId --name windows-x64-obj-x86_64 -D windsign-temp\windows-x64-obj-x86_64
|
||||||
|
echo "Downloaded x86_64 artifacts"
|
||||||
|
|
||||||
|
|
||||||
|
#Wait-Job -Name "DownloadGitObjectsRepo"
|
||||||
|
|
||||||
|
mkdir engine\obj-x86_64-pc-windows-msvc\ -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
npm run surfer -- ci --brand release
|
||||||
|
|
||||||
function SignAndPackage($name) {
|
function SignAndPackage($name) {
|
||||||
echo "Executing on $name"
|
echo "Executing on $name"
|
||||||
@@ -33,43 +46,50 @@ function SignAndPackage($name) {
|
|||||||
echo "Packaging $name"
|
echo "Packaging $name"
|
||||||
$env:SURFER_SIGNING_MODE="sign"
|
$env:SURFER_SIGNING_MODE="sign"
|
||||||
$env:MAR="$PWD\\build\\winsign\\mar.exe"
|
$env:MAR="$PWD\\build\\winsign\\mar.exe"
|
||||||
if ($name -eq "generic") {
|
if ($name -eq "arm64") {
|
||||||
$env:SURFER_COMPAT="true"
|
$env:SURFER_COMPAT="aarch64"
|
||||||
} else {
|
} else {
|
||||||
rm env:SURFER_COMPAT -ErrorAction SilentlyContinue
|
$env:SURFER_COMPAT="x86_64"
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "Compat Mode? $env:SURFER_COMPAT"
|
echo "Compat Mode? $env:SURFER_COMPAT"
|
||||||
pnpm surfer package --verbose
|
npm run package -- --verbose
|
||||||
|
|
||||||
# In the release script, we do the following:
|
# In the release script, we do the following:
|
||||||
# tar -xvf .github/workflows/object/windows-x64-signed-generic.tar.gz -C windows-x64-signed-generic
|
# tar -xvf .github/workflows/object/windows-x64-signed-x86_64.tar.gz -C windows-x64-signed-x86_64
|
||||||
# We need to create a tar with the same structure and no top-level directory
|
# We need to create a tar with the same structure and no top-level directory
|
||||||
# Inside, we need:
|
# Inside, we need:
|
||||||
# - update_manifest/*
|
# - update_manifest/*
|
||||||
# - windows.mar or windows-generic.mar
|
# - windows.mar
|
||||||
# - zen.installer.exe or zen.installer-generic.exe
|
# - zen.installer.exe
|
||||||
# - zen.win-generic.zip or zen.win-specific.zip
|
# - zen.win-x86_64.zip
|
||||||
echo "Creating tar for $name"
|
echo "Creating tar for $name"
|
||||||
rm .\windsign-temp\windows-x64-signed-$name -Recurse -ErrorAction SilentlyContinue
|
rm .\windsign-temp\windows-x64-signed-$name -Recurse -ErrorAction SilentlyContinue
|
||||||
mkdir windsign-temp\windows-x64-signed-$name
|
mkdir windsign-temp\windows-x64-signed-$name
|
||||||
|
|
||||||
# Move the MAR, add the `-generic` suffix if needed
|
# Move the MAR, add the `-arm64` suffix if needed
|
||||||
if ($name -eq "generic") {
|
echo "Moving MAR for $name"
|
||||||
mv .\dist\output.mar windsign-temp\windows-x64-signed-$name\windows-generic.mar
|
if ($name -eq "arm64") {
|
||||||
|
mv .\dist\output.mar windsign-temp\windows-x64-signed-$name\windows-$name.mar
|
||||||
} else {
|
} else {
|
||||||
mv .\dist\output.mar windsign-temp\windows-x64-signed-$name\windows.mar
|
mv .\dist\output.mar windsign-temp\windows-x64-signed-$name\windows.mar
|
||||||
}
|
}
|
||||||
|
|
||||||
# Move the installer
|
# Move the installer
|
||||||
if ($name -eq "generic") {
|
echo "Moving installer for $name"
|
||||||
mv .\dist\zen.installer.exe windsign-temp\windows-x64-signed-$name\zen.installer-generic.exe
|
if ($name -eq "arm64") {
|
||||||
|
mv .\dist\zen.installer.exe windsign-temp\windows-x64-signed-$name\zen.installer-$name.exe
|
||||||
} else {
|
} else {
|
||||||
mv .\dist\zen.installer.exe windsign-temp\windows-x64-signed-$name\zen.installer.exe
|
mv .\dist\zen.installer.exe windsign-temp\windows-x64-signed-$name\zen.installer.exe
|
||||||
}
|
}
|
||||||
|
|
||||||
# Move the zip
|
# Move the zip
|
||||||
|
echo "Moving zip for $name"
|
||||||
|
if ($name -eq "arm64") {
|
||||||
|
mv (Get-Item .\dist\*.en-US.win64-aarch64.zip) windsign-temp\windows-x64-signed-$name\zen.win-arm64.zip
|
||||||
|
} else {
|
||||||
mv (Get-Item .\dist\*.en-US.win64.zip) windsign-temp\windows-x64-signed-$name\zen.win-$name.zip
|
mv (Get-Item .\dist\*.en-US.win64.zip) windsign-temp\windows-x64-signed-$name\zen.win-$name.zip
|
||||||
|
}
|
||||||
|
|
||||||
# Extract the zip, sign everything inside, and repackage it
|
# Extract the zip, sign everything inside, and repackage it
|
||||||
Expand-Archive -Path windsign-temp\windows-x64-signed-$name\zen.win-$name.zip -DestinationPath windsign-temp\windows-x64-signed-$name\zen.win-$name
|
Expand-Archive -Path windsign-temp\windows-x64-signed-$name\zen.win-$name.zip -DestinationPath windsign-temp\windows-x64-signed-$name\zen.win-$name
|
||||||
@@ -85,29 +105,32 @@ function SignAndPackage($name) {
|
|||||||
|
|
||||||
echo "Invoking tar for $name"
|
echo "Invoking tar for $name"
|
||||||
# note: We need to sign it into a parent folder, called windows-x64-signed-$name
|
# note: We need to sign it into a parent folder, called windows-x64-signed-$name
|
||||||
rmdir .\.github\workflows\object\windows-x64-signed-$name -Recurse -ErrorAction SilentlyContinue
|
rmdir .\windsign-temp\windows-binaries\windows-x64-signed-$name -Recurse -ErrorAction SilentlyContinue
|
||||||
mv .\windsign-temp\windows-x64-signed-$name .\.github\workflows\object\windows-x64-signed-$name -Force
|
mv windsign-temp\windows-x64-signed-$name .\windsign-temp\windows-binaries -Force
|
||||||
|
|
||||||
echo "Finished $name"
|
echo "Finished $name"
|
||||||
}
|
}
|
||||||
|
|
||||||
SignAndPackage specific
|
SignAndPackage arm64
|
||||||
SignAndPackage generic
|
SignAndPackage x86_64
|
||||||
|
|
||||||
echo "All artifacts signed and packaged, ready for release!"
|
echo "All artifacts signed and packaged, ready for release!"
|
||||||
echo "Commiting the changes to the repository"
|
echo "Commiting the changes to the repository"
|
||||||
git add .\.github\workflows\object
|
cd windsign-temp\windows-binaries
|
||||||
|
git add .
|
||||||
git commit -m "Sign and package windows artifacts"
|
git commit -m "Sign and package windows artifacts"
|
||||||
git push
|
git push
|
||||||
|
cd ..\..
|
||||||
|
|
||||||
# Cleaning up
|
# Cleaning up
|
||||||
|
|
||||||
echo "All done!"
|
echo "All done!"
|
||||||
echo "All the artifacts (Generic and Specific) are signed and packaged, get a rest now!"
|
echo "All the artifacts (x86_64 and arm46) are signed and packaged, get a rest now!"
|
||||||
Read-Host "Press Enter to continue"
|
Read-Host "Press Enter to continue"
|
||||||
|
|
||||||
echo "Cleaning up"
|
echo "Cleaning up"
|
||||||
rmdir windsign-temp -Recurse -ErrorAction SilentlyContinue
|
rmdir windsign-temp\windows-x64-obj-x86_64 -Recurse -ErrorAction SilentlyContinue
|
||||||
|
rmdir windsign-temp\windows-x64-obj-arm64 -Recurse -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
echo "Opening visual studio code"
|
echo "Opening visual studio code"
|
||||||
code .
|
code .
|
||||||
|
Before Width: | Height: | Size: 7.3 KiB |
Before Width: | Height: | Size: 3.9 KiB |
Before Width: | Height: | Size: 6.8 KiB |
Before Width: | Height: | Size: 3.3 KiB |
Before Width: | Height: | Size: 5.9 KiB |
@@ -1 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 256 256"><defs><style>.g{fill:#000;}.g,.h,.i{stroke-width:0px;}.h{fill:url(#e);}.i{fill:#fff;}</style><linearGradient id="e" x1="128" y1="256" x2="128" y2="0" gradientUnits="userSpaceOnUse"><stop offset=".1" stop-color="#fff" stop-opacity=".02"/><stop offset=".9" stop-color="#fff" stop-opacity=".1"/></linearGradient></defs><g id="c"><rect class="g" y="0" width="256" height="256" rx="58.4" ry="58.4"/></g><g id="d"><rect class="h" y="0" width="256" height="256" rx="58.4" ry="58.4"/></g><g id="f"><path class="i" d="M165.9156,146.3156c-15.6016,0-28.6656,11.0055-31.8813,25.6562h-12.0687c-3.2156-14.6508-16.2797-25.6562-31.8813-25.6562-18.0063,0-32.6562,14.65-32.6562,32.6562s14.65,32.6562,32.6562,32.6562c15.6016,0,28.6656-11.0055,31.8813-25.6562h12.0687c3.2156,14.6508,16.2797,25.6562,31.8813,25.6562,18.0063,0,32.6562-14.65,32.6562-32.6562s-14.65-32.6562-32.6562-32.6562ZM90.0844,197.6281c-10.2875,0-18.6562-8.3687-18.6562-18.6562s8.3687-18.6562,18.6562-18.6562,18.6562,8.3688,18.6562,18.6562-8.3687,18.6562-18.6562,18.6562ZM165.9156,197.6281c-10.2875,0-18.6562-8.3687-18.6562-18.6562s8.3687-18.6562,18.6562-18.6562,18.6562,8.3688,18.6562,18.6562-8.3687,18.6562-18.6562,18.6562Z"/><path class="i" d="M214.4,115.6812h-21.8391l-9.2422-65.2906c-.3031-2.1406-1.5813-4.0219-3.4594-5.0969-1.8781-1.0719-4.1469-1.2188-6.1469-.3906l-45.7125,18.8906-45.7125-18.8906c-2-.8281-4.2688-.6813-6.1469.3906-1.8781,1.075-3.1562,2.9562-3.4594,5.0969l-9.2422,65.2906h-21.8391c-3.8656,0-7,3.1344-7,7s3.1344,7,7,7h172.8c3.8656,0,7-3.1344,7-7s-3.1344-7-7-7ZM85.2781,61.2875l40.0469,16.55c1.7125.7063,3.6375.7063,5.35,0l40.0469-16.55,7.6984,54.3937h-100.8406l7.6984-54.3937Z"/></g></svg>
|
|
Before Width: | Height: | Size: 1.8 KiB |
Before Width: | Height: | Size: 12 KiB |
Before Width: | Height: | Size: 4.9 KiB |
@@ -1 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 80 80"><defs><style>.g{fill:#000;}.g,.h,.i{stroke-width:0px;}.h{fill:url(#e);}.i{fill:#fef9fe;}</style><linearGradient id="e" x1="40" y1="80" x2="40" y2="0" gradientUnits="userSpaceOnUse"><stop offset=".1" stop-color="#fff" stop-opacity=".02"/><stop offset=".9" stop-color="#fff" stop-opacity=".1"/></linearGradient></defs><g id="c"><rect class="g" width="80" height="80" rx="18.25" ry="18.25"/></g><g id="d"><rect class="h" width="80" height="80" rx="18.25" ry="18.25"/></g><g id="f"><path class="i" d="M63.4352,57.677c-.0536,3.2125-2.7416,5.7589-5.9546,5.7589h-22.0762c-1.1221,0-1.8295-1.2103-1.2751-2.1859,1.4628-2.5738,4.3202-6.7829,8.5529-9.1539.4406-.2468.9366-.3783,1.4416-.3783h13.4532c3.2692,0,5.9129,2.6774,5.8582,5.9591Z"/><path class="i" d="M45.8707,18.7498c-1.4628,2.5738-4.3202,6.7829-8.5529,9.1539-.4406.2468-.9366.3783-1.4416.3783h-13.3567c-3.213,0-5.901-2.5464-5.9546-5.7589-.0547-3.2817,2.589-5.9591,5.8582-5.9591h22.1726c1.1221,0,1.8295,1.2103,1.2751,2.1859Z"/><path class="i" d="M22.4207,63.4375c-.7473,0-1.5065-.1438-2.2398-.4475-2.9896-1.2383-4.4093-4.6657-3.171-7.6551,1.9045-4.5977,4.6342-8.7196,8.1136-12.2511,3.6044-3.6585,7.8551-6.5172,12.6343-8.4968,6.5691-2.7211,11.6853-7.8373,14.4061-14.4061,1.2383-2.9896,4.6658-4.409,7.6551-3.171,2.9896,1.2383,4.4093,4.6657,3.171,7.6551-1.9045,4.5977-4.6342,8.7196-8.1136,12.2511-3.6044,3.6585-7.8551,6.5172-12.6343,8.4968-6.5691,2.7211-11.6853,7.8373-14.4061,14.4061-.9345,2.2562-3.1164,3.6185-5.4153,3.6185Z"/></g></svg>
|
|
Before Width: | Height: | Size: 1.6 KiB |
Before Width: | Height: | Size: 9.6 KiB |
Before Width: | Height: | Size: 101 KiB |
Before Width: | Height: | Size: 104 KiB |
Before Width: | Height: | Size: 31 KiB |
Before Width: | Height: | Size: 87 KiB |
Before Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 3.3 KiB |
Before Width: | Height: | Size: 500 B |
Before Width: | Height: | Size: 682 B |
Before Width: | Height: | Size: 748 B |
Before Width: | Height: | Size: 6.5 KiB |
Before Width: | Height: | Size: 946 B |
Before Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 1.6 KiB |
Before Width: | Height: | Size: 103 KiB |
Before Width: | Height: | Size: 219 B After Width: | Height: | Size: 219 B |
BIN
configs/branding/release/PrivateBrowsing_150.png
Normal file
After Width: | Height: | Size: 9.4 KiB |
BIN
configs/branding/release/PrivateBrowsing_70.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
configs/branding/release/VisualElements_150.png
Normal file
After Width: | Height: | Size: 103 KiB |
BIN
configs/branding/release/VisualElements_70.png
Normal file
After Width: | Height: | Size: 103 KiB |
BIN
configs/branding/release/content/about-logo-private.png
Normal file
After Width: | Height: | Size: 6.0 KiB |
1
configs/branding/release/content/about-logo-private.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?><svg id="e" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 256 256"><defs><style>.h{filter:url(#f);}.i{fill:#202020;}.j{fill:#f2f0e3;}</style><filter id="f" x="-.4" y="1.68" width="256.8" height="256.8" filterUnits="userSpaceOnUse"><feOffset dx="0" dy="2"/><feGaussianBlur result="g" stdDeviation="2"/><feFlood flood-color="#000" flood-opacity=".5"/><feComposite in2="g" operator="in"/><feComposite in="SourceGraphic"/></filter></defs><g class="h"><rect class="i" x="5.75" y="5.7717" width="244.5" height="244.5" rx="46" ry="46"/></g><path class="j" d="M165.9933,146.3748c-15.6335,0-28.7244,11.028-31.9466,25.7088h-12.0935c-3.2222-14.6808-16.313-25.7088-31.9466-25.7088-18.0431,0-32.7232,14.68-32.7232,32.7232s14.68,32.7232,32.7232,32.7232c15.6335,0,28.7244-11.028,31.9466-25.7088h12.0935c3.2222,14.6808,16.313,25.7088,31.9466,25.7088,18.0431,0,32.7232-14.68,32.7232-32.7232s-14.68-32.7232-32.7232-32.7232ZM90.0067,197.7925c-10.3086,0-18.6945-8.3859-18.6945-18.6945s8.3859-18.6945,18.6945-18.6945,18.6945,8.3859,18.6945,18.6945-8.3859,18.6945-18.6945,18.6945ZM165.9933,197.7925c-10.3086,0-18.6945-8.3859-18.6945-18.6945s8.3859-18.6945,18.6945-18.6945,18.6945,8.3859,18.6945,18.6945-8.3859,18.6945-18.6945,18.6945Z"/><path class="j" d="M214.577,115.6777h-21.8838l-9.2611-65.4244c-.3037-2.145-1.5845-4.0301-3.4665-5.1073-1.882-1.0741-4.1554-1.2212-6.1595-.3914l-45.8062,18.9293-45.8062-18.9293c-2.0041-.8298-4.2775-.6826-6.1595.3914-1.882,1.0772-3.1627,2.9623-3.4665,5.1073l-9.2611,65.4244h-21.8838c-3.8735,0-7.0143,3.1408-7.0143,7.0143s3.1408,7.0143,7.0143,7.0143h173.1541c3.8735,0,7.0143-3.1408,7.0143-7.0143s-3.1408-7.0143-7.0143-7.0143ZM85.1906,61.1725l40.1289,16.5839c1.716.7077,3.645.7077,5.361,0l40.1289-16.5839,7.7142,54.5052h-101.0473l7.7142-54.5052Z"/></svg>
|
After Width: | Height: | Size: 1.8 KiB |
BIN
configs/branding/release/content/about-logo-private@2x.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
configs/branding/release/content/about-logo.png
Normal file
After Width: | Height: | Size: 16 KiB |
12
configs/branding/release/content/about-logo.svg
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
<svg width="1024" height="1024" viewBox="0 0 1024 1024" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0_109_1042)">
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M512 627.385C575.725 627.385 627.385 575.725 627.385 512C627.385 448.275 575.725 396.615 512 396.615C448.275 396.615 396.615 448.275 396.615 512C396.615 575.725 448.275 627.385 512 627.385ZM604.308 512C604.308 562.98 562.98 604.308 512 604.308C461.02 604.308 419.692 562.98 419.692 512C419.692 461.02 461.02 419.692 512 419.692C562.98 419.692 604.308 461.02 604.308 512Z" fill="#F76F53"/>
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M712 512C712 622.457 622.457 712 512 712C401.543 712 312 622.457 312 512C312 401.543 401.543 312 512 312C622.457 312 712 401.543 712 512ZM512 673.538C601.215 673.538 673.538 601.215 673.538 512C673.538 422.785 601.215 350.462 512 350.462C422.785 350.462 350.462 422.785 350.462 512C350.462 601.215 422.785 673.538 512 673.538Z" fill="#F76F53"/>
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M812 512C812 677.685 677.685 812 512 812C346.315 812 212 677.685 212 512C212 346.315 346.315 212 512 212C677.685 212 812 346.315 812 512ZM512 758.154C647.947 758.154 758.154 647.947 758.154 512C758.154 376.053 647.947 265.846 512 265.846C376.053 265.846 265.846 376.053 265.846 512C265.846 647.947 376.053 758.154 512 758.154Z" fill="#F76F53"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0_109_1042">
|
||||||
|
<rect width="1024" height="1024" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.5 KiB |
BIN
configs/branding/release/content/about-logo@2x.png
Normal file
After Width: | Height: | Size: 33 KiB |
Before Width: | Height: | Size: 6.4 KiB After Width: | Height: | Size: 6.4 KiB |
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |
BIN
configs/branding/release/document.ico
Normal file
After Width: | Height: | Size: 105 KiB |
Before Width: | Height: | Size: 101 KiB After Width: | Height: | Size: 104 KiB |
BIN
configs/branding/release/firefox.ico
Normal file
After Width: | Height: | Size: 48 KiB |
BIN
configs/branding/release/firefox64.ico
Normal file
After Width: | Height: | Size: 76 KiB |
BIN
configs/branding/release/logo-mac.png
Normal file
After Width: | Height: | Size: 88 KiB |
BIN
configs/branding/release/logo.png
Normal file
After Width: | Height: | Size: 46 KiB |
BIN
configs/branding/release/logo1024.png
Normal file
After Width: | Height: | Size: 46 KiB |
BIN
configs/branding/release/logo128.png
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
configs/branding/release/logo16.png
Normal file
After Width: | Height: | Size: 699 B |
BIN
configs/branding/release/logo22.png
Normal file
After Width: | Height: | Size: 824 B |
BIN
configs/branding/release/logo24.png
Normal file
After Width: | Height: | Size: 957 B |
BIN
configs/branding/release/logo256.png
Normal file
After Width: | Height: | Size: 9.8 KiB |
BIN
configs/branding/release/logo32.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
BIN
configs/branding/release/logo48.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
configs/branding/release/logo512.png
Normal file
After Width: | Height: | Size: 21 KiB |
BIN
configs/branding/release/logo64.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
configs/branding/release/pbmode.ico
Normal file
After Width: | Height: | Size: 106 KiB |
BIN
configs/branding/release/wizWatermark.bmp
Normal file
After Width: | Height: | Size: 201 KiB |