Flower Reminder is the simple way to surprise your partner with some flowers by creating random entries in your Google calendar. For example, if you want to surprise you partner with flowers two times within three months for the complete year, you can use Flower Reminder to create these events in you Google calendar.
Things you need to use Flower Reminder.
- A Google developer account
- A Google calendar (I used a dedicated one)
- Some machine which runs PHP, git, composer, etc. to run the application
- Download the latest version of Flower Reminder
- Run
composer install -o --no-dev
- Run the application with:
php bin/flower-reminder
- Goto
https://console.developers.google.com
and login with your credentials - Create a new project
- Activate the Google Calendar API
- Select the API and create new credentials for it (Select Application data and that you don't use GCE, GKE, etc)
- Add a name for the service account
- Copy the email address which will be generated below the service id
- Add the role owner to the service account
- Open the new generated service account by clicking on the email
- Got to the keys tab and generate a new json key
- Save the new key-file.json to
flower-reminder/config/
The most difficult part is now done. In the next step we connect the new developer project with a new calendar.
- Goto
https://calendar.google.com/
and login with your credentials - Goto to the Settings Menu and create a new calendar (I called mine Flower Reminder)
- Share the new calendar with the generated service account id email address you copied in step 6 of the Google developer account creation and assign the privileges to edit events
With that done, every application which has the key-file.json can now create entries in your new shared calendar. Last not least we will configure some details in Flower Reminder so that the new calendar entries look and behave like we expected them to do.
service_account_file
: The name of the key-file.jsoncalendar_event_msg
: The event name which is displayed in the calendarcalendar_event_msg_description
: The event descriptioncalendar_event_starttime
: The start time of the event hh:mm:sscalendar_event_endtime
: The end time of the event hh:mm:sscalendar_event_reminder_mail
: The reminder e-mail addresscalendar_event_reminder_in_minutes
: The time the event will be announced
That's it. The configuration is done and Flower Reminder is ready to go.
Use the list command to get the calendar id of the prepared Google Calendar
php bin/flower-reminder reminder:calendar:list
----------------- ------------------------------------------------------
Calendar id
----------------- ------------------------------------------------------
Flower Reminder averylongidgenratedbygoogle@group.calendar.google.com
----------------- ------------------------------------------------------
Use the dummy command to verify the function of the flower reminder and the communication with Google. It will generate a calendar event on November 3rd 10am-10:25am for the current year
php bin/flower-reminder reminder:calendar:create:dummy averylongidgenratedbygoogle@group.calendar.google.com
[OK] Event with id 94hsajdfjksdfkfggnvk created
Use the random command to create random events in your Google calendar based on the default settings which are: Two reminder in three months, four times in row ( aka. one year).
You can customize several settings like start date, intervals, etc. by using the following options.
Options:
--startdate[=STARTDATE] The start date for the random event generation (default: now) [default: "2016-10-16 22:34:40"]
--interval-in-months[=INTERVAL-IN-MONTHS] The count of months for one interval (defalut: 3) [default: 3]
--remindings-per-interval[=REMINDINGS-PER-INTERVALL] The count of reminder per interval (default: 2) [default: 2]
--intervals[=INTERVALS] The loop of intervals (default: 4) [default: 4]
--multiple-reminders-per-month[=MULTIPLE-REMINDERS-PER-MONTH] Allow multiple reminder in a single month (default: 0) [default: 0]
php bin/flower-reminder reminder:calendar:create:random averylongidgenratedbygoogle@group.calendar.google.com
! [NOTE] Creating random events
8/8 [============================] 100%
! [NOTE] Listing events
---------------------------- ---------------
Event Id Calendar Date
---------------------------- ---------------
3375oij0eurngq9ii01hmvlv5g 2016-10-24
peb90kebecdhsrtr6siaafv4f4 2016-12-02
t4hvp94r2tu0jhu670c6oeri1o 2017-01-23
cca0podk0goi2u6kk3u9hd8l28 2017-03-23
pmc92icqg9t12nirrqfdk7ac04 2017-05-22
uiavo9ju71c5ui7j5moqcopmn0 2017-06-19
vt9te7qle5cafel5glugj1mobg 2017-07-31
s7r468qfna1886ue7l3olh3hio 2017-08-06
---------------------------- ---------------
[OK] Events created
- Run
composer install
- Run
php vendor/bin/phpunit tests/