-
Notifications
You must be signed in to change notification settings - Fork 108
Expand file tree
/
Copy pathbuild-site.py
More file actions
246 lines (209 loc) · 9.7 KB
/
build-site.py
File metadata and controls
246 lines (209 loc) · 9.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
"""
Build script for Thunderbird websites and related resources.
This script handles building various Thunderbird web properties including:
- Main website (www.thunderbird.net)
- Start page
- Updates site (updates.thunderbird.net)
- Calendar files
- tb.pro site
It also provides utilities for downloading legal documents and watching for changes.
"""
import argparse
import sys
import os.path
import os
from datetime import date
import build_calendar
import builder
import helper
import settings
import markdown
from pymdownx import emoji
from calgen.providers.CalendarificProvider import CalendarificProvider
def setup_argument_parser():
"""Configure and return the argument parser for command line options."""
parser = argparse.ArgumentParser(description='Build Thunderbird websites and resources')
parser.add_argument('--enus', help='Only build the en-US language.', action='store_true')
parser.add_argument('--debug', help='Log output with more detailed build information.', action='store_true')
parser.add_argument('--updates', help='Build the updates directory for updates.thunderbird.net.',
action='store_true')
parser.add_argument('--startpage', help='Build the start page instead of the main thunderbird.net website.',
action='store_true')
parser.add_argument('--buildcalendars', help='Builds the ics calendar files, instead of the websites.',
action='store_true')
parser.add_argument('--downloadlegal', help='Download the Thunderbird privacy policy document.', action='store_true')
parser.add_argument('--tbpro', help='Build the tb.pro site.', action='store_true')
parser.add_argument('--all', help='Build all sites (main website, start page, updates, tb.pro, roadmaps).',
action='store_true')
parser.add_argument('--roadmaps', help='Build the Thunderbird roadmaps site.', action='store_true')
parser.add_argument('--watch', help='Rebuild when template and asset dirs are changed, and run a server on localhost.',
action='store_true')
parser.add_argument('--port', const=8000, default=8000, type=int,
help='Port for the server that runs with --watch.', nargs='?')
return parser
parser = setup_argument_parser()
args = parser.parse_args()
def get_language_settings(enus_only=False):
"""Return language settings based on whether we're building for en-US only or all languages."""
if enus_only:
langmsg = 'in en-US only.'
languages = ['en-US']
calendar_locales = {'US': settings.CALENDAR_LOCALES.get('US')}
else:
langmsg = 'in all languages.'
languages = settings.PROD_LANGUAGES
calendar_locales = settings.CALENDAR_LOCALES
return langmsg, languages, calendar_locales
langmsg, languages, calendar_locales = get_language_settings(args.enus)
def build_startpage():
"""Build the Thunderbird start page."""
print(f'Rendering start page {langmsg}')
site = builder.Site(languages, settings.START_PATH, settings.START_RENDERPATH,
settings.START_CSS, debug=args.debug, dev_mode=args.watch)
site.build_startpage()
return site
def build_updates():
"""Build the updates.thunderbird.net site."""
print(f'Rendering updates {langmsg}')
default_channel = settings.DEFAULT_RELEASE_VERSION
version = helper.thunderbird_desktop.latest_version(default_channel)
beta_version = helper.thunderbird_desktop.latest_version('beta')
context = {
'current_year': date.today().year,
'matomo_site_id': settings.MATOMO_SITE_IDS.get('utn'),
}
site = builder.Site(languages, settings.UPDATES_PATH, settings.UPDATES_RENDERPATH,
settings.UPDATES_CSS, js_bundles=settings.UPDATES_JS,
data=context, debug=args.debug, dev_mode=args.watch,
extra_searchpaths=[settings.COMMON_SEARCHPATH])
site.build_updates()
return site
def build_calendars():
"""Build the calendar files."""
print("Building calendar files")
try:
api_key = os.environ['CALENDARIFIC_API_KEY']
except KeyError:
sys.exit("No `CALENDARIFIC_API_KEY` defined.")
build_calendar.build_calendars(CalendarificProvider({'api_key': api_key}), calendar_locales)
def download_legal():
"""Download legal documents."""
print("Downloading legal documents")
legal = builder.Legal(settings.WEBSITE_PATH)
legal.download()
def build_roadmaps():
"""Build roadmaps.thunderbird.net"""
print("Building roadmaps.thunderbird.net")
context = {}
os.makedirs(settings.ROADMAPS_RENDERPATH, exist_ok=True)
for file in os.listdir(settings.ROADMAPS_SRC):
if (file.endswith("md")):
with open(os.path.join(settings.ROADMAPS_SRC, file), "r") as f:
md_content = f.read()
html_content = markdown.markdown(
md_content,
extensions=["pymdownx.emoji"],
extension_configs={
"pymdownx.emoji": {
"emoji_generator": emoji.to_alt
}
}
)
clean_name = file.replace(".md", "")
# Products go in sub-dirs
if (clean_name == "index"):
template_extends = '{% extends "includes/base/landing-page.html" %}\n'
template_blockname = '{% block content %}\n'
temp_template_path = os.path.join(settings.ROADMAPS_PATH, "index.html")
else:
template_extends = '{% extends "includes/base/product-or-service.html" %}\n'
template_blockname = '{% block roadmap_content %}\n'
os.makedirs(os.path.join(settings.ROADMAPS_PATH, file.replace(".md", "")), exist_ok=True)
temp_template_path = os.path.join(settings.ROADMAPS_PATH, file.replace(".md", ""), "index.html")
# Landing page has a different template from sub-pages.
with open(temp_template_path, "w") as f:
f.write(template_extends)
f.write(template_blockname)
f.write(html_content) # The converted HTML is baked in here
f.write('{{ super() }}\n')
f.write('\n{% endblock %}')
site = builder.Site(languages, settings.ROADMAPS_PATH, settings.ROADMAPS_RENDERPATH,
settings.ROADMAPS_CSS, js_bundles=settings.ROADMAPS_JS,
data=context, debug=args.debug, dev_mode=args.watch,
extra_searchpaths=[settings.COMMON_SEARCHPATH])
site.build_roadmaps()
return site
def build_tbpro():
"""Build the tb.pro site."""
print("Building tb.pro site")
context = {
'current_year': date.today().year,
'default_plan': settings.TBPRO_DEFAULT_PLAN,
}
site = builder.Site(languages, settings.TBPRO_PATH, settings.TBPRO_RENDERPATH,
settings.TBPRO_CSS, js_bundles=settings.TBPRO_JS,
data=context, debug=args.debug, dev_mode=args.watch,
extra_searchpaths=[settings.COMMON_SEARCHPATH])
site.build_tbpro()
return site
def build_main_website():
"""Build the main www.thunderbird.net website."""
print(f'Rendering www.thunderbird.net {langmsg}')
default_channel = settings.DEFAULT_RELEASE_VERSION
version = helper.thunderbird_desktop.latest_version(default_channel)
beta_version = helper.thunderbird_desktop.latest_version('beta')
if os.path.exists('media/caldata/autogen/calendars.json'):
caldata = helper.load_calendar_json('media/caldata/autogen/calendars.json')
else:
caldata = helper.load_calendar_json('media/caldata/calendars.json')
context = {
'current_year': date.today().year,
'platform': 'desktop',
'query': '',
'platforms': helper.thunderbird_desktop.platforms('release'),
'full_builds_version': version.split('.', 1)[0],
'full_builds': helper.thunderbird_desktop.get_filtered_full_builds('release', version),
'full_builds_beta': helper.thunderbird_desktop.get_filtered_full_builds('beta', beta_version),
'channel_label': 'Thunderbird',
'releases': helper.thunderbird_desktop.list_releases(),
'calendars': caldata['calendars'],
'letters': caldata['letters'],
'CALDATA_URL': settings.CALDATA_URL,
'latest_thunderbird_version': version,
'latest_thunderbird_beta_version': beta_version,
'blog_data': [],
'default_channel': default_channel
}
site = builder.Site(languages, settings.WEBSITE_PATH, settings.WEBSITE_RENDERPATH,
settings.WEBSITE_CSS, js_bundles=settings.WEBSITE_JS,
data=context, debug=args.debug, dev_mode=args.watch,
extra_searchpaths=[settings.COMMON_SEARCHPATH])
site.build_website()
return site
site = None
if args.all:
conflicting = [args.startpage, args.updates, args.tbpro, args.roadmaps,
args.buildcalendars, args.downloadlegal, args.watch]
if any(conflicting):
parser.error('--all cannot be combined with individual site flags or --watch')
build_main_website()
build_startpage()
build_updates()
build_tbpro()
build_roadmaps()
elif args.startpage:
site = build_startpage()
elif args.updates:
site = build_updates()
elif args.tbpro:
site = build_tbpro()
elif args.roadmaps:
site = build_roadmaps()
elif args.buildcalendars:
build_calendars()
elif args.downloadlegal:
download_legal()
else:
site = build_main_website()
if args.watch and site:
builder.setup_observer(site, args.port)