File size: 9,635 Bytes
9de864e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
// auth.js - Модуль для авторизации и проверки авторизации
import { saveSession } from './session.js';
import { setAuthenticationStatus, getAuthenticationStatus, restartBrowserInHeadlessMode } from './browser.js';
import { extractAuthToken } from '../api/chat.js';

const AUTH_URL = 'https://chat.qwen.ai/';
const AUTH_SIGNIN_URL = 'https://chat.qwen.ai/auth?action=signin';

const VERIFICATION_TIMEOUT = 300000;

const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));

async function getPage(context) {
    if (context && typeof context.goto === 'function') {
        return context;
    } else if (context && typeof context.newPage === 'function') {
        return await context.newPage();
    } else {
        throw new Error('Неверный контекст: не страница Puppeteer, не контекст Playwright');
    }
}

function isPlaywright(context) {
    return context && typeof context.newPage === 'function';
}

async function promptUser(question) {
    return new Promise(resolve => {
        process.stdout.write(question);

        const onData = (data) => {
            const input = data.toString().trim();
            process.stdin.removeListener('data', onData);
            process.stdin.pause();
            resolve(input);
        };

        process.stdin.resume();
        process.stdin.once('data', onData);
    });
}

export async function checkAuthentication(context) {
    try {
        if (getAuthenticationStatus()) {
            return true;
        }

        const page = await getPage(context);
        const isPW = isPlaywright(context);

        console.log('Проверка авторизации...');
        
        try {
            await page.goto(AUTH_URL, { waitUntil: 'domcontentloaded', timeout: 120000 });
            
            if (isPW) {
                await page.waitForLoadState('domcontentloaded');
            }
            
            await delay(2000);

            const pageTitle = await page.title();
            const hasVerification = pageTitle.includes('Verification');

            if (hasVerification) {
                console.log('Обнаружена страница верификации. Пожалуйста, пройдите верификацию вручную.');
                await promptUser('После прохождения верификации нажмите ENTER для продолжения...');
                console.log('Верификация подтверждена пользователем.');
            }

            let loginContainerCount = 0;
            if (isPW) {
                loginContainerCount = await page.locator('.login-container').count();
            } else {
                const loginElements = await page.$$('.login-container');
                loginContainerCount = loginElements.length;
            }

            if (loginContainerCount === 0) {
                console.log('======================================================');
                console.log('               АВТОРИЗАЦИЯ ОБНАРУЖЕНА                 ');
                console.log('======================================================');

                setAuthenticationStatus(true);
                
                try {
                    await extractAuthToken(context, true);
                    await saveSession(context);
                    console.log('Сессия обновлена');
                } catch (e) {
                    console.error('Не удалось обновить сессию:', e);
                }

                if (isPW) {
                    await page.close();
                }

                return true;
            } else {
                console.log('------------------------------------------------------');
                console.log('               НЕОБХОДИМА АВТОРИЗАЦИЯ                 ');
                console.log('------------------------------------------------------');
                console.log('Пожалуйста, выполните следующие действия:');
                console.log('1. Войдите в систему через GitHub или другой способ в открытом браузере');
                console.log('2. Дождитесь завершения процесса авторизации');
                console.log('3. Нажмите ENTER в этой консоли');
                console.log('------------------------------------------------------');

                await promptUser('После успешной авторизации нажмите ENTER для продолжения...');
                console.log('Пользователь подтвердил завершение авторизации.');

                await page.reload({ waitUntil: 'domcontentloaded', timeout: 120000 });
                await delay(3000);

                let loginElements = 0;
                if (isPW) {
                    loginElements = await page.locator('.login-container').count();
                } else {
                    const elements = await page.$$('.login-container');
                    loginElements = elements.length;
                }

                if (loginElements === 0) {
                    console.log('Авторизация подтверждена.');
                    setAuthenticationStatus(true);

                    await saveSession(context);
                    await extractAuthToken(context, true);

                    if (isPW) {
                        await page.close();
                    }
                    
                    return true;
                } else {
                    console.log('Предупреждение: Авторизация не обнаружена.');
                    setAuthenticationStatus(false);
                    return false;
                }
            }
        } catch (error) {
            if (isPW) {
                await page.close().catch(() => {});
            }
            throw error;
        }
    } catch (error) {
        console.error('Ошибка при проверке авторизации:', error);
        setAuthenticationStatus(false);
        return false;
    }
}

export async function startManualAuthentication(context, skipRestart = false) {
    try {
        const page = await getPage(context);
        const isPW = isPlaywright(context);

        console.log('Открытие страницы для ручной авторизации...');
        
        try {
            await page.goto(AUTH_SIGNIN_URL, { waitUntil: 'load', timeout: 120000 });

            console.log('------------------------------------------------------');
            console.log('               НЕОБХОДИМА АВТОРИЗАЦИЯ                 ');
            console.log('------------------------------------------------------');
            console.log('Пожалуйста, выполните следующие действия:');
            console.log('1. Войдите в систему в открытом браузере');
            console.log('2. Дождитесь завершения процесса авторизации');
            console.log('3. Нажмите ENTER в этой консоли');
            console.log('------------------------------------------------------');

            await promptUser('После успешной авторизации нажмите ENTER для продолжения...');
            
            await page.goto(AUTH_URL, { waitUntil: 'domcontentloaded', timeout: 120000 });
            await delay(2000);

            let loginElements = 0;
            if (isPW) {
                loginElements = await page.locator('.login-container').count();
            } else {
                const elements = await page.$$('.login-container');
                loginElements = elements.length;
            }

            if (loginElements === 0) {
                console.log('Авторизация подтверждена.');
                setAuthenticationStatus(true);

                await saveSession(context);
                await extractAuthToken(context, true);

                console.log('Сессия сохранена успешно!');

                if (isPW) {
                    await page.close();
                }
                
                if (!skipRestart) {
                    await restartBrowserInHeadlessMode();
                }
                return true;
            } else {
                console.log('Авторизация не удалась.');
                setAuthenticationStatus(false);
                return false;
            }
        } catch (error) {
            if (isPW) {
                await page.close().catch(() => {});
            }
            throw error;
        }
    } catch (error) {
        console.error('Ошибка при ручной авторизации:', error);
        setAuthenticationStatus(false);
        return false;
    }
}

export async function checkVerification(page) {
    try {
        const pageTitle = await page.title();
        if (pageTitle.includes('Verification')) {
            console.log('Обнаружена страница верификации');
            await promptUser('Пройдите верификацию и нажмите ENTER...');
            return true;
        }
        return false;
    } catch (error) {
        return false;
    }
}