You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

35 lines
1.1 KiB

<script setup>
const randomString = (length) => {
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
let result = '';
for ( let i = 0; i < length; i++ )
result += characters.charAt(Math.floor(Math.random() * characters.length));
return result;
}
const params = new URLSearchParams();
params.append('response_type', 'code');
// eslint-disable-next-line
params.append('client_id', process.env.VUE_APP_SPOTIFY_CLIENT_ID);
// eslint-disable-next-line
params.append('redirect_uri', process.env.VUE_APP_SPOTIFY_REDIRECT_URI);
params.append('scope', 'user-read-email app-remote-control user-read-playback-state user-read-currently-playing user-modify-playback-state');
params.append('state', randomString(16));
const authUrl = 'https://accounts.spotify.com/authorize?' + params.toString();
</script>
<template>
<div>
<h1>Login</h1>
<div class="card">
<div class="card-header">
Authenticate with Spotify
</div>
<div class="card-body">
<a class="btn btn-primary" :href="authUrl">Authenticate</a>
</div>
</div>
</div>
</template>