-
Notifications
You must be signed in to change notification settings - Fork 2
/
table.inc
184 lines (148 loc) · 5.9 KB
/
table.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
<?php
/**
* Common mappings for table migrations.
*/
abstract class DingTableMigration extends Migration {
public function __construct($arguments) {
parent::__construct($arguments);
// With migrate_ui enabled, migration pages will indicate people involved in
// the particular migration, with their role and contact info. We default the
// list in the shared class; it can be overridden for specific migrations.
$this->team = array(
new MigrateTeamMember('Ewan Andreasen', 'ea@vejlebib.dk', t('Webdeveloper (Ding1 -> Ding2 Migration)')),
);
$this->description = $arguments['description'];
$this->dependencies = $arguments['dependencies'];
$this->sourceConnection = 'legacy';
$this->machine_name = $arguments['machine_name'];
$this->source_table = $arguments['source_table'];
$this->destination_table = $arguments['destination_table'];
$this->source_key = $arguments['source_key'];
$this->source = new MigrateSourceSQL($this->query());
$this->destination = new MigrateDestinationTable($this->destination_table);
$this->map = new MigrateSQLMap(
$this->machineName,
$this->source_key,
MigrateDestinationTable::getKeySchema($this->destination_table)
);
}
protected function query() {
$query = Database::getConnection('default', $this->sourceConnection)
->select($this->source_table, 't')
->fields('t');
return $query;
}
}
class DingPlace2bookMigration extends DingTableMigration {
public function __construct($arguments) {
$arguments = array(
'description' => t('Migration of ding_place2book table from Ding1/D6'),
'machine_name' => 'DingPlace2book',
'group_name' => 'ding1_group',
'source_table' => 'ding_place2book',
'destination_table' => 'ding_place2book',
'dependencies' => array('DingEvent'),
'source_key' => array(
'nid' => array(
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'description' => 'Source node ID of related event node',
'alias' => 't',
)
),
);
parent::__construct($arguments);
$this->addSimpleMappings(array('place2book_id', 'capacity', 'maintain_copy', 'kultunaut_export', 'passive'));
$this->addFieldMapping('nid', 'nid')
->sourceMigration('DingEvent');
}
protected function query() {
$query = parent::query();
// To avoid errors coming from event nodes that does not exist,
// we join with the node table adding the condition that node id must not be null
$query->leftJoin('node', 'n', 't.nid=n.nid');
$query->isNotNull('n.nid');
return $query;
}
}
class DingOpeningHoursMigration extends DingTableMigration {
public function __construct($arguments) {
$arguments = array(
'description' => t('Migration of opening_hours table from Ding1/D6'),
'machine_name' => 'DingOpeningHours',
'group_name' => 'ding1_group',
'source_table' => 'opening_hours',
'destination_table' => 'opening_hours',
'dependencies' => array('DingLibrary'),
'source_key' => array(
'instance_id' => array(
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'description' => 'ID of opening hours instance',
'alias' => 't',
)
),
);
parent::__construct($arguments);
$this->addSimpleMappings(array('instance_id', 'date', 'start_time', 'end_time', 'notice', 'repeat_rule', 'repeat_end_date', 'original_instance_id', 'customised'));
$this->addFieldMapping('nid', 'nid')
->sourceMigration('DingLibrary');
/*
$this->addFieldMapping('instance_id')
->description(t('Let instance_id count up itself on the destination'));
$this->addFieldMapping(NULL, 'instance_id')
->description(t('Let instance_id count up itself on the destination'));
// Unmapped source fields
$this->addUnmigratedSources(array('instance_id'));
*/
// Unmapped destination fields
$this->addUnmigratedDestinations(array('category_tid'));
}
public function prepareRow($row) {
// Always include this snippet, in case our parent class decides to ignore the row
if (parent::prepareRow($row) === FALSE) {
return FALSE;
}
// Fix repeat end dates that were incorrectly set as 0000-00-00 by inserting today 20 years in the future
if ($row->repeat_end_date == '0000-00-00') {
$row->repeat_end_date = date('Y-m-d', strtotime('+20 years'));
// Logging
watchdog('migrate_ding1_ding2', 'Fixing repeat_end_date of 0000-00-00 by setting it to future date %date', array('%date'=>$row->repeat_end_date), WATCHDOG_INFO);
}
}
}
class DingAuthmapMigration extends DingTableMigration {
public function __construct($arguments) {
$arguments = array(
'description' => t('Migration of authmap table from Ding1/D6'),
'machine_name' => 'DingAuthmap',
'group_name' => 'ding1_group',
'source_table' => 'authmap',
'destination_table' => 'authmap',
'dependencies' => array('DingUser'),
'source_key' => array(
'uid' => array(
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'description' => 'Source User ID',
'alias' => 't',
)
),
);
parent::__construct($arguments);
$this->addSimpleMappings(array('authname'));
// In D7/Ding2, it is ding_user module that handles authentication for external users,
// so we set module to ding_user when migrating authmap table
$this->addFieldMapping('module')
->defaultValue('ding_user');
$this->addFieldMapping('uid', 'uid')
->sourceMigration('DingUser');
// Unmapped source fields
$this->addUnmigratedSources(array('aid', 'module'));
// Unmapped destination fields
$this->addUnmigratedDestinations(array('aid'));
}
}