2022-03-15 18:00:53 +00:00
// (c) Copyright Ascensio System SIA 2010-2022
//
// This program is a free software product.
// You can redistribute it and/or modify it under the terms
// of the GNU Affero General Public License (AGPL) version 3 as published by the Free Software
// Foundation. In accordance with Section 7(a) of the GNU AGPL its Section 15 shall be amended
// to the effect that Ascensio System SIA expressly excludes the warranty of non-infringement of
// any third-party rights.
//
// This program is distributed WITHOUT ANY WARRANTY, without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For details, see
// the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
//
// You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia, EU, LV-1021.
//
// The interactive user interfaces in modified source and object code versions of the Program must
// display Appropriate Legal Notices, as required under Section 5 of the GNU AGPL version 3.
//
// Pursuant to Section 7(b) of the License you must retain the original Product logo when
// distributing the program. Pursuant to Section 7(e) we decline to grant you any rights under
// trademark law for use of our trademarks.
//
// All the Product's GUI elements, including illustrations and icon sets, as well as technical writing
// content are licensed under the terms of the Creative Commons Attribution-ShareAlike 4.0
// International. See the License terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
2022-02-09 18:49:52 +00:00
namespace ASC.Data.Backup.Tasks.Modules ;
public class CalendarModuleSpecifics : ModuleSpecificsBase
2020-05-20 15:14:44 +00:00
{
2022-02-09 18:49:52 +00:00
public override ModuleName ModuleName = > ModuleName . Calendar ;
public override IEnumerable < TableInfo > Tables = > _tables ;
public override IEnumerable < RelationInfo > TableRelations = > _tableRelations ;
2020-08-27 14:01:37 +00:00
2022-02-09 18:49:52 +00:00
private readonly RelationInfo [ ] _tableRelations ;
private readonly TableInfo [ ] _tables = new [ ]
{
2022-02-09 18:33:50 +00:00
new TableInfo ( "calendar_calendars" , "tenant" , "id" ) { UserIDColumns = new [ ] { "owner_id" } } ,
new TableInfo ( "calendar_calendar_item" ) ,
new TableInfo ( "calendar_calendar_user" ) { UserIDColumns = new [ ] { "user_id" } } ,
new TableInfo ( "calendar_events" , "tenant" , "id" )
2020-05-20 15:14:44 +00:00
{
2022-02-09 18:33:50 +00:00
UserIDColumns = new [ ] { "owner_id" } ,
DateColumns = new Dictionary < string , bool > { { "start_date" , true } , { "end_date" , true } }
} ,
new TableInfo ( "calendar_event_history" , "tenant" ) ,
new TableInfo ( "calendar_event_item" ) ,
new TableInfo ( "calendar_event_user" ) { UserIDColumns = new [ ] { "user_id" } } ,
new TableInfo ( "calendar_notifications" , "tenant" )
{
UserIDColumns = new [ ] { "user_id" } ,
DateColumns = new Dictionary < string , bool > { { "notify_date" , true } }
}
2022-02-09 18:49:52 +00:00
} ;
2020-05-26 08:52:47 +00:00
2022-02-09 18:49:52 +00:00
public CalendarModuleSpecifics ( Helpers helpers )
: base ( helpers )
{
_tableRelations = new [ ]
2020-05-26 08:52:47 +00:00
{
2020-05-20 15:14:44 +00:00
new RelationInfo ( "calendar_calendars" , "id" , "calendar_calendar_item" , "calendar_id" ) ,
new RelationInfo ( "calendar_calendars" , "id" , "calendar_calendar_user" , "calendar_id" ) ,
new RelationInfo ( "calendar_calendars" , "id" , "calendar_events" , "calendar_id" ) ,
new RelationInfo ( "calendar_calendars" , "id" , "calendar_event_history" , "calendar_id" ) ,
new RelationInfo ( "calendar_events" , "id" , "calendar_event_history" , "event_id" ) ,
new RelationInfo ( "calendar_events" , "id" , "calendar_event_item" , "event_id" ) ,
new RelationInfo ( "calendar_events" , "id" , "calendar_event_user" , "event_id" ) ,
new RelationInfo ( "calendar_events" , "id" , "calendar_notifications" , "event_id" ) ,
2020-05-26 08:52:47 +00:00
new RelationInfo ( "core_user" , "id" , "calendar_calendar_item" , "item_id" , typeof ( TenantsModuleSpecifics ) ,
2020-05-20 15:14:44 +00:00
x = > Convert . ToInt32 ( x [ "is_group" ] ) = = 0 ) ,
2020-05-26 08:52:47 +00:00
new RelationInfo ( "core_group" , "id" , "calendar_calendar_item" , "item_id" , typeof ( TenantsModuleSpecifics ) ,
x = > Convert . ToInt32 ( x [ "is_group" ] ) = = 1 & & ! helpers . IsEmptyOrSystemGroup ( Convert . ToString ( x [ "item_id" ] ) ) ) ,
new RelationInfo ( "core_user" , "id" , "calendar_event_item" , "item_id" , typeof ( TenantsModuleSpecifics ) ,
2020-05-20 15:14:44 +00:00
x = > Convert . ToInt32 ( x [ "is_group" ] ) = = 0 ) ,
2020-05-26 08:52:47 +00:00
new RelationInfo ( "core_group" , "id" , "calendar_event_item" , "item_id" , typeof ( TenantsModuleSpecifics ) ,
x = > Convert . ToInt32 ( x [ "is_group" ] ) = = 1 & & ! helpers . IsEmptyOrSystemGroup ( Convert . ToString ( x [ "item_id" ] ) ) )
2020-05-20 15:14:44 +00:00
} ;
2022-02-09 18:49:52 +00:00
}
2020-05-20 15:14:44 +00:00
2022-02-09 18:49:52 +00:00
protected override string GetSelectCommandConditionText ( int tenantId , TableInfo table )
{
if ( table . Name = = "calendar_calendar_item" | | table . Name = = "calendar_calendar_user" )
2020-05-20 15:14:44 +00:00
{
2022-02-09 18:49:52 +00:00
return "inner join calendar_calendars as t1 on t1.id = t.calendar_id where t1.tenant = " + tenantId ;
}
2020-05-20 15:14:44 +00:00
2022-02-09 18:49:52 +00:00
if ( table . Name = = "calendar_event_item" | | table . Name = = "calendar_event_user" )
{
return "inner join calendar_events as t1 on t1.id = t.event_id where t1.tenant = " + tenantId ;
}
2020-05-20 15:14:44 +00:00
2022-02-09 18:49:52 +00:00
if ( table . Name = = "calendar_event_history" )
{
return string . Format (
"inner join calendar_calendars as t1 on t1.id = t.calendar_id and t1.tenant = t.tenant inner join calendar_events as t2 on t2.id = t.event_id where t1.tenant = {0} and t2.tenant = {0}" ,
tenantId ) ;
2020-05-20 15:14:44 +00:00
}
2022-02-09 18:49:52 +00:00
return base . GetSelectCommandConditionText ( tenantId , table ) ;
2020-05-20 15:14:44 +00:00
}
}