blob: f8fa130ce3380b7d1cda1c2c48327e8c71657062 [file] [log] [blame]
Copybara854996b2021-09-07 19:36:02 +00001# Copyright 2016 The Chromium Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style
3# license that can be found in the LICENSE file or at
4# https://developers.google.com/open-source/licenses/bsd
5
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +02006"""Defines settings for the avm99963 bugs monorail instance."""
Copybara854996b2021-09-07 19:36:02 +00007from __future__ import print_function
8from __future__ import division
9from __future__ import absolute_import
10
11import os
12import re
13
14from google.appengine.api import app_identity
15
16from framework import framework_constants
17from proto import project_pb2
18from proto import site_pb2
19
20
21# This file is divided into the following parts:
22# 1. Settings you must edit before deploying your site.
23# 2. Settings you would edit on certain occasions while maintaining your site.
24# 3. Settings enable specific features.
25# 4. Settings that you can usually leave as-is.
26
27# TODO(jrobbins): Store these settings in the database and implement
28# servlets for domain admins to edit them without needing to redeploy the
29# app.
30
31
32####
33# Part 1: settings that you must edit before deploying your site.
34
35# Email address that is offered to users who might need help using the tool.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020036feedback_email = 'me+monorail.feedback@avm99963.com'
Copybara854996b2021-09-07 19:36:02 +000037
38# For debugging when running in staging: send all outbound
39# email to this address rather than to the actual address that
40# it would normally be sent to.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020041send_all_email_to = 'monorail-staging-emails+all+%(user)s+%(domain)s@dontsend.avm99963.com'
Copybara854996b2021-09-07 19:36:02 +000042
43# For debugging when running the server locally: send all outbound
44# email to this address rather than to the actual address that
45# it would normally be sent to.
46send_local_email_to = (
47 send_all_email_to or
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020048 'monorail-staging-emails+dev+%(user)s+%(domain)s@dontsend.avm99963.com')
Copybara854996b2021-09-07 19:36:02 +000049
50# User to send emails from Monorail as. The reply_to sections of emails will be
51# set to appspotmail addresses.
52# Note: If configuring a new monorail instance without DNS records and reserved
53# email addresses then setting these values to
54# 'reply@${app_id}.appspotmail.com' and 'noreply@{app_id}.appspotmail.com'
55# is likely the best option.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020056
57# Old values (TODO: set up DNS records and uncomment this):
58#send_email_as_format = 'monorail@%(domain)s'
59#send_noreply_email_as_format = 'monorail+noreply@%(domain)s'
60
61send_email_as_format = 'reply@avm99963-bugs.appspotmail.com'
62send_noreply_email_as_format = 'noreply@avm99963-bugs.appspotmail.com'
Copybara854996b2021-09-07 19:36:02 +000063
64# The default is to look for a database named "monorail" in replicas
65# named "replica-00" .. "replica-09"
66# Replica names for -prod, -staging, and -dev may diverge if replicas ever fail.
67# In such cases the db_replica_names list can be overwritten in Part 5.
68db_database_name = 'monorail'
69db_primary_name = 'primary'
70db_replica_prefix = 'replica'
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020071db_region = 'europe-west1'
Copybara854996b2021-09-07 19:36:02 +000072
73# The default connection pool size for mysql connections.
74db_cnxn_pool_size = 20
75
76# The number of logical database shards used. Each replica is complete copy
77# of the primary, so any replica DB can answer queries about any logical shard.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020078num_logical_shards = 1
Copybara854996b2021-09-07 19:36:02 +000079
80# "Learn more" link for the site home page
81learn_more_link = None
82
83# Site name, displayed above the search box on the site home page.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +020084site_name = 'avm99963 bugs'
Copybara854996b2021-09-07 19:36:02 +000085
86# Who is allowed to create new projects? Set to ANYONE or ADMIN_ONLY.
87project_creation_restriction = site_pb2.UserTypeRestriction.ADMIN_ONLY
88
89# Default access level when creating a new project.
90default_access_level = project_pb2.ProjectAccess.ANYONE
91
92# Possible access levels to offer when creating a new project.
93allowed_access_levels = [
94 project_pb2.ProjectAccess.ANYONE,
95 project_pb2.ProjectAccess.MEMBERS_ONLY]
96
97# Who is allowed to create user groups? Set to ANYONE or ADMIN_ONLY.
98group_creation_restriction = site_pb2.UserTypeRestriction.ADMIN_ONLY
99
100# Who is allowed to create hotlists? Set to ANYONE or ADMIN_ONLY.
101hotlist_creation_restriction = site_pb2.UserTypeRestriction.ANYONE
102
103# Text that mentions these words as shorthand host names will be autolinked
104# regardless of the lack of "https://" or ".com".
105autolink_shorthand_hosts = [
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200106 'go',
Copybara854996b2021-09-07 19:36:02 +0000107 ]
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200108autolink_numeric_shorthand_hosts = []
Copybara854996b2021-09-07 19:36:02 +0000109
110
111# We only allow self-service account linking invites when the child account is
112# linking to a parent account in an allowed domain.
113linkable_domains = {
114 # Child account domain: [parent account domains]
Copybara854996b2021-09-07 19:36:02 +0000115}
116
117
118####
119# Part 2: Settings you would edit on certain occasions.
120
121# Read-only mode prevents changes while we make server-side changes.
122read_only = False
123
124# Timestamp used to notify users when the read only mode or other status
125# described in the banner message takes effect. It is
126# expressed as a tuple of ints: (year, month, day[, hour[, minute[, second]]])
127# e.g. (2009, 3, 20, 21, 45) represents March 20 2009 9:45PM UTC.
128banner_time = None
129
130# Display a site maintenance banner on every monorail page.
131banner_message = ''
132
133# User accounts with email addresses at these domains are all banned.
134banned_user_domains = []
135
136# We use this for specifying cloud task parent
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200137CLOUD_TASKS_REGION = 'europe-west1'
Copybara854996b2021-09-07 19:36:02 +0000138
139# We only send subscription notifications to users who have visited the
140# site in the last 6 months.
141subscription_timeout_secs = 180 * framework_constants.SECS_PER_DAY
142
143# Location of GCS spam classification staging trainer. Whenever the training
144# code is changed, this should be updated to point to the new package.
145trainer_staging = ('gs://monorail-staging-mlengine/spam_trainer_1517870972/'
146 'packages/befc9b29d9beb7e89d509bd1e9866183c138e3a32317cc'
147 'e253342ac9f8e7c375/trainer-0.1.tar.gz')
148
149# Location of GCS spam classification prod trainer. Whenever the training
150# code is changed, this should be updated to point to the new package.
151trainer_prod = ('gs://monorail-prod-mlengine/spam_trainer_1521755738/packages/'
152 '3339dfcb5d7b6c9d714fb9b332fd72d05823e9a1850ceaf16533a6124bcad'
153 '6fd/trainer-0.1.tar.gz')
154####
155# Part 3: Settings that enable specific features
156
157# Enables "My projects" drop down menu
158enable_my_projects_menu = True
159
160# Enables stars in the UI for projects
161enable_project_stars = True
162
163# Enables stars in the UI for users
164enable_user_stars = True
165
166# Enable quick edit mode in issue peek dialog and show dialog on hover
167enable_quick_edit = True
168
169
170####
171# Part 4: Settings that you can usually leave as-is.
172
173# local_mode makes the server slower and more dynamic for easier debugging.
174# E.g., template files are reloaded on each request.
175local_mode = os.environ['SERVER_SOFTWARE'].startswith('Development')
176unit_test_mode = os.environ['SERVER_SOFTWARE'].startswith('test')
177
178# If we assume 1KB each, then this would be 400 MB for this cache in frontends
179# that have only 1024 MB total.
180issue_cache_max_size = 400 * 1000
181
182# If we assume 1KB each, then this would be 400 MB for this cache in frontends
183# that have only 1024 MB total.
184comment_cache_max_size = 400 * 1000
185
186# 150K users should be enough for all the frequent daily users plus the
187# occasional users that are mentioned on any popular pages.
188user_cache_max_size = 150 * 1000
189
190# Normally we use the default namespace, but during development it is
191# sometimes useful to run a tainted version on staging that has a separate
192# memcache namespace. E.g., os.environ.get('CURRENT_VERSION_ID')
193memcache_namespace = None # Should be None when committed.
194redis_namespace = None
195
196# Default Redis host and port
197redis_host = 'localhost'
198redis_port = '6379'
199
200# Recompute derived issue fields via work items rather than while
201# the user is waiting for a page to load.
202recompute_derived_fields_in_worker = True
203
204# The issue search SQL queries have a LIMIT clause with this amount.
205search_limit_per_shard = 10 * 1000 # This is more than all open in chromium.
206
207# The GAE search feature is slow, so don't request too many results.
208# This limit is approximately the most results that we can get from
209# the fulltext engine in 1s. If we reach this limit in any shard,
210# the user will see a message explaining that results were capped.
211fulltext_limit_per_shard = 1 * 2000
212
213# Retrieve at most this many issues from the DB when showing an issue grid.
214max_issues_in_grid = 6000
215# This is the most tiles that we show in grid view. If the number of results
216# is larger than this, we display IDs instead.
217max_tiles_in_grid = 1000
218
219# Maximum number of project results to display on a single pagination page
220max_project_search_results_per_page = 100
221
222# Maximum number of results per pagination page, regardless of what
223# the user specified in their request. This exists to prevent someone
224# from doing a DoS attack that makes our servers do a huge amount of work.
225max_artifact_search_results_per_page = 1000
226
227# Maximum number of comments to display on a single pagination page
228max_comments_per_page = 500
229
230# Max number of issue starrers to notify via email. Issues with more
231# that this many starrers will only notify the last N of them after a
232# comment from a project member.
233max_starrers_to_notify = 4000
234
235# In projects that have more than this many issues the next and prev
236# links on the issue detail page will not be shown when the user comes
237# directly to an issue without specifying any query terms.
238threshold_to_suppress_prev_next = 10000
239
240# Format string for the name of the FTS index shards for issues.
241search_index_name_format = 'issues%02d'
242
243# Name of the FTS index for projects (not sharded).
244project_search_index_name = 'projects'
245
246# Each backend has this many seconds to respond, otherwise frontend gives up
247# on that shard.
248backend_deadline = 45
249
250# If the initial call to a backend fails, try again this many times.
251# Initial backend calls are failfast, meaning that they fail immediately rather
252# than queue behind other requests. The last 2 retries will wait in queue.
253backend_retries = 3
254
255# Do various extra logging at INFO level.
256enable_profiler_logging = True
257
258# Mail sending domain. Normally set this to None and it will be computed
259# automatically from your AppEngine APP_ID. But, it can be overridden below.
260mail_domain = None
261
262# URL format to browse source code revisions. This can be overridden
263# in specific projects by setting project.revision_url_format.
264# The format string may include "{revnum}" for the revision number.
265revision_url_format = 'https://crrev.com/{revnum}'
266
267# Users with emails in the "priviledged" domains do NOT get any advantage
268# but they do default their preference to show unobscured email addresses.
269priviledged_user_domains = [
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200270 'avm99963.com',
Copybara854996b2021-09-07 19:36:02 +0000271 ]
272
273# Branded domains: Any UI GET to a project listed below on prod or staging
274# should have the specified host, otherwise it will be redirected such that
275# the specified host is used.
276branded_domains = {} # defaults to empty for localhost
Copybara854996b2021-09-07 19:36:02 +0000277branded_domains_prod = {
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200278 '*': 'bugs.avm99963.com',
Copybara854996b2021-09-07 19:36:02 +0000279}
280
281# The site home page will immediately redirect to a default project for these
282# domains, if the project can be viewed. Structure is {hostport: project_name}.
283domain_to_default_project = {} # defaults to empty for localhost
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200284domain_to_default_project_prod = {}
Copybara854996b2021-09-07 19:36:02 +0000285
286
287# Names of projects on code.google.com which we allow cross-linking to.
288recognized_codesite_projects = [
Copybara854996b2021-09-07 19:36:02 +0000289]
290
291####
292# Part 5: Instance-specific settings that override lines above.
293# This ID is for -staging and other misc deployments. Prod is defined below.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200294analytics_id = ''
Copybara854996b2021-09-07 19:36:02 +0000295
296if unit_test_mode:
297 db_cloud_project = '' # No real database is used during unit testing.
298 app_id = ''
299else:
300 app_id = app_identity.get_application_id()
301
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200302 if app_id == 'avm99963-bugs':
303 send_all_email_to = None # Deliver it to the intended users.
Copybara854996b2021-09-07 19:36:02 +0000304 # The Google Cloud SQL databases to use.
305 db_cloud_project = app_id
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200306 analytics_id = ''
307 branded_domains = branded_domains_prod
308 domain_to_default_project = domain_to_default_project_prod
Copybara854996b2021-09-07 19:36:02 +0000309 # For each of these redis_hosts, they must match the corresponding
310 # HOST address of the redis instance for the environment. You can use
311 # the following command to find it.
312 # ```
313 # gcloud redis instances list --project monorail-staging \
314 # --region us-central1
315 # ````
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200316 # Leaving empty for now
317 redis_host = ''
Adrià Vilanova Martínezcab9d512021-07-10 01:50:12 +0200318 elif app_id == 'monorail-staging':
319 site_name = 'Monorail Staging'
320 banner_message = 'This staging site does not send emails.'
321 # The Google Cloud SQL databases to use.
322 db_cloud_project = app_id
323 branded_domains = branded_domains
324 domain_to_default_project = domain_to_default_project
325 # For each of these redis_hosts, they must match the corresponding
326 # HOST address of the redis instance for the environment. You can use
327 # the following command to find it.
328 # ```
329 # gcloud redis instances list --project monorail-staging \
330 # --region us-central1
331 # ````
332 redis_host = '10.228.109.51'
333
334 elif app_id == 'monorail-dev':
335 site_name = 'Monorail Dev'
336 banner_message = 'This dev site does not send emails.'
337 # The Google Cloud SQL databases to use.
338 db_cloud_project = app_id
339 branded_domains = branded_domains
340 domain_to_default_project = domain_to_default_project
341 # See comment above on how to find this address.
342 redis_host = '10.150.170.251'
343 # Use replicas created when testing the restore procedures on 2021-02-24
344 db_replica_prefix = 'replica-2'
Copybara854996b2021-09-07 19:36:02 +0000345
346if local_mode:
347 site_name = 'Monorail Local'
348 num_logical_shards = 10
349 redis_host = 'localhost'
350 # Run cloud tasks emulator at port 9090
351 CLOUD_TASKS_EMULATOR_ADDRESS = '127.0.0.1:9090'
Adrià Vilanova Martínezcab9d512021-07-10 01:50:12 +0200352 CLOUD_TASKS_REGION = 'us-central1'
Copybara854996b2021-09-07 19:36:02 +0000353
354# Combine the customized info above to make the name of the primary DB instance.
355db_instance = db_cloud_project + ':' + db_region + ':' + db_primary_name
356
357# Combine the customized info above to make the names of the replica DB
358# instances.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200359db_replica_names = [db_primary_name for i in range(num_logical_shards)]
Copybara854996b2021-09-07 19:36:02 +0000360
361# Format string for the name of the physical database replicas.
362physical_db_name_format = (db_cloud_project + ':' + db_region + ':%s')
363
364# preferred domains to display
365preferred_domains = {
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200366 'avm99963-bugs.appspot.com': 'bugs.avm99963.com'}
Copybara854996b2021-09-07 19:36:02 +0000367
368# Borg robot service account
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200369borg_service_account = 'chrome-infra-prod-borg-NOTUSEDBYAVM99963BUGS@system.gserviceaccount.com'
Copybara854996b2021-09-07 19:36:02 +0000370
371# Prediction API params.
372classifier_project_id = 'project-id-testing-only'
373
374# Necessary for tests.
375if 'APPLICATION_ID' not in os.environ:
376 os.environ['APPLICATION_ID'] = 'testing-app'
377
378if local_mode:
379 # There is no local stub for ML Engine.
380 classifier_project_id = 'monorail-staging'
381else:
382 classifier_project_id = app_identity.get_application_id()
383
384classifier_model_id = '20170302'
385
386# Number of distinct users who have to flag an issue before it
387# is automatically removed as spam.
388# Currently effectively disabled.
389spam_flag_thresh = 1000
390
391# If the classifier's confidence is less than this value, the
392# item will show up in the spam moderation queue for manual
393# review.
394classifier_moderation_thresh = 1.0
395
396# If the classifier's confidence is greater than this value,
397# and the label is 'spam', the item will automatically be created
398# with is_spam=True, and will be filtered out from search results.
399classifier_spam_thresh = 0.995
400
401# Users with email addresses ending with these will not be subject to
402# spam filtering.
403spam_allowlisted_suffixes = (
404 '@chromium.org',
405 '.gserviceaccount.com',
406 '@google.com',
407 '@webrtc.org',
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200408 '@avm99963.com',
Copybara854996b2021-09-07 19:36:02 +0000409)
410
411# New issues filed by these users in these groups
412# automatically get the Restrict-View-Google label.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200413restrict_new_issues_user_groups = []
Copybara854996b2021-09-07 19:36:02 +0000414
415# Users in these groups see a "corp mode" warning dialog when commenting
416# on public issues, informing them that their comments are public by default.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200417public_issue_notice_user_groups = []
Copybara854996b2021-09-07 19:36:02 +0000418
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200419full_emails_perm_groups = []
Copybara854996b2021-09-07 19:36:02 +0000420
421# These email suffixes are allowed to create new alert bugs via email.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200422alert_allowlisted_suffixes = ('@avm99963.com',)
Copybara854996b2021-09-07 19:36:02 +0000423
424# The person who is notified if there is an unexpected problem in the alert
425# pipeline.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200426alert_escalation_email = 'me@avm99963.com'
Copybara854996b2021-09-07 19:36:02 +0000427
428# Bugs autogenerated from alert emails are created through this account.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200429alert_service_account = 'autogenerated-bug-from-alert-mails-monorail@noreply.avm99963.com'
Copybara854996b2021-09-07 19:36:02 +0000430
431# The number of hash buckets to use when vectorizing text from Issues and
432# Comments. This should be the same value that the model was trained with.
433spam_feature_hashes = 500
434
435# The number of features to use when vectorizing text from Issues and
436# Comments. This should be the same value that the model was trained with.
437component_features = 5000
438
439# The name of the spam model in ML Engine.
440spam_model_name = 'spam_only_words'
441
442# The name of the component model in ML Engine
443component_model_name = 'component_top_words'
444
445# The name of the gcs bucket containing component predicition trainer code.
446component_ml_bucket = classifier_project_id + '-mlengine'
447
448ratelimiting_enabled = True
449
450# Requests that hit ratelimiting_cost_thresh_sec get one extra count
451# added to their bucket at the end of the request for each additional
452# multiple of this latency.
453ratelimiting_ms_per_count = 1000
454
455api_ratelimiting_enabled = True
456
457# When we post an auto-ping comment, it is posted by this user @ the preferred
458# domain name. E.g., 'monorail@bugs.chromium.org'.
459date_action_ping_author = 'monorail'
460
461# Hard-coding this so that we don't rely on sys.maxint, which could
462# potentially differ. It is equal to the maximum unsigned 32 bit integer,
463# because the `int(10) unsigned` column type in MySQL is 32 bits.
464maximum_snapshot_period_end = 4294967295
465
466# The maximum number of rows chart queries can scan.
467chart_query_max_rows = 10000
468
469# Client ID to use for loading the Google API client, gapi.js.
Adrià Vilanova Martínez515639b2021-07-06 16:43:59 +0200470# (This is not used by avm99963 bugs, this is only useful for buganizer bugs)
471gapi_client_id = ''
Copybara854996b2021-09-07 19:36:02 +0000472
473# The pub/sub topic on which to publish issue update messages.
474if local_mode:
475 # In local dev, send issue updates to the monorail-dev project.
476 # There also exists a pubsub emulator we could potentially use in the future:
477 # https://cloud.google.com/pubsub/docs/emulator
478 pubsub_project = 'monorail-dev'
479else:
480 pubsub_project = app_identity.get_application_id()
481
482pubsub_topic_id = 'projects/%s/topics/issue-updates' % pubsub_project
483
484# All users in the following domains will have API access.
485# Important: the @ symbol must be included.
Adrià Vilanova Martínez96deb382021-08-08 00:13:47 +0200486api_allowed_email_domains = ('@avm99963.com', '@avm99963-bugs.iam.gserviceaccount.com')