This repository has been archived by the owner on May 2, 2018. It is now read-only.
forked from vejlebib/migrate_ding1_ding2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmigrate_ding1_ding2.migrate.inc
99 lines (86 loc) · 3.2 KB
/
migrate_ding1_ding2.migrate.inc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
/*
* You must implement hook_migrate_api(), setting the API level to 2, if you are
* implementing any migration classes. As of Migrate 2.5, you should also
* register your migration and handler classes explicitly here - the former
* method of letting them get automatically registered on a cache clear will
* break in certain environments (see http://drupal.org/node/1778952).
*/
function migrate_ding1_ding2_migrate_api() {
$api = array(
'api' => 2,
'groups' => array(
'ding1_group' => array(
'title' => t('Ding1 Group'),
),
),
'migrations' => array(
// Node types
'DingCampaign' => array('class_name' => 'DingCampaignMigration'),
'DingEvent' => array('class_name' => 'DingEventMigration'),
'DingLibrary' => array('class_name' => 'DingLibraryMigration'),
'DingNews' => array('class_name' => 'DingNewsMigration'),
'DingPage' => array('class_name' => 'DingPageMigration'),
// User profiles
'DingRole' => array('class_name' => 'DingRoleMigration'),
'DingUser' => array('class_name' => 'DingUserMigration'),
'DingProfileProviderAlma' => array('class_name' => 'DingProfileProviderAlmaMigration'),
'DingProfileStaff' => array('class_name' => 'DingProfileStaffMigration'),
// Taxonomies
'DingEventCategoryTerm' => array('class_name' => 'DingEventCategoryTermMigration'),
'DingEventTargetTerm' => array('class_name' => 'DingEventTargetTermMigration'),
'DingNewsCategoryTerm' => array('class_name' => 'DingNewsCategoryTermMigration'),
'DingTagsTerm' => array('class_name' => 'DingTagsTermMigration'),
// Tables
'DingPlace2book' => array('class_name' => 'DingPlace2bookMigration'),
'DingOpeningHours' => array('class_name' => 'DingOpeningHoursMigration'),
'DingAuthmap' => array('class_name' => 'DingAuthmapMigration'),
// Miscellaneous
'DingFile' => array('class_name' => 'DingFileMigration'),
'DingBookmark' => array('class_name' => 'DingBookmarkMigration'),
),
'field handlers' => array(
'DateMigrateFieldHandler',
),
);
return $api;
}
/*
* Function to insert a new ting_object into the database.
*
* Return value: the tid of the created ting_object.
*
* TO DO: This is not the drupal way of creating a new ting_object entity a should be replaced by the proper calls.
*/
function migrate_ding1_ding2_add_ting_object($ting_id) {
// if ting_object already exists, return the tid
$result = db_query('SELECT t.tid FROM {ting_object} t WHERE t.ding_entity_id = :entid', array(':entid' => $ting_id));
$tid = $result->fetchField();
if ($tid) {
return $tid;
}
// open transaction
$transaction = db_transaction();
try {
$tid = db_insert('ting_object')
->fields(array(
'ding_entity_id' => $ting_id,
))
->execute();
$vid = db_insert('ting_object_revision')
->fields(array(
'tid' => $tid,
'timestamp' => 0,
))
->execute();
db_update('ting_object')
->condition('tid', $tid)
->fields(array('vid' => $vid))
->execute();
}
catch (Exception $e) {
$transaction->rollback();
watchdog_exception('migrate_ding1_ding2', $e);
}
return $tid;
}