API Kalendar Google ialah alat yang berkuasa untuk mengurus acara dan menjadualkan mesyuarat secara pengaturcaraan. Tutorial ini akan membimbing anda menyepadukan API ke dalam aplikasi Node.js untuk mengendalikan pengesahan OAuth, mendapatkan semula token akses dan mencipta acara. Kami juga akan merangkumi pengendalian ubah hala dalam aplikasi bahagian hadapan untuk pengalaman pengguna yang lancar.
Langkah pertama ialah membenarkan pengguna membuat pengesahan dengan akaun Google mereka dan memberikan akses untuk mengurus kalendar mereka. Ini dicapai menggunakan protokol OAuth2.
Berikut ialah kaedah untuk menjana URL pengesahan OAuth2 Google:
async googleAuthConsent() { try { // Read credentials from a file const credentials = JSON.parse( await promisify(fs.readFile)('./client_secrets.json', 'utf-8'), ); // change this with your redirect url const REDIRECT_URI = "http://localhost:3000"; const oauth2Client = new google.auth.OAuth2( credentials.web.client_id, credentials.web.client_secret, REDIRECT_URI, ); const scopes = ['https://www.googleapis.com/auth/calendar']; const authUrl = oauth2Client.generateAuthUrl({ access_type: 'offline', scope: scopes, }); return { message: 'Auth URL created successfully', url: authUrl, }; } catch (error) { throw new Error(error.message || 'Internal Server Error'); } }
Selepas pengguna membuat pengesahan melalui URL yang dijana, mereka dihalakan semula ke aplikasi anda dengan kod. Kod ini ditukar dengan token.
async generateGoogleOAuthToken( data: { code: string; scope: string }, ) { try { const { code } = data; const credentials = JSON.parse( await promisify(fs.readFile)('./client_secrets.json', 'utf-8'), ); // change this with your redirect url const REDIRECT_URI = "http://localhost:3000"; const oauth2Client = new google.auth.OAuth2( credentials.web.client_id, credentials.web.client_secret, REDIRECT_URI, ); const { tokens } = await oauth2Client.getToken(code); // your logic for storing token i.g. database or file return { message: 'User OAuth Token Generated Successfully', token, }; } catch (error) { throw new Error(error.message || 'Internal Server Error'); } }
Dengan token yang disimpan dengan selamat, anda kini boleh menggunakan API Kalendar Google untuk membuat acara. Di bawah ialah kaedah generik untuk menjadualkan mesyuarat, lengkap dengan butiran acara seperti masa, hadirin, peringatan dan pautan Google Meet pilihan.
Kaedah ini mencapai perkara berikut:
async googleAuthConsent() { try { // Read credentials from a file const credentials = JSON.parse( await promisify(fs.readFile)('./client_secrets.json', 'utf-8'), ); // change this with your redirect url const REDIRECT_URI = "http://localhost:3000"; const oauth2Client = new google.auth.OAuth2( credentials.web.client_id, credentials.web.client_secret, REDIRECT_URI, ); const scopes = ['https://www.googleapis.com/auth/calendar']; const authUrl = oauth2Client.generateAuthUrl({ access_type: 'offline', scope: scopes, }); return { message: 'Auth URL created successfully', url: authUrl, }; } catch (error) { throw new Error(error.message || 'Internal Server Error'); } }
Untuk mengendalikan ubah hala selepas pengesahan Google, bahagian hadapan hendaklah:
Contoh aliran:
Penyepaduan ini ialah langkah pertama ke arah membina ciri penjadualan yang berkuasa dalam aplikasi NodeJS anda. Bahagian seterusnya akan merangkumi kaedah penciptaan acara generik. Digabungkan dengan bahagian hadapan untuk interaksi pengguna, anda boleh mencipta penyelesaian penjadualan yang mantap dengan usaha yang minimum.
Nantikan pelaksanaan lengkap dan panduan pengurusan acara!
Jika anda ingin melihat tutorial video ini sila komen di bawah!
Atas ialah kandungan terperinci Mengintegrasikan API Kalendar Google dalam Node.JS: Panduan untuk Penciptaan Acara dan Penjadualan Mesyuarat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!