@ubaidbinwaris/linkedin 1.0.8 → 1.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/login/login.js +39 -0
- package/src/utils/logger.js +1 -0
package/package.json
CHANGED
package/src/login/login.js
CHANGED
|
@@ -156,6 +156,45 @@ async function loginToLinkedIn(options = {}, credentials = null) {
|
|
|
156
156
|
if (launchOptions.headless) {
|
|
157
157
|
logger.warn("Checkpoint detected in headless mode.");
|
|
158
158
|
|
|
159
|
+
// Attempt to resolve simple checkpoints (e.g. "Yes, it's me", "Skip") automatically
|
|
160
|
+
try {
|
|
161
|
+
logger.info("Attempting to resolve simple checkpoint headlessly...");
|
|
162
|
+
const simpleResolved = await page.evaluate(async () => {
|
|
163
|
+
// Find buttons, links, or elements with button role
|
|
164
|
+
const candidates = Array.from(document.querySelectorAll('button, a, [role="button"], input[type="submit"], input[type="button"]'));
|
|
165
|
+
const targetText = ['Yes', 'Skip', 'Not now', 'Continue', 'Sign in', 'Verify', 'Let’s do it', 'Next'];
|
|
166
|
+
|
|
167
|
+
// Find a candidate with one of these texts
|
|
168
|
+
const btn = candidates.find(b => {
|
|
169
|
+
const text = (b.innerText || b.value || '').trim();
|
|
170
|
+
return targetText.some(t => text.includes(t));
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
if (btn) {
|
|
174
|
+
btn.click();
|
|
175
|
+
return true;
|
|
176
|
+
}
|
|
177
|
+
return false;
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
if (simpleResolved) {
|
|
181
|
+
logger.info("Clicked a resolution button. Waiting to see if it clears...");
|
|
182
|
+
await randomDelay(2000, 4000);
|
|
183
|
+
if (!(await detectCheckpoint(page))) {
|
|
184
|
+
logger.info("Checkpoint resolved headlessly! Proceeding...");
|
|
185
|
+
// Re-verify session
|
|
186
|
+
try {
|
|
187
|
+
await page.waitForURL("**/feed**", { timeout: 10000 });
|
|
188
|
+
return { browser, context, page };
|
|
189
|
+
} catch (e) {
|
|
190
|
+
logger.warn("Resolved checkpoint but feed did not load. Continuing...");
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
} catch (err) {
|
|
195
|
+
logger.warn(`Failed to auto-resolve checkpoint: ${err.message}`);
|
|
196
|
+
}
|
|
197
|
+
|
|
159
198
|
if (options.onCheckpoint && typeof options.onCheckpoint === 'function') {
|
|
160
199
|
logger.info("Triggering onCheckpoint callback...");
|
|
161
200
|
await options.onCheckpoint();
|
package/src/utils/logger.js
CHANGED
|
@@ -21,6 +21,7 @@ const defaultLogger = winston.createLogger({
|
|
|
21
21
|
transports: [
|
|
22
22
|
new winston.transports.File({ filename: path.join(logDir, "error.log"), level: "error" }),
|
|
23
23
|
new winston.transports.File({ filename: path.join(logDir, "combined.log") }),
|
|
24
|
+
new winston.transports.Console() // Output to console
|
|
24
25
|
],
|
|
25
26
|
});
|
|
26
27
|
|