Skip to content

Office.Cloud.Google.Calendar

apobekiaris edited this page Sep 22, 2020 · 8 revisions

GitHub issues GitHub close issues

About

The Google.Calendar package integrates with the Google Calendar cloud service.

Details


Credits: to Brokero that sponsor the initial implementation of this module.


This is a platform agnostic module that authenticates against Google using the Xpand.XAF.Modules.Google package, for details head to it's wiki page.

The Xpand.XAF.Modules.Office.Cloud.Google.Calendar provides a configurable two way synchronization between the IEvent Domain Components and the Google.Apis.Calendar.v3.Event entity. All CRUD operations will execute the cloud api after a successful XAF transaction.

You can use the model to configure:

  • The subject Views, the target container Calendar and which Domain Component should be created when a NewCloudEvent. image
  • The CRUD SynchronizationType and the CallDirection. image

The package can operate without any configuration by executing a predefined map between the IEvent and Google.Apis.Calendar.v3.Event objects on Update and on Insert for both incoming and outgoing calls.

To customize the predefined map you can use a query like the next one which suffix the Google.Apis.Calendar.v3.Event subject with the current date:

CalendarService.CustomizeSynchronization
    .Do(e => {
        var tuple = e.Instance;
        if (tuple.mapAction != MapAction.Delete){
            if (tuple.callDirection == CallDirection.In){
                tuple.local.Subject = $"{tuple.cloud.Subject} - {DateTime.Now}";
            }
            else if (tuple.callDirection == CallDirection.Out){
                tuple.cloud.Subject = $"{tuple.local.Subject} - {DateTime.Now}";
            }
            e.Handled = true;
        }
    })
    .Subscribe();

Cloud to local synchronization: The package track changes using synchronization tokens.

The first time the run method is called it will perform a full sync and store the sync token. On each subsequent execution it will load the saved sync token and perform an incremental sync.

Possible future improvements:

Any other need you may have.

Let me know if you want me to implement them for you.


Examples

In the next screencast you can see all CRUD operations on the Event BO and how they synchronize with the Office365 Calendar, for both platforms Win, Web and both directions Incoming, Outgoing. At the bottom the Reactive.Logger.Client.Win is reporting as the module is used.

Xpand XAF Modules Office Cloud Google Calendar

image

Installation

  1. First you need the nuget package so issue this command to the VS Nuget package console

    Install-Package Xpand.XAF.Modules.Office.Cloud.Google.Calendar.

    The above only references the dependencies and next steps are mandatory.

  2. Ways to Register a Module or simply add the next call to your module constructor

    RequiredModuleTypes.Add(typeof(Xpand.XAF.Modules.Office.Cloud.Google.CalendarModule));

Versioning

The module is not bound to DevExpress versioning, which means you can use the latest version with your old DevExpress projects Read more.

The module follows the Nuget Version Basics.

Dependencies

.NetFramework: net461

DevExpress.Persistent.Base Any
DevExpress.ExpressApp Any
DevExpress.ExpressApp.Xpo Any
Fasterflect.Xpand 2.0.7
Google.Apis.Auth 1.49.0
Google.Apis.Calendar.v3 1.49.0.2049
JetBrains.Annotations 2020.1.0
Newtonsoft.Json 12.0.3
System.Reactive 4.4.1
Xpand.Extensions 2.202.50.1
Xpand.Extensions.Office.Cloud 2.202.51.3
Xpand.Extensions.Reactive 2.202.51.3
Xpand.Extensions.XAF 2.202.51.3
Xpand.Extensions.XAF.Xpo 2.202.47.1
Xpand.XAF.Modules.Office.Cloud.Google 2.202.12.4
Xpand.XAF.Modules.Reactive 2.202.51.4
Xpand.VersionConverter 2.202.10

Issues-Debugging-Troubleshooting

To Step in the source code you need to enable Source Server support in your Visual Studio/Tools/Options/Debugging/Enable Source Server Support. See also How to boost your DevExpress Debugging Experience.

If the package is installed in a way that you do not have access to uninstall it, then you can unload it with the next call at the constructor of your module.

Xpand.XAF.Modules.Reactive.ReactiveModuleBase.Unload(typeof(Xpand.XAF.Modules.Office.Cloud.Google.Calendar.Office.Office.Cloud.Google.CalendarModule))

Tests

The module is tested on Azure for each build with these tests. All Tests run as per our Compatibility Matrix

image

image


Custom badge

Star the project if you think it deserves it.

GitHub stars

Fork the project to extend and contribute.

GitHub forks

Clone this wiki locally