Saya ingin mengirim email acara kalender google ke banyak pengguna melalui email mereka. Saat ini acara dibuat tetapi email tidak dikirim ke pengguna tamu yang telah kami tambahkan di acara ini. Jadi ingin mengirim email ke pengguna tamu saat acara dibuat. Jadi bisakah Anda membantu saya mengapa surat tidak terkirim?

require __DIR__ . '/vendor/autoload.php';

/*if (php_sapi_name() != 'cli') {
    throw new Exception('This application must be run on the command line.');
}*/

/**
 * Returns an authorized API client.
 * @return Google_Client the authorized client object
 */
function getClient()
{
    $client = new Google_Client();
    $client->setApplicationName('Google Calendar API PHP Quickstart');
    $client->setScopes(Google_Service_Calendar::CALENDAR);
    $client->setAuthConfig(__DIR__ .'/credentials.json');
    $client->setAccessType('offline');
    $client->setPrompt('select_account consent');

    // Load previously authorized token from a file, if it exists.
    // The file token.json stores the user's access and refresh tokens, and is
    // created automatically when the authorization flow completes for the first
    // time.
    $tokenPath = 'token.json';
    if (file_exists($tokenPath)) {
        $accessToken = json_decode(file_get_contents($tokenPath), true);
        $client->setAccessToken($accessToken);
    }

    // If there is no previous token or it's expired.
    if ($client->isAccessTokenExpired()) {
        // Refresh the token if possible, else fetch a new one.
        if ($client->getRefreshToken()) {
            $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
        } else {
            // Request authorization from the user.
            $authUrl = $client->createAuthUrl();
            printf("Open the following link in your browser:\n%s\n", $authUrl);
            print 'Enter verification code: ';
            $authCode = trim(fgets(STDIN));

            // Exchange authorization code for an access token.
            $accessToken = $client->fetchAccessTokenWithAuthCode($authCode);
            $client->setAccessToken($accessToken);

            // Check to see if there was an error.
            if (array_key_exists('error', $accessToken)) {
                throw new Exception(join(', ', $accessToken));
            }
        }
        // Save the token to a file.
        if (!file_exists(dirname($tokenPath))) {
            mkdir(dirname($tokenPath), 0700, true);
        }
        file_put_contents($tokenPath, json_encode($client->getAccessToken()));
    }
    return $client;
}


// Get the API client and construct the service object.
$client = getClient();
$service = new Google_Service_Calendar($client);

// Print the next 10 events on the user's calendar.
$calendarId = 'primary';
$optParams = array(
  'maxResults' => 10,
  'orderBy' => 'startTime',
  'singleEvents' => true,
  'timeMin' => date('c'),
);
$results = $service->events->listEvents($calendarId, $optParams);
$events = $results->getItems();

// Refer to the PHP quickstart on how to setup the environment:
// https://developers.google.com/calendar/quickstart/php
// Change the scope to Google_Service_Calendar::CALENDAR and delete any stored
// credentials.

$event = new Google_Service_Calendar_Event(array(
  'summary' => 'Test Event',
  'location' => 'Test Event',
  'description' => 'This is my test description',
  'start' => array(
    'dateTime' => '2020-05-21T04:02:00-04:00',
    'timeZone' => 'Asia/Kolkata',
  ),
  'end' => array(
    'dateTime' => '2020-05-22T16:05:00-07:00',
    'timeZone' => 'Asia/Kolkata',
  ),
  'recurrence' => array(
    'RRULE:FREQ=DAILY;COUNT=1'
  ),
  'attendees' => array(
    array('email' => 'lorit12866@frost2d.net'),
  ),
  'reminders' => array(
    'useDefault' => FALSE,
    'overrides' => array(
      array('method' => 'email', 'minutes' => 24 * 60),
      array('method' => 'popup', 'minutes' => 10),
    ),
  ),
));

$calendarId = 'primary';
$event = $service->events->insert($calendarId, $event, ['sendUpdates' => 'all']);
//$event = $service->events->insert($calendarId, $event);
printf('Event created: %s\n', $event->htmlLink);

Terima kasih sebelumnya!

-2
Gaurang Sondagar 3 Juli 2020, 13:30

1 menjawab

Jawaban Terbaik

Jika masalah Anda terkait dengan peserta yang tidak menerima pengingat 24 jam sebelum acara:

Ingatlah bahwa penimpaan pengingat default hanya berfungsi untuk pembuat acara.

Seperti yang dapat Anda verifikasi di bawah Properti acara pribadi:

Beberapa properti bersifat pribadi, seperti pengingat, colorId, transparansi, atau properti extendedProperties.private. Properti ini dikendalikan oleh pengaturan peserta dan bukan oleh kalender penyelenggara.

Dengan kata lain, peserta akan menerima (atau tidak menerima) pengingat sesuai dengan pengaturan mereka di kalender mereka, Anda tidak dapat memaksakan pengingat pada mereka.

Jika masalah Anda terkait dengan peserta yang tidak menerima pemberitahuan saat Anda membuat alarm:

  • Ingatlah bahwa Anda telah menentukan tanggal mulai dan berakhirnya acara di masa lalu
  • Pemberitahuan hanya akan dikirim saat Anda membuat acara yang sedang berlangsung di masa mendatang
1
ziganotschka 8 Juli 2020, 13:15