Module: PWN::WWW::Synack

Defined in:
lib/pwn/www/synack.rb

Overview

This plugin supports platform.synack.com actions.

Class Method Summary collapse

Class Method Details

.authorsObject

Author(s)

0day Inc. <[email protected]>



97
98
99
100
101
# File 'lib/pwn/www/synack.rb', line 97

public_class_method def self.authors
  "AUTHOR(S):
    0day Inc. <[email protected]>
  "
end

.close(opts = {}) ⇒ Object

Supported Method Parameters

browser_obj = PWN::WWW::Synack.close(

browser_obj: 'required - browser_obj returned from #open method'

)



86
87
88
89
90
91
92
93
# File 'lib/pwn/www/synack.rb', line 86

public_class_method def self.close(opts = {})
  browser_obj = opts[:browser_obj]
  PWN::Plugins::TransparentBrowser.close(
    browser_obj: browser_obj
  )
rescue StandardError => e
  raise e
end

.helpObject

Display Usage for this Module



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
# File 'lib/pwn/www/synack.rb', line 105

public_class_method def self.help
  puts "USAGE:
    browser_obj = #{self}.open(
      browser_type: 'optional - :firefox|:chrome|:ie|:headless (Defaults to :firefox)',
      proxy: 'optional - scheme://proxy_host:port',
      with_tor: 'optional - boolean (defaults to false)'
    )
    puts browser_obj.public_methods

    browser_obj = #{self}.login(
      browser_obj: 'required - browser_obj returned from #open method',
      username: 'required - username',
      password: 'optional - passwd (will prompt if blank),
      mfa: 'optional - if true prompt for mfa token (defaults to false)'
    )

    browser_obj = #{self}.logout(
      browser_obj: 'required - browser_obj returned from #open method'
    )

    #{self}.close(
      browser_obj: 'required - browser_obj returned from #open method'
    )

    #{self}.authors
  "
end

.login(opts = {}) ⇒ Object

Supported Method Parameters

browser_obj = PWN::WWW::Synack.login(

browser_obj: 'required - browser_obj returned from #open method',
username: 'required - username',
password: 'optional - passwd (will prompt if blank)',
mfa: 'optional - if true prompt for mfa token (defaults to false)'

)



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
# File 'lib/pwn/www/synack.rb', line 34

public_class_method def self.(opts = {})
  browser_obj = opts[:browser_obj]
  username = opts[:username].to_s.scrub.strip.chomp
  password = opts[:password]

  if password.nil?
    password = PWN::Plugins::AuthenticationHelper.mask_password
  else
    password = opts[:password].to_s.scrub.strip.chomp
  end
  mfa = opts[:mfa]

  browser_obj.goto('https://login.synack.com')

  browser_obj.text_field(name: 'email').wait_until(&:present?).set(username)
  browser_obj.text_field(name: 'password').wait_until(&:present?).set(password)
  browser_obj.button(class: 'btn').click!

  if mfa
    until browser_obj.url.include?('https://platform.synack.com')
      browser_obj.text_field(name: 'authy_token').wait_until(&:present?).set(PWN::Plugins::AuthenticationHelper.mfa(prompt: 'enter mfa token'))
      browser_obj.button(class: 'btn').click!
      sleep 3
    end
    print "\n"
  end

  browser_obj
rescue StandardError => e
  raise e
end

.logout(opts = {}) ⇒ Object

Supported Method Parameters

browser_obj = PWN::WWW::Synack.logout(

browser_obj: 'required - browser_obj returned from #open method'

)



71
72
73
74
75
76
77
78
79
# File 'lib/pwn/www/synack.rb', line 71

public_class_method def self.logout(opts = {})
  browser_obj = opts[:browser_obj]
  browser_obj.img(class: 'navbar-avatar-img').wait_until(&:present?).click!
  browser_obj.button(text: 'Logout').wait_until(&:present?).click!

  browser_obj
rescue StandardError => e
  raise e
end

.open(opts = {}) ⇒ Object

Supported Method Parameters

browser_obj = PWN::WWW::Synack.open(

browser_type: 'optional - :firefox|:chrome|:ie|:headless (Defaults to :firefox)',
proxy: 'optional - scheme://proxy_host:port',
with_tor: 'optional - boolean (defaults to false)'

)



16
17
18
19
20
21
22
23
24
# File 'lib/pwn/www/synack.rb', line 16

public_class_method def self.open(opts = {})
  browser_obj = PWN::Plugins::TransparentBrowser.open(opts)

  browser_obj.goto('https://www.synack.com')

  browser_obj
rescue StandardError => e
  raise e
end