This repository has been archived by the owner on Nov 30, 2022. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 376
/
Copy pathtoken_handler.blade.php
61 lines (53 loc) · 2.09 KB
/
token_handler.blade.php
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
<script data-turbolinks-eval="false">
var SESSION_TOKEN_REFRESH_INTERVAL = {{ \Osiset\ShopifyApp\Util::getShopifyConfig('session_token_refresh_interval') }};
var LOAD_EVENT = '{{ \Osiset\ShopifyApp\Util::getShopifyConfig('turbo_enabled') ? 'turbolinks:load' : 'DOMContentLoaded' }}';
// Token updates
document.addEventListener(LOAD_EVENT, () => {
retrieveToken(app);
keepRetrievingToken(app);
});
// Retrieve session token
async function retrieveToken(app) {
window.sessionToken = await utils.getSessionToken(app);
// Update everything with the session-token class
Array.from(document.getElementsByClassName('session-token')).forEach((el) => {
if (el.hasAttribute('value')) {
el.value = window.sessionToken;
el.setAttribute('value', el.value);
} else {
el.dataset.value = window.sessionToken;
}
});
const bearer = `Bearer ${window.sessionToken}`;
if (window.jQuery) {
// jQuery
if (window.jQuery.ajaxSettings.headers) {
window.jQuery.ajaxSettings.headers['Authorization'] = bearer;
} else {
window.jQuery.ajaxSettings.headers = { 'Authorization': bearer };
}
}
if (window.Livewire) {
// livewire
window.livewire.addHeaders({
'Authorization': bearer,
'content-type': 'application/json',
'X-Requested-With': 'XMLHttpRequest'
});
}
if (window.axios) {
// Axios
window.axios.defaults.headers.common['Authorization'] = bearer;
}
}
// Keep retrieving a session token periodically
function keepRetrievingToken(app) {
setInterval(() => {
retrieveToken(app);
}, SESSION_TOKEN_REFRESH_INTERVAL);
}
document.addEventListener('turbolinks:request-start', (event) => {
var xhr = event.data.xhr;
xhr.setRequestHeader('Authorization', `Bearer ${window.sessionToken}`);
});
</script>