forked from j5oh/synackAPI
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbot.py
executable file
·72 lines (60 loc) · 2.03 KB
/
bot.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
#!/usr/bin/env python3
from synack import synack
import time
###### PLEASE READ THIS FIRST #####
## This is the URL you must read ##
## before using a bot. It gives ##
## you the maximum API requests ##
## allowed. If you exceed the 5- ##
## minute maximum, you are at ##
## risk for being removed from ##
## the platform in its entirety. ##
## ##
## IT IS ADVISED THAT YOU DO NOT ##
## POLL MORE THAN ONCE EVERY 10 ##
## SECONDS!!! PLEASE REVIEW THE ##
## HELP CENTER ARTICLE! ##
## ##
## https://support.synack.com/hc/en-us/articles/1500002201401-Mission-Automation-Throttling-MUST-READ ##
## ##
## YOU ALONE ARE RESPONSIBLE FOR ##
## MAKING SURE YOU DO NOT EXCEED ##
## THE MAXIMUM NUMBER OF ALLOWED ##
## API CALLS OVER THE SPECIFIED ##
## PERIOD! ##
###################################
## This is a bare-bones mission ##
## bot. The sky is the limit on ##
## what options you want to add ##
## to it ##
## pollSleep will sleep for x ##
## seconds after polling the ##
## API for available missions ##
pollSleep = 100
## claimSleep will sleep for y ##
## seconds after attempting to ##
## claim mission. This is used ##
## to prevent hitting the max ##
## API requests over any 5 min ##
## period. ##
claimSleep = 100
## Don't claim missions on the following targets ##
dontclaim=[]
## Only claim missions on the following ##
## target types: ##
## "Web Application" ##
## "Reverse Engineering" ##
## "Mobile" ##
## "Host" ##
## "Source Code" ##
## "Hardware" ##
assetType = []
s1 = synack()
s1.getSessionToken()
while True:
time.sleep(pollSleep)
missionJson = s1.pollMissions()
if len(missionJson) == 0:
continue
s1.claimMission(missionJson, dontclaim, assetType)
time.sleep(claimSleep)