Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
S
StreamMon
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
SexHackMe
StreamMon
Commits
da9d297e
Commit
da9d297e
authored
7 months ago
by
nextime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Re-add script
parent
3c431578
Pipeline
#163
canceled with stages
Changes
1
Pipelines
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
58 additions
and
0 deletions
+58
-0
streammon.py
streammon.py
+58
-0
No files found.
streammon.py
0 → 100644
View file @
da9d297e
import
asyncio
from
playwright.async_api
import
async_playwright
import
argparse
import
os
from
datetime
import
datetime
async
def
monitor_streamate
(
log_path
):
async
with
async_playwright
()
as
p
:
browser
=
await
p
.
chromium
.
connect_over_cdp
(
"http://localhost:9222"
)
while
True
:
contexts
=
browser
.
contexts
for
context
in
contexts
:
for
page
in
context
.
pages
:
if
"performerclient.streamatemodels.com"
in
page
.
url
:
print
(
f
"Found Streamate tab"
)
await
monitor_requests
(
page
,
log_path
)
await
asyncio
.
sleep
(
5
)
# Check every 5 seconds
async
def
monitor_requests
(
page
,
log_path
):
async
def
log_request
(
request
):
if
request
.
resource_type
not
in
[
'document'
,
'image'
,
'font'
,
'stylesheet'
]:
log_entry
=
f
"[{datetime.now()}] Request: {request.method} {request.url}
\n
"
with
open
(
log_path
,
'a'
)
as
f
:
f
.
write
(
log_entry
)
async
def
log_response
(
response
):
#print(await response.body())
#print(response.request.resource_type)
#if response.request.resource_type not in ['document', 'image', 'font', 'stylesheet']:
if
response
.
request
.
resource_type
in
[
'xhr'
]
and
not
response
.
url
.
endswith
(
".mp3"
):
log_entry
=
f
"[{datetime.now()}] Response: {response.status} {response.url} -> BODY: "
log_body
=
await
response
.
body
()
with
open
(
log_path
,
'a'
)
as
f
:
f
.
write
(
log_entry
)
print
(
log_body
)
f
.
write
(
str
(
log_body
))
f
.
write
(
"
\n\n
"
)
page
.
on
(
"request"
,
log_request
)
page
.
on
(
"response"
,
log_response
)
while
True
:
await
asyncio
.
sleep
(
1
)
if
__name__
==
"__main__"
:
parser
=
argparse
.
ArgumentParser
(
description
=
"Monitor Streamate requests"
)
parser
.
add_argument
(
"--log_path"
,
type
=
str
,
default
=
"streamate_requests.log"
,
help
=
"Path to the log file"
)
args
=
parser
.
parse_args
()
log_dir
=
os
.
path
.
dirname
(
args
.
log_path
)
if
log_dir
and
not
os
.
path
.
exists
(
log_dir
):
os
.
makedirs
(
log_dir
)
asyncio
.
run
(
monitor_streamate
(
args
.
log_path
))
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment