forked from Noctem/Monocle
-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathconfig.example.py
783 lines (656 loc) · 32.1 KB
/
config.example.py
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
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
### Define a unique instance id. It needs to be different for each instance running.
### If not set explicitly, monocle root dir will be used as default.
#
#INSTANCE_ID = '/var/www/Monocle'
### All lines that are commented out (and some that aren't) are optional ###
DB_ENGINE = 'sqlite:///db.sqlite'
#DB_ENGINE = 'mysql://user:pass@localhost/monocle?charset=utf8mb4' ## don't forget ?charset=utf8mb4 after your DB name !
#DB_ENGINE = 'postgresql://user:pass@localhost/monocle'
### DB queue/pool size settings
### These are to be used if you see errors relating to pool_size from sqlalchemy
### DO not set extremely high
#
# DB_POOL_SIZE = 5 # sqlalchemy defualt
# DB_MAX_OVERFLOW = 10 # sqlalchemy default
## Reconnect db session after x seconds. It solves lost connection error if DB wait_timeout is set to lower values.
# DB_POOL_RECYCLE = 600
AREA_NAME = 'SLC' # the city or region you are scanning
LANGUAGE = 'EN' # ISO 639-1 codes EN, DE, ES, FR, IT, JA, KO, PT, or ZH for Pokémon/move names
MAX_CAPTCHAS = 100 # stop launching new visits if this many CAPTCHAs are pending
SCAN_DELAY = 10 # wait at least this many seconds before scanning with the same account
SPEED_UNIT = 'miles' # valid options are 'miles', 'kilometers', 'meters'
SPEED_LIMIT = 19.5 # limit worker speed to this many SPEED_UNITs per hour
##If true, will query OSM to determine if gym is in a park
#PARK_CHECK = True
# The number of simultaneous workers will be these two numbers multiplied.
# On the initial run, workers will arrange themselves in a grid across the
# rectangle you defined with MAP_START and MAP_END.
# The rows/columns will also be used for the dot grid in the console output.
# Provide more accounts than the product of your grid to allow swapping.
GRID = (4, 4) # rows, columns
### Extra accounts to pull from DB in percentage of total workers for swap.
### Default 0.0 (0%)
#EXTRA_ACCOUNT_PERCENT = 0.0
#
### For example, if you want to have extra 10% accounts for periodic swapping, set
#EXTRA_ACCOUNT_PERCENT = 0.1
### Lv30 accounts to pull from DB in percentage of total workers for encounter.
### Setting this will enable Lv30 pool for encounters
### Default 0.0(0%)
#LV30_PERCENT_OF_WORKERS = 0.0
#
### For example, if you want to have 5% level 30 acccounts for encounter, set
#LV30_PERCENT_OF_WORKERS = 0.05
#
### Delay in seconds before starting next encounter.
### This allows adjustment of overall encounter rate (to make it slower).
#LV30_ENCOUNTER_WAIT=0.0
### Gym Raider accounts to pull from DB in percentage of total gyms inside the borders for gym scanning.
### Default 0.0(0%) Monkey Raiders turned off by default
#RAIDERS_PER_GYM = 0
#
### For example, if you want to have 0.03 raiders per gym, set 0.03.
### As a basic guideline, 0.03 would result in around 5 mins refresh time for all gyms.
### The following describes requirement of 3 workers per 100 gyms with guarantee of maximum 5 mins refresh time.
#RAIDERS_PER_GYM = 0.03
### Do GMO requests for lv30 accounts.
### Setting False will increase encounter rate and reduce hashing usage as it will apply insta-teleport encounter.
### Setting True will reduce account ban risks as it will apply normal Monocle behavior.
### Default False.
#LV30_GMO = False
### Maximum speed for lv30 accounts in SPEED_UNIT/hr.
### Defaults to 0.0 (disabled).
### When disabled, worker will not take any traveling time to encounter. (insta-teleport activated!)
#LV30_MAX_SPEED = 745.6454
### If encounter jobs queue up more than this amount, new sightings will be saved without encounter.
### Defaults to 0, which means no max limit.
#LV30_MAX_QUEUE = 0
#
###It is recommended to set it to this formula if you decided to cap the max queue size.
LV30_MAX_QUEUE = int(LV30_PERCENT_OF_WORKERS * GRID[0] * GRID[1] * 10.0)
# the corner points of a rectangle for your workers to spread out over before
# any spawn points have been discovered
MAP_START = (40.7913, -111.9398)
MAP_END = (40.7143, -111.8046)
# ensure that you visit within this many meters of every part of your map during bootstrap
# lower values are more thorough but will take longer
BOOTSTRAP_RADIUS = 70
GIVE_UP_KNOWN = 300 # try to find a worker for a known spawn for this many seconds before giving up
GIVE_UP_UNKNOWN = 1500 # try to find a worker for an unknown point for this many seconds before giving up
SKIP_SPAWN = 1500 # don't even try to find a worker for a spawn if the spawn time was more than this many seconds ago
# How often should the mystery queue be reloaded (default 90s)
# this will reduce the grouping of workers around the last few mysteries
#RESCAN_UNKNOWN = 90
# filename of accounts CSV
# If a CSV file is specified, this file will be processed on each start.
# If not set, you will have to import manually your accounts with scripts/import_accounts.py script.
# ACCOUNTS_CSV = None
### Swap out accounts on warning popup
#ACCOUNTS_SWAP_OUT_ON_WARN = True
#
### Set period (days) for account hibernations for each swap out category.
### Only those categories defined here will be swapped in. The rest will not attempt to swapin.
### For hibernation to work, set up cron for cleanup.py. See wiki for details.
### Default is the following.
#ACCOUNTS_HIBERNATE_CONFIG = {
# 'banned': 45.0, # Perma banned, we'd never know
# 'warn': 45.0, # Warned, mostly equal to code3
# 'sbanned': 45.0, # Shadow banned, will turn to warn/code3 in 3-5 days
# 'code3': 45.0, # Temp banned, might be good again in 2-4 weeks
# 'tempdisabled': 0.02083333333, # 30 mins. Something was messed up and login has been temp disabled for 15 mins.
#}
# the directory that the pickles folder, socket, CSV, etc. will go in
# defaults to working directory if not set
#DIRECTORY = None
# Allows you to specify how many log files to keep before recycling
# Monocle defaults to scan.log plus 4 for a total of 5
#LOGGED_FILES = 4
# Allows you to specify size for log files to keep
# Monocle defaults to scan.log
#LOGGED_SIZE = 500000
# Limit the number of simultaneous logins to this many at a time.
# Lower numbers will increase the amount of time it takes for all workers to
# get started but are recommended to avoid suddenly flooding the servers with
# accounts and arousing suspicion.
SIMULTANEOUS_LOGINS = 4
# Limit the number of workers simulating the app startup process simultaneously.
SIMULTANEOUS_SIMULATION = 10
# Immediately select workers whose speed are below (SPEED_UNIT)p/h instead of
# continuing to try to find the worker with the lowest speed.
# May increase clustering if you have a high density of workers.
GOOD_ENOUGH = 0.1
# Seconds to sleep after failing to find an eligible worker before trying again.
SEARCH_SLEEP = 2.5
## alternatively define a Polygon to use as boundaries (requires shapely)
## more information available in the shapely manual:
## http://toblerity.org/shapely/manual.html#polygons
#from shapely.geometry import Polygon
#BOUNDARIES = Polygon(((40.799609, -111.948556), (40.792749, -111.887341), (40.779264, -111.838078), (40.761410, -111.817908), (40.728636, -111.805293), (40.688833, -111.785564), (40.689768, -111.919389), (40.750461, -111.949938)))
# key for Bossland's hashing server, needed if you're not using Go Hash.
#HASH_KEY = '9d87af14461b93cb3605' # this key is fake
### Optional conguration for hash server.
### Do not mess with the following hash configs if you don't know what you are doing.
#
### Buddyauth endpoint
#HASH_ENDPOINT="http://pokehash.buddyauth.com"
#
### Gohash config
#
#Set it to True to use GOHASH
#GO_HASH = False
#
#GO_HASH_KEY = 'YOURGOHASHKEY' # edit with your Gohash key
#
### Gohash endpoint
#GOHASH_ENDPOINT="http://hash.gomanager.biz"
# Skip PokéStop spinning and egg incubation if your request rate is too high
# for your hashing subscription.
# e.g.
# 75/150 hashes available 35/60 seconds passed => fine
# 70/150 hashes available 30/60 seconds passed => throttle (only scan)
# value: how many requests to keep as spare (0.1 = 10%), False to disable
#SMART_THROTTLE = False
# Swap the worker that has seen the fewest Pokémon every x seconds
# Defaults to whatever will allow every worker to be swapped within 6 hours
#SWAP_OLDEST = 300 # 5 minutes
# Only swap if it's been active for more than x minutes
#MINIMUM_RUNTIME = 10
### these next 6 options use more requests but look more like the real client
APP_SIMULATION = True # mimic the actual app's login requests
COMPLETE_TUTORIAL = True # complete the tutorial process and configure avatar for all accounts that haven't yet
INCUBATE_EGGS = True # incubate eggs if available
## encounter Pokémon to store IVs.
## valid options:
# 'all' will encounter every Pokémon that hasn't been already been encountered
# 'some' will encounter Pokémon if they are in ENCOUNTER_IDS or eligible for notification
# None will never encounter Pokémon
ENCOUNTER = None
#ENCOUNTER_IDS = (3, 6, 9, 45, 62, 71, 80, 85, 87, 89, 91, 94, 114, 130, 131, 134)
# PokéStops
SPIN_POKESTOPS = True # spin all PokéStops that are within range
SPIN_COOLDOWN = 300 # spin only one PokéStop every n seconds (default 300)
## Gyms
### Toggles scanning for gym names.
#GYM_NAMES = True
### Toggles scanning gyms for gym_defenders.
### Set this to False if you want to call GYM_GET_INFO RPC only for gym names.
#GYM_DEFENDERS = True
# minimum number of each item to keep if the bag is cleaned
# bag cleaning is disabled if this is not present or is commented out
''' # triple quotes are comments, remove them to use this ITEM_LIMITS example
ITEM_LIMITS = {
1: 0, # Poké Ball
2: 0, # Great Ball
3: 5, # Ultra Ball
4: 10, # Master Ball
101: 0, # Potion
102: 0, # Super Potion
103: 0, # Hyper Potion
104: 5, # Max Potion
201: 0, # Revive
202: 5, # Max Revive
301: 5, # Lucky Egg
401: 5, # Incense
501: 5, # Lure Module
701: 5, # Razz Berry
702: 5, # Bluk Berry
703: 5, # Nanab Berry
704: 5, # Wepar Berry
705: 5, # Pinap Berry
902: 5, # Incubator
}
'''
# Update the console output every x seconds
REFRESH_RATE = 0.75 # 750ms
# Update the seen/speed/visit/speed stats every x seconds
STAT_REFRESH = 5
# sent with GET_PLAYER requests, should match your region
PLAYER_LOCALE = {'country': 'US', 'language': 'en', 'timezone': 'America/Denver'}
# retry a request after failure this many times before giving up
MAX_RETRIES = 3
# number of seconds before timing out on a login request
LOGIN_TIMEOUT = 2.5
# add spawn points reported in cell_ids to the unknown spawns list
#MORE_POINTS = False
# Set to True to kill the scanner when a newer version is forced
#FORCED_KILL = False
### Exclude these Pokémon from the map by default (only visible in trash layer)
### DB insert is not affected. The will still be inserted to DB as normal. See NO_DB_INSERT_IDS config below.
TRASH_IDS = (
16, 19, 21, 29, 32, 41, 46, 48, 50, 52, 56, 74, 77, 96, 111, 133,
161, 163, 167, 177, 183, 191, 194
)
### Prevent these pokemon from being inserted to the database and thus visible on the map; at all
### Default is None (Everything is inserted)
#NO_DB_INSERT_IDS = None
### To set it the same as TRASH_IDS do the following.
#NO_DB_INSERT_IDS = TRASH_IDS
# include these Pokémon on the "rare" report
RARE_IDS = (3, 6, 9, 45, 62, 71, 80, 85, 87, 89, 91, 94, 114, 130, 131, 134)
from datetime import datetime
REPORT_SINCE = datetime(2017, 2, 17) # base reports on data from after this date
# used for altitude queries and maps in reports
#GOOGLE_MAPS_KEY = 'OYOgW1wryrp2RKJ81u7BLvHfYUA6aArIyuQCXu4' # this key is fake
REPORT_MAPS = True # Show maps on reports
#ALT_RANGE = (1250, 1450) # Fall back to altitudes in this range if Google query fails
## Round altitude coordinates to this many decimal places
## More precision will lead to larger caches and more Google API calls
## Maximum distance from coords to rounded coords for precisions (at Lat40):
## 1: 7KM, 2: 700M, 3: 70M, 4: 7M
#ALT_PRECISION = 2
## Automatically resolve captchas using 2Captcha key.
#CAPTCHA_KEY = '1abc234de56fab7c89012d34e56fa7b8'
## the number of CAPTCHAs an account is allowed to receive before being swapped out
#CAPTCHAS_ALLOWED = 3
## Get new accounts from the CAPTCHA queue first if it's not empty
#FAVOR_CAPTCHA = True
## Use anticaptcha instead of 2captcha
#USE_ANTICAPTCHA = True
# allow displaying the live location of workers on the map
MAP_WORKERS = True
# filter these Pokemon from the map to reduce traffic and browser load
#MAP_FILTER_IDS = [161, 165, 16, 19, 167]
# unix timestamp of last spawn point migration, spawn times learned before this will be ignored
LAST_MIGRATION = 1481932800 # Dec. 17th, 2016
# Treat a spawn point's expiration time as unknown if nothing is seen at it on more than x consecutive visits
#FAILURES_ALLOWED = 3
## Map data provider and appearance, previews available at:
## https://leaflet-extras.github.io/leaflet-providers/preview/
#MAP_PROVIDER_URL = '//{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'
#MAP_PROVIDER_ATTRIBUTION = '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
# set of proxy addresses and ports
# SOCKS requires aiosocks to be installed
#PROXIES = {'http://127.0.0.1:8080', 'https://127.0.0.1:8443', 'socks5://127.0.0.1:1080'}
# Bytestring key to authenticate with manager for inter-process communication
#AUTHKEY = b'm3wtw0'
# Address to use for manager, leave commented if you're not sure.
#MANAGER_ADDRESS = r'\\.\pipe\monocle' # must be in this format for Windows
#MANAGER_ADDRESS = 'monocle.sock' # the socket name for Unix systems
#MANAGER_ADDRESS = ('127.0.0.1', 5002) # could be used for CAPTCHA solving and live worker maps on remote systems
# Store the cell IDs so that they don't have to be recalculated every visit.
# Enabling will (potentially drastically) increase memory usage.
#CACHE_CELLS = False
# Only for use with web_sanic (requires PostgreSQL)
#DB = {'host': '127.0.0.1', 'user': 'monocle_role', 'password': 'pik4chu', 'port': '5432', 'database': 'monocle'}
# Disable to use Python's event loop even if uvloop is installed
#UVLOOP = True
# The number of coroutines that are allowed to run simultaneously.
#COROUTINES_LIMIT = GRID[0] * GRID[1]
### FRONTEND CONFIGURATION
LOAD_CUSTOM_HTML_FILE = False # File path MUST be 'templates/custom.html'
LOAD_CUSTOM_CSS_FILE = False # File path MUST be 'static/css/custom.css'
LOAD_CUSTOM_JS_FILE = False # File path MUST be 'static/js/custom.js'
#FB_PAGE_ID = None
#TWITTER_SCREEN_NAME = None # Username withouth '@' char
#DISCORD_INVITE_ID = None
#TELEGRAM_USERNAME = None # Username withouth '@' char
## Variables below will be used as default values on frontend
#RAIDS_FILTER = (1, 2, 3, 4, 5) # Levels shown by default on map
FIXED_OPACITY = False # Make marker opacity independent of remaining time
SHOW_TIMER = False # Show remaining time on a label under each pokemon marker
SHOW_TIMER_RAIDS = True # Show remaining time on a label under each raid marker
### OPTIONS BELOW THIS POINT ARE ONLY NECESSARY FOR NOTIFICATIONS ###
NOTIFY = False # enable notifications
# notify gyms data updates to webhooks
#NOTIFY_GYMS_WEBHOOK = False
# create images with Pokémon image and optionally include IVs and moves
# requires cairo and ENCOUNTER = 'notifying' or 'all'
TWEET_IMAGES = True
# IVs and moves are now dependant on level, so this is probably not useful
IMAGE_STATS = False
# As many hashtags as can fit will be included in your tweets, these will
# be combined with landmark-specific hashtags (if applicable).
HASHTAGS = {AREA_NAME, 'Monocle', 'PokemonGO'}
#TZ_OFFSET = 0 # UTC offset in hours (if different from system time)
# the required number of seconds remaining to notify about a Pokémon
TIME_REQUIRED = 600 # 10 minutes
### Only set either the NOTIFY_RANKING or NOTIFY_IDS, not both!
# The (x) rarest Pokémon will be eligible for notification. Whether a
# notification is sent or not depends on its score, as explained below.
NOTIFY_RANKING = 90
# Pokémon to potentially notify about, in order of preference.
# The first in the list will have a rarity score of 1, the last will be 0.
#NOTIFY_IDS = (130, 89, 131, 3, 9, 134, 62, 94, 91, 87, 71, 45, 85, 114, 80, 6)
# Sightings of the top (x) will always be notified about, even if below TIME_REQUIRED
# (ignored if using NOTIFY_IDS instead of NOTIFY_RANKING)
ALWAYS_NOTIFY = 14
# Always notify about the following Pokémon even if their time remaining or scores are not high enough
#ALWAYS_NOTIFY_IDS = {89, 130, 144, 145, 146, 150, 151}
# Never notify about the following Pokémon, even if they would otherwise be eligible
#NEVER_NOTIFY_IDS = TRASH_IDS
#######################################################
## NOTIFY POKEMON
##
## If some values are left out,
## Monocle uses the values of DEFAULT_ALARM
##
## So either set all values or delete the '#' signs
## infront of the DEFAULT_ALARM lines
#######################################################
#######################
# ICON SPRITES
#
# copyright safe icons:
#ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Copyrightfree-Assets/{}.png"
#EGG_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Copyrightfree-Assets/egg_{}.png"
#GMAP_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Copyrightfree-Assets-32x32/{}.png"
#GMAP_EGG_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Copyrightfree-Assets-32x32/egg_{}.png"
#
# non copyright safe icons:
ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Original-Assets/{}.png"
EGG_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Original-Assets/egg_{}.png"
GMAP_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Original-Assets-32x32/{}.png"
GMAP_EGG_ICONS_URL = "https://raw.githubusercontent.com/M4d40/my-po-icons/master/Original-Assets-32x32/egg_{}.png"
# Available keywords for poke alarms:
###############################
# address, latitude, longitude, poke_id, poke_name,
# weather_boosted, gmap_link, applemap_link,
# disappear_time_12, disappear_time_24, time_left,
# poke_iv, poke_form, poke_gender, poke_height, poke_weight,
# poke_move_1, poke_move_2, poke_lvl, poke_cp,
# poke_atk, poke_def, poke_sta
# address takes a lot of google maps api calls!
#
# Available Filter:
#
# 'filter_ids': [1,2,3,4,5,6,8,9,246,247,248],
# 'filter_ivs': {'value': 95, 'op': '>=', 'ignore_unknown': True},
# Both can be added within one alarm
#
# Available iv filter operators: '>','>=','<','<=','=='
WEATHER_STATUS = {
0: "Not boosted",
1: "Clear",
2: "Rainy",
3: "Partly Cloudy",
4: "Overcast",
5: "Windy",
6: "Snow",
7: "Fog"
}
#DEFAULT_ALARM = {
# 'username': '{poke_name}',
# 'title': 'A wild {poke_name} {poke_iv}% (lvl {poke_lvl} | {poke_cp}CP) ({poke_atk}/{poke_def}/{poke_sta}) appeared',
# 'description': """Until {disappear_time_24} ({time_left} left)
#IV: {poke_iv}% ({poke_atk}/{poke_def}/{poke_sta})
#CP: {poke_cp} | Level: {poke_lvl}
#Attacks: {poke_move_1} / {poke_move_2}
#Gender: {poke_gender} | Weight: {poke_weight} kg | Height: {poke_height} m
#Google Maps Link: {gmap_link},
#Apple Maps Link: {applemap_link}""",
# 'color': 'BLUE', # RED/AQUA/GREEN/BLUE/GOLD/ORANGE/RED/GREY/NAVY
# 'avatar_url': ICONS_URL,
# 'thumbnail_url': ICONS_URL,
# 'icon_url': ICONS_URL
#}
#POKEMON_ALARMS = {
# 'discord': [
# {
# 'name': 'filter pokemon ids',
# 'title': 'A wild {poke_name} {poke_iv}% (lvl {poke_lvl} | {poke_cp}CP) ({poke_atk}/{poke_def}/{poke_sta}) appeared',
# 'description': """Until {disappear_time_24} ({time_left} left)""",
# 'filter_ids': [1,2,3,4,5,6,8,9,246,247,248],
# 'webhook_url': 'YOUR DISCORDCHANNEL WEBHOOK',
# 'avatar_url': ICONS_URL,
# 'thumbnail_url': ICONS_URL,
# 'mention': '12345678901234' # User ID
# },
# {
# 'name': 'filter pokemon ivs',
# 'username': 'iv-95-bot',
# 'filter_ivs': {'value': 95, 'op': '>=', 'ignore_unknown': True},
# 'webhook_url': 'YOUR DISCORDCHANNEL WEBHOOK',
# },
# {
# 'name': 'combined filter ivs and ids',
# 'username': 'id-iv-95-combo-bot',
# 'filter_ids': [1,2,3,4,5,6,8,9,246,247,248],
# 'filter_ivs': {'value': 95, 'op': '>=', 'ignore_unknown': True},
# 'webhook_url': 'YOUR DISCORDCHANNEL WEBHOOK',
# 'color': 'RED',
# }
# ]
#}
# Override the rarity score for particular Pokémon
# format is: {pokemon_id: rarity_score}
#RARITY_OVERRIDE = {148: 0.6, 149: 0.9}
# Ignore IV score and only base decision on rarity score (default if IVs not known)
#IGNORE_IVS = False
# Ignore rarity score and only base decision on IV score
#IGNORE_RARITY = False
# The Pokémon score required to notify goes on a sliding scale from INITIAL_SCORE
# to MINIMUM_SCORE over the course of FULL_TIME seconds following a notification
# Pokémon scores are an average of the Pokémon's rarity score and IV score (from 0 to 1)
# If NOTIFY_RANKING is 90, the 90th most common Pokémon will have a rarity of score 0, the rarest will be 1.
# IV score is the IV sum divided by 45 (perfect IVs).
FULL_TIME = 1800 # the number of seconds after a notification when only MINIMUM_SCORE will be required
INITIAL_SCORE = 0.7 # the required score immediately after a notification
MINIMUM_SCORE = 0.4 # the required score after FULL_TIME seconds have passed
### The following values are fake, replace them with your own keys to enable
### notifications, otherwise exclude them from your config
### You must provide keys for at least one service to use notifications.
#PB_API_KEY = 'o.9187cb7d5b857c97bfcaa8d63eaa8494'
#PB_CHANNEL = 0 # set to the integer of your channel, or to None to push privately
#TWITTER_CONSUMER_KEY = '53d997264eb7f6452b7bf101d'
#TWITTER_CONSUMER_SECRET = '64b9ebf618829a51f8c0535b56cebc808eb3e80d3d18bf9e00'
#TWITTER_ACCESS_KEY = '1dfb143d4f29-6b007a5917df2b23d0f6db951c4227cdf768b'
#TWITTER_ACCESS_SECRET = 'e743ed1353b6e9a45589f061f7d08374db32229ec4a61'
## Telegram bot token is the one Botfather sends to you after completing bot creation.
## Chat ID can be two different values:
## 1) '@channel_name' for channels
## 2) Your chat_id if you will use your own account. To retrieve your ID, write to your bot and check this URL:
## https://api.telegram.org/bot<BOT_TOKEN_HERE>/getUpdates
##
## TELEGRAM_MESSAGE_TYPE can be 0 or 1:
## => 0 you'll receive notifications as venue (as you already seen before in Monocle)
## => 1 you'll receive notifications as text message with GMaps link
#TELEGRAM_BOT_TOKEN = '123456789:AA12345qT6QDd12345RekXSQeoZBXVt-AAA'
#TELEGRAM_CHAT_ID = '@your_channel'
#TELEGRAM_MESSAGE_TYPE = 0
## The following raid notification related configs
## only apply to Monkey's version of raids notification (no webhook support, only Telegram and Discord)
## For webhook raids notification, see below for NOTIFY_RAIDS_WEBHOOK
##
## Available keywords for egg/raid alarms:
###########################################
## gym_name, gym_pic, team, level,
## address, gmap_link, applemap_link,
## poke_id, poke_name, move_1, move_2,
## time_battle_12, time_battle_24,
## raid_end_12, raid_end_24
##
#####################################
## Available alarm level operators:
## '>','>=','<','<=','=='
##
#NOTIFY_EGGS = False # Enable egg notifications. Default False
#NOTIFY_RAIDS = False # Enable raid notifications. Default False
#TELEGRAM_RAIDS_LVL_MIN = 1
#TELEGRAM_RAIDS_IDS = {143, 248}
#TEAM = {
# 0: "No Team",
# 1: "Mystic (blue)",
# 2: "Valor (red)",
# 3: "Instinct (yellow)"
#}
#DEFAULT_EGG_ALARM = {
# 'type': 'egg',
# 'username': 'Egg Bot',
# 'title': "A Level {level} Egg appeared",
# 'description': """Gym: {gym_name}
#It hatches at: {time_battle_24}
#Controlled by: {team}
#Raid ends at: {raid_end_24}""",
# 'level': {'value': 1, 'op': '>='},
# 'color': 'GREY', # RED/AQUA/GREEN/BLUE/GOLD/ORANGE/RED/GREY/NAVY
# 'thumbnail_url': "{gym_pic}",
# 'avatar_url': EGG_ICONS_URL,
# 'gmap_icon_url': GMAP_EGG_ICONS_URL,
# 'webhook_url': "https://discordapp.com/api/webhooks/xxxxxxxxxxxxx/xxxxxxxxxxxxxxx"
#}
#DEFAULT_RAID_ALARM = {
# 'type': 'raid',
# 'username': 'Raid Bot',
# 'title': 'A {poke_name} Raid (Level {level}) hatched',
# 'description': """Gym: {gym_name}
#Until: {raid_end_24}
#Controlled by: **Team {team}**
#Pokemon: **{poke_name}**
#Attacks: **{move_1}** / **{move_2}**""",
# 'level': {'value': 1, 'op': '>='},
# 'color': 'BLUE', # RED/AQUA/GREEN/BLUE/GOLD/ORANGE/RED/GREY/NAVY
# 'thumbnail_url': "{gym_pic}",
# 'avatar_url': ICONS_URL,
# 'gmap_icon_url': GMAP_ICONS_URL,
# 'webhook_url': 'https://discordapp.com/api/webhooks/xxxxxxxxxxxxx/xxxxxxxxxxxxxxx'
#}
#RAID_ALARMS = {
# 'discord': [
# {
# 'type': 'egg',
# 'level': {'value': 4, 'op': '>='},
# 'username': 'Eggs lvl4 and higher Bot',
# 'color': 'GREY', # RED/AQUA/GREEN/BLUE/GOLD/ORANGE/RED/GREY/NAVY
# 'webhook_url': 'https://discordapp.com/api/webhooks/xxxxxxxxx/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
# },
# {
# 'type': 'egg',
# 'level': {'value': 1, 'op': '=='},
# 'username': 'LVL 1 Egg Bot',
# 'webhook_url': 'https://discordapp.com/api/webhooks/xxxxxxxxx/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
# },
# {
# 'type': 'raid',
# 'level': {'value': 1, 'op': '=='},
# 'username': 'LVL 1 Raid Bot',
# 'webhook_url': 'https://discordapp.com/api/webhooks/xxxxxxxxx/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
# }
# ]
#}
#TELEGRAM_RAIDS_CHAT_ID = '@your_channel'
#WEBHOOKS = {'http://127.0.0.1:4000'}
#####
## Webhook formatting config
##
## Allows configuration of outgoing raid webhooks.
## Defines <our field name>:<recipient's field name>
##
## The following are all the available fields for raid webhook.
## "external_id", "latitude", "longitude", "level", "pokemon_id",
## "team", "cp", "move_1", "move_2",
## "raid_begin", "raid_battle", "raid_end",
## "gym_id", "base64_gym_id", "name", "gym_url"
##
## For PokeAlarm, no raid webhook config is needed since it is supported out of the box
## Note that you must set NOTIFY_GYMS_WEBHOOK to True in config in order to obtain gym names from PokeAlarm.
#
#WEBHOOK_RAID_MAPPING = {}
#
## For others, the following is an example to map rename the field `raid_seed` to `external_id`.
#
#WEBHOOK_RAID_MAPPING = {
# 'raid_seed': 'external_id',
# 'gym_url': 'url',
#}
#
# Gym webhook require worker raiders to be fully functionnal
#
#WEBHOOK_GYM_MAPPING = {
# 'gym_id': 'gym_id',
# 'last_modified': 'last_modified',
# 'guard_pokemon_id': 'guard_pokemon_id',
# 'is_in_battle': 'in_battle',
# 'slots_available': 'slots_available',
# 'latitude': 'latitude',
# 'longitude': 'longitude',
# 'team': 'team',
# 'name': 'name',
# 'url': 'url',
# 'gym_defenders': 'gym_defenders',
# 'total_cp': 'total_cp',
#}
#
#Send weather change notifications to webhook
#NOTIFY_WEATHER = True
##### Referencing landmarks in your tweets/notifications
#### It is recommended to store the LANDMARKS object in a pickle to reduce startup
#### time if you are using queries. An example script for this is in:
#### scripts/pickle_landmarks.example.py
#from pickle import load
#with open('pickles/landmarks.pickle', 'rb') as f:
# LANDMARKS = load(f)
### if you do pickle it, just load the pickle and omit everything below this point
#from monocle.landmarks import Landmarks
#LANDMARKS = Landmarks(query_suffix=AREA_NAME)
# Landmarks to reference when Pokémon are nearby
# If no points are specified then it will query OpenStreetMap for the coordinates
# If 1 point is provided then it will use those coordinates but not create a shape
# If 2 points are provided it will create a rectangle with its corners at those points
# If 3 or more points are provided it will create a polygon with vertices at each point
# You can specify the string to search for on OpenStreetMap with the query parameter
# If no query or points is provided it will query with the name of the landmark (and query_suffix)
# Optionally provide a set of hashtags to be used for tweets about this landmark
# Use is_area for neighborhoods, regions, etc.
# When selecting a landmark, non-areas will be chosen first if any are close enough
# the default phrase is 'in' for areas and 'at' for non-areas, but can be overriden for either.
### replace these with well-known places in your area
## since no points or query is provided, the names provided will be queried and suffixed with AREA_NAME
#LANDMARKS.add('Rice Eccles Stadium', shortname='Rice Eccles', hashtags={'Utes'})
#LANDMARKS.add('the Salt Lake Temple', shortname='the temple', hashtags={'TempleSquare'})
## provide two corner points to create a square for this area
#LANDMARKS.add('City Creek Center', points=((40.769210, -111.893901), (40.767231, -111.888275)), hashtags={'CityCreek'})
## provide a query that is different from the landmark name so that OpenStreetMap finds the correct one
#LANDMARKS.add('the State Capitol', shortname='the Capitol', query='Utah State Capitol Building')
### area examples ###
## query using name, override the default area phrase so that it says 'at (name)' instead of 'in'
#LANDMARKS.add('the University of Utah', shortname='the U of U', hashtags={'Utes'}, phrase='at', is_area=True)
## provide corner points to create a polygon of the area since OpenStreetMap does not have a shape for it
#LANDMARKS.add('Yalecrest', points=((40.750263, -111.836502), (40.750377, -111.851108), (40.751515, -111.853833), (40.741212, -111.853909), (40.741188, -111.836519)), is_area=True)
### Shadown ban module
#SB_DETECTOR = False
#SB_COMMON_POKEMON_IDS = (16,19,23,27,29,32,43,46,52,54,60,69,77,81,98,118,120,129,177,183,187,191,194,209,218,293,304,320,325,333,339)
#SB_MAX_ENC_MISS = 3 # Number of encounter misses before account is marked as sbanned
#SB_MIN_SIGHTING_COUNT = 30 # Minimum sightings required to flag SB
#SB_QUARANTINE_VISITS = 12 # Number of mininum visits needed to check if an account has seen any uncommon
#HIBERNATE_WEBHOOK = None # Define webhook end point for Hibernation notifications. Payload is Discord type.
#HIBERNATE_WEBHOOK_MIN_LEVEL = 1 # Minimum level to notify to Hibernate webhook
####
### PgScout (Credit to Avatar690)
## MUST MATCH YOUR PGSCOUT CONFIG.JSON. Will encounter based on ENCOUNTER_IDs above.
## If encounter fails, worker.py will attempt to encounter with the running acount (if lv > 30)
## If it fails, sighting will be saved without additional encounter info.
### Enter in your address for PGSCOUT hook endpoint including hostname, port (if any) and path.
### If set to a url, PGSCOUT will be used. If None, normal Monocle encounter will be used.
#
#PGSCOUT_ENDPOINT = None
#
## Example,
#PGSCOUT_ENDPOINT = {"http://127.0.0.1:1234/iv","http://127.0.0.1:1235/iv"}
#
## *Take note that /iv is needed at the end for PGScout. Do not remove it.*
## Set the connection timeout to wait on a response from PGScout. Default is 40 seconds.
## Timeout will be connection dependent, proxy dependent, etc. I recommend keeping it at the default.
## Going too high will certainly guarantee a response from a Scout but will lead to greater inefficiency
## and instability for Monocle
#
#PGSCOUT_TIMEOUT = 40
#
### Record keeping settings
###
### If True, new fort_sightings and raids will be inserted. Else, existing records for the same fort will be updated (if found).
### Default is False
#KEEP_GYM_HISTORY = False
#
### If True, new sightings inserted. Else, existing sighting for the same spawnpoint will be updated (if found).
### Default is True
#KEEP_SPAWNPOINT_HISTORY = True
### Cleanup
## Max number of rows to delete in each execution per table. Not recommended to set it too high. It will choke the DB.
# CLEANUP_LIMIT = 100000
## Table specific cleanup times. Set -1.0 to disable
# CLEANUP_RAIDS_OLDER_THAN_X_HR = 6.0
# CLEANUP_SIGHTINGS_OLDER_THAN_X_HR = 6.0
# CLEANUP_FORT_SIGHTINGS_OLDER_THAN_X_HR = 6.0
# CLEANUP_MYSTERY_SIGHTINGS_OLDER_THAN_X_HR = 24.0
### Discord webhook url for sending scan log messages
#SCAN_LOG_WEBHOOK = None