@alfabit/keycloak 0.0.13 → 0.0.15
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
CHANGED
|
@@ -98,13 +98,6 @@ export const getAuthMethods = () => {
|
|
|
98
98
|
const methods = reactive({
|
|
99
99
|
async loginPopup(idpHint: TIdpHint, redirectUri?: string) {
|
|
100
100
|
redirectUri = redirectUri ?? getUrl();
|
|
101
|
-
|
|
102
|
-
console.log({
|
|
103
|
-
isMobile: isMobile(),
|
|
104
|
-
idpHint,
|
|
105
|
-
redirectUri,
|
|
106
|
-
});
|
|
107
|
-
|
|
108
101
|
if (isMobile()) {
|
|
109
102
|
switch (idpHint) {
|
|
110
103
|
case 'google':
|
|
@@ -176,12 +169,6 @@ export const getAuthMethods = () => {
|
|
|
176
169
|
if (keycloak.value) {
|
|
177
170
|
clearTokens();
|
|
178
171
|
setTimeout(() => {
|
|
179
|
-
console.log('logout', {
|
|
180
|
-
keycloakRedirectUriIsLogout: keycloakRedirectUriIsLogout.value,
|
|
181
|
-
dontChangeRedirectUri: dontChangeRedirectUri.value,
|
|
182
|
-
redirectUri: redirectUri ?? getUrl(),
|
|
183
|
-
});
|
|
184
|
-
|
|
185
172
|
keycloak.value &&
|
|
186
173
|
keycloak.value.logout({
|
|
187
174
|
redirectUri: redirectUri ?? getUrl(),
|
|
@@ -303,26 +290,26 @@ export const isRtExp = () => {
|
|
|
303
290
|
}
|
|
304
291
|
};
|
|
305
292
|
|
|
306
|
-
const isPopup = () => {
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
};
|
|
293
|
+
// const isPopup = () => {
|
|
294
|
+
// console.log('run isPopup');
|
|
295
|
+
// // для авторизации в popup - это запускается в дочернем окне
|
|
296
|
+
// try {
|
|
297
|
+
// // Отправляем сообщение родителю
|
|
298
|
+
// if (window.opener) {
|
|
299
|
+
// console.log('window opener');
|
|
300
|
+
|
|
301
|
+
// window.opener.postMessage(
|
|
302
|
+
// {
|
|
303
|
+
// type: 'keycloak-auth-success',
|
|
304
|
+
// message: 'success',
|
|
305
|
+
// },
|
|
306
|
+
// '*'
|
|
307
|
+
// );
|
|
308
|
+
// }
|
|
309
|
+
// } catch (err) {
|
|
310
|
+
// console.warn('Error in login-popup-redirect.html:', err);
|
|
311
|
+
// }
|
|
312
|
+
// };
|
|
326
313
|
|
|
327
314
|
let isInitKeycloak = false;
|
|
328
315
|
|
|
@@ -334,18 +321,18 @@ export async function initKeycloak() {
|
|
|
334
321
|
if (!OPENID_REALM) throw new Error('Не задана переменная keycloak: realm');
|
|
335
322
|
if (!OPENID_CLIENT_ID) throw new Error('Не задана переменная keycloak: clientId');
|
|
336
323
|
|
|
337
|
-
console.log({
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
});
|
|
324
|
+
// console.log({
|
|
325
|
+
// OPENID_URL,
|
|
326
|
+
// OPENID_REALM,
|
|
327
|
+
// OPENID_CLIENT_ID,
|
|
328
|
+
|
|
329
|
+
// VITE_OPENID_URL: import.meta.env?.VITE_OPENID_URL,
|
|
330
|
+
// VITE_PUBLIC_KEYCLOAK_URL: import.meta.env?.VITE_PUBLIC_KEYCLOAK_URL,
|
|
331
|
+
// VITE_OPENID_REALM: import.meta.env?.VITE_OPENID_REALM,
|
|
332
|
+
// VITE_PUBLIC_KEYCLOAK_REALM: import.meta.env?.VITE_PUBLIC_KEYCLOAK_REALM,
|
|
333
|
+
// VITE_OPENID_CLIENT_ID: import.meta.env?.VITE_OPENID_CLIENT_ID,
|
|
334
|
+
// VITE_PUBLIC_KEYCLOAK_CLIENT_ID: import.meta.env?.VITE_PUBLIC_KEYCLOAK_CLIENT_ID,
|
|
335
|
+
// });
|
|
349
336
|
|
|
350
337
|
keycloak.value = new Keycloak({
|
|
351
338
|
url: OPENID_URL,
|
|
@@ -353,10 +340,6 @@ export async function initKeycloak() {
|
|
|
353
340
|
clientId: OPENID_CLIENT_ID,
|
|
354
341
|
});
|
|
355
342
|
|
|
356
|
-
console.log({
|
|
357
|
-
keycloak: keycloak.value,
|
|
358
|
-
});
|
|
359
|
-
|
|
360
343
|
const isNeedAuth = !!getToken() && !isRtExp();
|
|
361
344
|
|
|
362
345
|
// window.opener - если находимся в popup (но не в passport), то 100% уже авторизованы и можно поставить login-required
|
|
@@ -385,25 +368,15 @@ export async function initKeycloak() {
|
|
|
385
368
|
if (idToken) initOptions.idToken = idToken;
|
|
386
369
|
}
|
|
387
370
|
|
|
388
|
-
console.log({
|
|
389
|
-
initOptions,
|
|
390
|
-
});
|
|
391
|
-
|
|
392
371
|
try {
|
|
393
|
-
console.log('before keycloak init');
|
|
394
|
-
|
|
395
372
|
const res = await keycloak.value.init(initOptions);
|
|
396
373
|
|
|
397
|
-
console.log('after keycloak init', {
|
|
398
|
-
res,
|
|
399
|
-
});
|
|
400
|
-
|
|
401
374
|
setTokens();
|
|
402
375
|
|
|
403
376
|
if (res) {
|
|
404
377
|
//await keycloak.value.updateToken(70);
|
|
405
378
|
setTokens();
|
|
406
|
-
isPopup();
|
|
379
|
+
// isPopup();
|
|
407
380
|
keycloakUserData.value = keycloak.value?.tokenParsed ?? null;
|
|
408
381
|
isAuth.value = true;
|
|
409
382
|
try {
|
|
@@ -427,7 +400,7 @@ export async function initKeycloak() {
|
|
|
427
400
|
}
|
|
428
401
|
return isAuth.value;
|
|
429
402
|
} catch (error) {
|
|
430
|
-
console.
|
|
403
|
+
console.warn('Ошибка Keycloak:', error);
|
|
431
404
|
isAuth.value = false;
|
|
432
405
|
return false;
|
|
433
406
|
} finally {
|
|
@@ -457,8 +430,6 @@ let _keycloakInit: IUseKeycloak | null = null;
|
|
|
457
430
|
export const keycloakInit = (dontChangeRedirectUri?: Ref<boolean>, keycloakRedirectUriIsLogout?: Ref<string | undefined>): IUseKeycloak => {
|
|
458
431
|
if (_keycloakInit) return _keycloakInit;
|
|
459
432
|
|
|
460
|
-
console.log('>>>>> Lazy keycloakInit called');
|
|
461
|
-
|
|
462
433
|
dontChangeRedirectUri ||= inject('dontChangeRedirectUri', ref(false));
|
|
463
434
|
keycloakRedirectUriIsLogout ||= inject('keycloakRedirectUriIsLogout', ref(undefined));
|
|
464
435
|
|
|
@@ -475,8 +446,5 @@ export const keycloakInit = (dontChangeRedirectUri?: Ref<boolean>, keycloakRedir
|
|
|
475
446
|
isAtExp,
|
|
476
447
|
isRtExp,
|
|
477
448
|
};
|
|
478
|
-
|
|
479
|
-
console.log('@alfabit/keycloak fn keycloakInit', {_keycloakInit});
|
|
480
|
-
|
|
481
449
|
return _keycloakInit;
|
|
482
450
|
};
|
package/src/plugins/keycloak.ts
CHANGED
|
@@ -2,8 +2,6 @@ import { ref } from 'vue';
|
|
|
2
2
|
import { createKeycloakInit, getAuthMethods, keycloakInit } from '../composables';
|
|
3
3
|
|
|
4
4
|
export const useKeycloak = () => {
|
|
5
|
-
console.trace('Trace: useKeycloak');
|
|
6
|
-
console.log('@alfabit/keycloak fn useKeycloak');
|
|
7
5
|
const keycloak = keycloakInit(ref(false), ref(undefined));
|
|
8
6
|
const auth = getAuthMethods();
|
|
9
7
|
return {
|
|
@@ -13,13 +11,11 @@ export const useKeycloak = () => {
|
|
|
13
11
|
};
|
|
14
12
|
|
|
15
13
|
export const createKeycloak = () => {
|
|
16
|
-
console.log('@alfabit/keycloak fn createKeycloak');
|
|
17
14
|
createKeycloakInit();
|
|
18
15
|
};
|
|
19
16
|
|
|
20
17
|
export const keycloakPlugin = {
|
|
21
18
|
install() {
|
|
22
|
-
console.log('@alfabit/keycloak plugin install');
|
|
23
19
|
createKeycloak();
|
|
24
20
|
//app.config.globalProperties.$keycloak = useKeycloak();
|
|
25
21
|
},
|