Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
S
SHMCamStudio
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
1
Merge Requests
1
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
SHMCamStudio
Commits
b8a231ca
Commit
b8a231ca
authored
Jun 18, 2025
by
nextime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Playwright...
parent
a5d8432d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
6 deletions
+48
-6
browser.py
shmcs/browser.py
+48
-6
No files found.
shmcs/browser.py
View file @
b8a231ca
...
...
@@ -11,12 +11,21 @@ logging.getLogger(__name__)
async
def
monitor_stream
(
log_path
,
domain
):
async
with
async_playwright
()
as
p
:
browser_is_pw
=
False
try
:
browser
=
await
p
.
chromium
.
connect_over_cdp
(
"http://localhost:9222"
)
except
:
user_data_dir
=
'./user-data'
cont
=
await
p
.
chromium
.
launch_persistent_context
(
user_data_dir
,
headless
=
False
,
args
=
[
"--disable-infobars"
,
"--disable-features=Antaniu"
],
ignore_default_args
=
[
"--enable-automation"
,
"--no-sandbox"
],)
cont
=
await
p
.
chromium
.
launch_persistent_context
(
user_data_dir
,
#viewport=None,
headless
=
False
,
args
=
[
"--disable-infobars"
,
#"--disable-features=Antaniu"
],
ignore_default_args
=
[
"--enable-automation"
,
"--no-sandbox"
],)
pages
=
cont
.
pages
browser_is_pw
=
True
if
pages
:
page
=
pages
[
0
]
else
:
...
...
@@ -26,6 +35,10 @@ async def monitor_stream(log_path, domain):
logger
.
info
(
"Browser session retained"
)
#await browser.close()
browser
=
cont
.
browser
bw
=
0
dw
=
0
bh
=
0
bw
=
0
while
True
:
browser
=
cont
.
browser
if
browser
:
...
...
@@ -33,12 +46,41 @@ async def monitor_stream(log_path, domain):
else
:
contexts
=
[
cont
]
for
context
in
contexts
:
logger
.
debug
(
"@@@@@@@@@@@ NEW CONTEXT @@@@@@@@"
)
if
browser_is_pw
:
sizedone
=
False
for
page
in
context
.
pages
:
logger
.
info
(
"newpagess----------------"
)
if
browser_is_pw
and
not
sizedone
:
w
=
await
page
.
evaluate
(
'window.outerWidth'
)
h
=
await
page
.
evaluate
(
'window.outerHeight'
)
if
bw
==
0
and
bh
==
0
:
tw
=
page
.
viewport_size
[
"width"
]
th
=
page
.
viewport_size
[
"height"
]
dw
=
w
-
tw
dh
=
h
-
th
logger
.
info
(
"ViewPort difference:
%
d
%
d"
,
dw
,
dh
)
elif
bw
!=
w
or
bh
!=
h
:
logger
.
info
(
"outerWindow detected:
%
d
%
d"
,
w
,
h
)
logger
.
info
(
"ViewPort difference:
%
d
%
d"
,
dw
,
dh
)
logger
.
info
(
"Change ViewPort Size:
%
d
%
d"
,
w
-
dw
,
h
-
dh
)
await
page
.
set_viewport_size
({
"width"
:
w
-
dw
,
"height"
:
h
-
dh
})
# XXX I NEED TO CHANGE THE VIEWPORT OF ALL PAGES OR IT
# GET CONFUSED. EASY: TODO: USE A FUCKING TATE MACHINE
sizedone
=
True
bw
=
w
bh
=
h
#logger.info("Size: %d %d", w, h)
if
domain
in
page
.
url
:
print
(
f
"Found Streamate tab"
)
logger
.
info
(
f
"Found Streamate tab"
)
# XXX THIS IS FUCKONG BLOCKING, TODO: RAKE IT OUT AND PUT THE
# WHOLE THING IN A STATE MACHINE
await
monitor_requests
(
page
,
log_path
)
await
asyncio
.
sleep
(
5
)
# Check every 5 seconds
# XXX TODO: I ALREADY SAID MAKE A FUCKING STATE MACHINE?
logger
.
info
(
"PORCDIOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO
\b\b
"
)
await
asyncio
.
sleep
(
3
)
# Check every 0.1 seconds
async
def
monitor_requests
(
page
,
log_path
):
async
def
log_request
(
request
):
if
request
.
resource_type
not
in
[
'document'
,
'image'
,
'font'
,
'stylesheet'
]:
...
...
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