forked from looker-open-source/sdk-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsudoAsUser.ts
103 lines (95 loc) · 3.35 KB
/
sudoAsUser.ts
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
/*
* The MIT License (MIT)
*
* Copyright (c) 2019 Looker Data Sciences, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
import {
NodeSettingsIniFile,
NodeSession,
Looker40SDK as LookerSDK,
IAuthSession
} from '@looker/sdk'
/**
*
* @type {string} Local configuration file name, one directory above
*/
const localConfig = '../looker.ini'
/**
*
* @type {NodeSettingsIniFile} Settings retrieved from the configuration file
*/
const settings = new NodeSettingsIniFile(localConfig, 'Looker')
/**
* Automatic authentication support for the Node SDK
* @type {NodeSession} Initialized node-based session manager
*/
const session = new NodeSession(settings)
/**
* Initialized SDK object
* @type {LookerSDK} SDK object configured for use with Node
*/
const sdk = new LookerSDK(session)
/**
*
* @type {string} email matching pattern for searching users
*/
const matchDomain = '%@looker.com'
/**
* Find a different user than the specified user
* @param {number} userId id to exclude from match
* @param {string} emailPattern email pattern for user search
* @returns {Promise<undefined | IUser>} Returns the first matched user, or undefined if no match
*/
const anyoneButMe = async (userId: number, emailPattern: string) => {
const all = await sdk.ok(
sdk.search_users({ email: emailPattern, page: 1, per_page: 2 })
)
if (!all || all.length === 0) {
console.warn(`No matches for ${emailPattern}`)
return undefined
}
// find a user who is not the specified user
const [other] = all.filter(u => u.id !== userId && !u.is_disabled).slice(0, 1)
return other
}
;(async () => {
const userFields =
'id, first_name, last_name, display_name, email, personal_space_id, home_space_id, group_ids, role_ids'
// retrieve your user account to verify correct credentials
const me = await sdk.ok(sdk.me(userFields))
if (!me) {
console.warn('API authentication failed')
return
}
console.log({ me })
const sudoUser = await anyoneButMe(me.id!, matchDomain)
if (sudoUser) {
const auth = sdk.authSession as IAuthSession
await auth.login(sudoUser.id)
const sudo = await sdk.ok(sdk.me(userFields))
console.log({ sudo })
await sdk.authSession.logout() // logout of sudo
}
await sdk.authSession.logout() // logout of API session
if (!sdk.authSession.isAuthenticated()) {
console.log('Logout successful')
}
})()