- 扫描 ID:
- f66b5f00-cdb8-4d40-a49a-f27c8f6cbf52已完成
- 提交的 URL:
- https://ludo.vision/
- 报告完成时间:
链接 · 找到 2 个
从页面中识别出的传出链接
链接 | 文本 |
---|---|
https://github.com/msitarzewski/ludovision | GitHub |
https://bsky.app/settings/app-passwords | Bluesky App Passwords page |
JavaScript 变量 · 找到 3 个
在页面窗口对象上加载的全局 JavaScript 变量是在函数外部声明的变量,可以从当前范围内的代码中的任何位置访问
名称 | 类型 |
---|---|
onbeforetoggle | object |
documentPictureInPicture | object |
onscrollend | object |
控制台日志消息 · 找到 4 条
记录到 Web 控制台的消息
类型 | 类别 | 记录 |
---|---|---|
error | network |
|
warning | other |
|
verbose | dom |
|
error | network |
|
HTML
页面的原始 HTML 正文
<!DOCTYPE html><html><head>
<title>Ludovision</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="styles.css">
<script src="settings.js"></script>
<script src="script.js"></script>
<meta name="robots" content="noindex">
<!-- open graph meta tags -->
<meta property="og:title" content="Ludovision">
<meta property="og:description" content="View raw image data from the Bluesky firehose. Viewer discretion is advised. VPN and private browsing recommended.">
<meta property="og:image" content="samples/feed.jpg">
<meta property="og:url" content="https://ludovision.com">
</head>
<body>
<div id="warning-modal" style="display: flex;">
<div>
<h1>WARNING</h1>
<p id="warning-text" style="text-transform: uppercase;">
You are viewing raw image data directly from the Bluesky firehose. This data INCLUDES unfiltered, unmoderated, and sensitive content. Viewer discretion is advised. Proceed only if you are prepared to encounter images that have not been reviewed for appropriateness or relevance. You agree that you are of a legal age to view this content.
</p>
<p id="warning-text">
<strong>Disclaimer:</strong><br>
The creator of this tool assumes no responsibility for the content accessed through this service. Any inappropriate use, redistribution, or exploitation of the data is strictly prohibited. By continuing, you agree to hold the creator harmless from any liability arising from your use of this data.
</p>
<p id="warning-text">
This tool and its instructions are open source and available on <a href="https://github.com/msitarzewski/ludovision" target="_blank">GitHub</a>.
</p>
<p id="warning-text" style="color: red;">
NOTE: PRIVATE BROWSING MODE IS RECOMMENDED. Private browsing prevents images from being stored on your device and will reside in memory only.
</p>
<div class="form-group">
<input type="checkbox" id="launch-warning-checkbox">
<label for="launch-warning-checkbox">I understand and accept the above disclaimer</label>
</div>
<div class="modal-buttons">
<button id="ok-button">OK</button>
<button id="cancel-button">Cancel</button>
</div>
</div>
</div>
<div id="header">
<h1>Ludovision</h1>
<div id="settings-container" class="settings-menu">
<!-- close button-->
<div class="form-container">
<button id="close-settings-button" class="close-settings-button"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"></path></svg></button>
<div class="form-header">Settings</div>
<div class="form-group">
<label for="image-size-slider" class="form-label">Image Size</label>
<div class="form-inputs">
<input type="number" id="image-size-input" min="32" max="512" value="128" step="32" class="form-control">
<input type="range" id="image-size-slider" min="32" max="512" value="128" step="32" class="form-control-range">
</div>
</div>
<div class="form-group">
<label for="sort-toggle" class="form-label">Newest First</label>
<div class="form-inputs">
<input type="checkbox" id="sort-toggle" class="form-check-input">Yes
</div>
</div>
<div class="form-group">
<label for="blur-toggle" class="form-label">Blur Unwanted</label>
<div class="form-inputs">
<input type="checkbox" id="blur-toggle" class="form-check-input">Yes
</div>
</div>
<div class="form-group">
<label for="speed-slider" class="form-label">Feed Delay (<span id="speed-value">0</span>ms)</label>
<div class="form-inputs">
<input type="range" id="speed-slider" min="0" max="2000" value="0" step="100" class="form-control-range">
</div>
</div>
<div id="auth-container">
<div class="form-group">
<label for="bsky-identifier" class="form-label">Bluesky Identifier</label>
<div class="form-inputs">
<input type="text" id="bsky-identifier" class="form-control">
</div>
</div>
<div class="form-group">
<label for="bsky-app-password" class="form-label">App Password</label>
<div class="form-inputs">
<input type="password" id="bsky-app-password" class="form-control" placeholder="xxxx-xxxx-xxxx-xxxx">
</div>
</div>
<div class="form-group">
<div class="form-inputs" style="display: flex; justify-content: end;">
<button id="auth-button" class="form-control">Auth</button>
<button id="clear-button" class="form-control" style="display: none;">Clear</button>
</div>
</div>
</div>
<div class="button-group">
<button id="pause-button" class="btn btn-sm btn-primary">Pause Feed</button>
<button id="skip-button" class="btn btn-sm btn-danger">Skip</button>
<button id="restart-button" class="btn btn-sm btn-secondary">Restart Feed</button>
</div>
</div>
</div>
<div id="debug-info"></div>
<button id="hamburger-menu" class="hamburger-menu">
<!--?xml version="1.0" encoding="UTF-8"?-->
<svg width="32px" height="32px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<title>Menu</title>
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<g id="Menu">
<rect id="Rectangle" fill-rule="nonzero" x="0" y="0" width="24" height="24"></rect>
<line x1="5" y1="7" x2="19" y2="7" id="Path" stroke="white" stroke-width="2" stroke-linecap="round"></line>
<line x1="5" y1="17" x2="19" y2="17" id="Path" stroke="white" stroke-width="2" stroke-linecap="round"></line>
<line x1="5" y1="12" x2="19" y2="12" id="Path" stroke="white" stroke-width="2" stroke-linecap="round"></line>
</g>
</g>
</svg>
</button>
</div>
<div id="images-container" style="grid-auto-rows: 128px; grid-template-columns: repeat(auto-fill, minmax(128px, 1fr));">
<!-- Images will be appended here -->
</div>
<div id="image-modal" class="modal" style="display: none;">
<img id="modal-image" alt="Full-size image" style="max-width: 90%; max-height: 90%;">
<div class="modal-buttons">
<button id="profile-link" class="view-profile-button" href="#" target="_blank">View Profile</button>
<button id="view-all-media-button" class="view-all-media-button" href="#">View Gallery</button>
</div>
</div>
<div id="gallery-modal" class="modal" style="display: none;">
<div class="grid">
<!-- Gallery images will be appended here -->
</div>
<div class="modal-buttons">
<button id="close-gallery-button">Close</button>
<button id="gallery-profile-link" class="view-profile-button" href="#" target="_blank">View Profile</button>
</div>
</div>
<div id="gallery-image-modal" class="modal" style="display: none;">
<img id="gallery-modal-image" alt="Full-size gallery image" style="max-width: 90%; max-height: 90%;">
<div id="magnifier" style="display: none;"></div>
</div>
<div id="instructions-modal" class="modal" style="display: none;">
<div class="modal-content">
<div class="modal-header">App Password Required</div>
<div class="modal-body">
<img src="samples/gallery.jpg" loading="lazy" alt="Gallery" style="max-width: 100%; height: auto;">
<p>
This button would normally be used to view the gallery - every image this user has posted on Bluesky.
</p>
<p>
To view the gallery, you need to create an app password and enter it in either the settings
file or the settings menu. Follow the instructions on the <a href="https://bsky.app/settings/app-passwords" target="_blank">Bluesky App Passwords page</a>
to create an app password.
</p>
</div>
<div class="modal-footer">
<button id="close-instructions-button" class="btn btn-danger">Close</button>
</div>
</div>
</div>
</body></html>