-
Notifications
You must be signed in to change notification settings - Fork 3
/
versioncontrol.install
648 lines (612 loc) · 30.7 KB
/
versioncontrol.install
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
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
<?php
// $Id$
/**
* @file
* Version Control API - An interface to version control systems
* whose functionality is provided by pluggable back-end modules.
*
* Copyright 2006 by Karthik ("Zen", http://drupal.org/user/21209)
* Copyright 2006, 2007 by Derek Wright ("dww", http://drupal.org/user/46549)
* Copyright 2007, 2008, 2009 by Jakob Petsovits ("jpetso", http://drupal.org/user/56020)
*/
/**
* Implementation of hook_schema().
*/
function versioncontrol_schema() {
$schema['versioncontrol_operations'] = array(
'description' => 'The combined table for commit, branch and tag operations.',
'fields' => array(
'vc_op_id' => array(
'description' => 'Unique identifier for each operation in this table. Does not necessarily correspond to chronological order in any way.',
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
),
'type' => array(
'description' =>
'Operation type as specified by the backend: either of VERSIONCONTROL_OPERATION_COMMIT, VERSIONCONTROL_OPERATION_BRANCH or VERSIONCONTROL_OPERATION_TAG. (For version control systems like Subversion that need to emulate branches and tags, this will still be VERSIONCONTROL_OPERATION_COMMIT - the "intended" meaning is stored as associated label action.)',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'repo_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_repositories}.repo_id) for the repository that was affected by the operation.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'date' => array(
'description' => 'Date/time when the operation was executed, as Unix timestamp.',
'type' => 'int',
'size' => 'big',
'not null' => TRUE,
'default' => 0,
),
'uid' => array(
'description' =>
'The {users}.uid for the Drupal user corresponding to the VCS-specific username in {versioncontrol_operations}.username, if such an association can be found. 0 otherwise. (The account associations are retrieved from the {versioncontrol_accounts} table.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'username' => array(
'description' => 'VCS specific username of the user who executed this operation. For distributed version control systems, this should be the author, not the committer.',
'type' => 'varchar',
'length' => 64,
'not null' => TRUE,
'default' => '',
),
'revision' => array(
'description' =>
'VCS specific global revision identifier, like "1234" for Subversion or some SHA-1 hash for various distributed version control systems. Empty string if the VCS does not support atomic commits / global revisions.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'message' => array(
'description' =>
'Log message. Might be empty for branch and tag operations, depending on the version control system\'s capabilities. Should really not be empty for commit messages, except for the super-evil case when the commit author is sloppy enough not to enter one *and* the VCS allows that to happen.',
'type' => 'text',
'not null' => FALSE,
),
),
'indexes' => array(
'type' => array('type'),
'repo_id' => array('repo_id'),
'date' => array('date'),
'uid' => array('uid'),
'username' => array('username'),
'revision' => array('revision'),
),
'primary key' => array('vc_op_id'),
);
$schema['versioncontrol_operation_labels'] = array(
'description' =>
'This table contains information about which branches and/or tags (= labels, referred to by the label_id) have been affected by an operation (vc_op_id), and how they\'ve been affected (action). Let\'s refer to that combination as "label action".
Commit operations might not have any label associated, which happens e.g. for SVN commits outside of /trunk, /tags and /branches (or if labels are neither natively supported nor emulated).
Possible label actions are:
- Commit: commit operation, label is a branch, action == VERSIONCONTROL_ACTION_MODIFIED
- Native branch/tag creation: branch or tag operation, label has the
same type as the operation, action == VERSIONCONTROL_ACTION_ADDED
- Native branch/tag deletion: branch or tag operation, label has the
same type as the operation, action == VERSIONCONTROL_ACTION_DELETED
- Emulated branch/tag creation or deletion (think of SVN branches and
tags): commit operation, any label type, action is the same as for
native creations/deletions.',
'fields' => array(
'vc_op_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_operations}.vc_op_id) for the operation that affected the given label(s).',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'label_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_labels}.label_id) for the affected label.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'action' => array(
'description' =>
'Specifies how the label was affected, see the {versioncontrol_operation_labels} table description for details on the semantics. Possible values are VERSIONCONTROL_ACTION_MODIFIED, VERSIONCONTROL_ACTION_ADDED and VERSIONCONTROL_ACTION_DELETED.',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
),
'primary key' => array('vc_op_id', 'label_id'),
);
$schema['versioncontrol_labels'] = array(
'description' =>
'This table stores information about branches and tags (= labels) that exist in a repository. While there might be multiple operations involving the same branch/tag (see also {versioncontrol_operation_labels}, e.g. "create DRUPAL-6--1-0 tag for the files in project 1", "create DRUPAL-6--1-0 tag for the files in project 2", "delete DRUPAL-6--1-0 tag for the files in project 2 again"), there is only one row in this table that represents this label ("DRUPAL-6--1-0" in the above example).',
'fields' => array(
'label_id' => array(
'description' => 'Unique identifier for a branch or tag in this label, equivalent to the (also unique) repo_id/name/type combination in the same row.',
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
),
'repo_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_repositories}.repo_id) for the repository that this label is located in.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'name' => array(
'description' => 'Name of the label, e.g. "HEAD", "master", "DRUPAL-6--1" or "6.x-1.0".',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'type' => array(
'description' =>
'Whether this label is a branch or a tag. Consequently, this can be either VERSIONCONTROL_OPERATION_BRANCH or VERSIONCONTROL_OPERATION_TAG. (If we went for total correctness, it would have been VERSIONCONTROL_LABEL_{BRANCH,TAG} but I fear the confusion coming out of two similar constants. Therefore, reusing the operation constants.)',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
),
'unique keys' => array(
'repo_id_name_type' => array('repo_id', 'name', 'type'),
),
'primary key' => array('label_id'),
);
$schema['versioncontrol_operation_items'] = array(
'description' =>
'This table relates an operation to the items (or more correctly, to the item revisions) that it affected. For example, an SVN commit with revision "1234" might modify an item that is now /trunk/file.txt at revision "1234", and move a directory from somewhere else that is now /trunk/dir at revision "1234". Those items are recorded here along with the vc_op_id that describes the general operation properties.
Branch/tag operations that affect the whole repository (like in Git or Mercurial) do not have items associated, whereas branch/tag operations that affect only a limited set of items (like in CVS or Subversion) link to the branched/tagged items with this table.',
'fields' => array(
'vc_op_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_operations}.vc_op_id) for the operation that affected the given item(s).',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'item_revision_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_item_revisions}.item_revision_id) for the affected item revision.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'type' => array(
'description' =>
'Real member or cached item. This is an implementation detail of a performance optimization (for queries with a "paths" constraint), and private to the API module. Other modules must not touch this. VERSIONCONTROL_OPERATION_MEMBER_ITEM is the standard value and makes up for most entries in here, whereas VERSIONCONTROL_OPERATION_CACHED_AFFECTED_ITEM is the optimization (denoting an item that is not part of a versioncontrol_get_operation_items() result but will still cause that operation to be found if it matches the "paths" constraint).',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
),
'indexes' => array(
'type' => array('type'),
),
'primary key' => array('vc_op_id', 'item_revision_id'),
);
$schema['versioncontrol_source_items'] = array(
'description' =>
'This table stores item history, i.e. it relates an item to one or more direct predecessors (= source items). Likewise, a source item can also have multiple successors, for example if it\'s copied to one location and later (or at the same time) moved to another location.',
'fields' => array(
'item_revision_id' => array(
'description' =>
'Foreign key for the successor item, referring to {versioncontrol_item_revisions}.item_revision_id. This one is more recent in revision history than the source item.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'source_item_revision_id' => array(
'description' =>
'Foreign key for the source item - also referring to {versioncontrol_item_revisions}.item_revision_id, but to a different one than the above {versioncontrol_source_items}.item_revision_id. Contains 0 if the action is VERSIONCONTROL_ACTION_ADDED.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'action' => array(
'description' =>
'Action that was performed while transforming the source item into the successor item. Can be one of the VERSIONCONTROL_ACTION_* values listed at the top of versioncontrol.module.
The VERSIONCONTROL_ACTION_DELETED and VERSIONCONTROL_ACTION_REPLACED actions are considered to be the end in the history of an item, no further successors than the current one should be retrieved. (For VERSIONCONTROL_ACTION_DELETED, item_revision_id links to a deleted item. For VERSIONCONTROL_ACTION_REPLACED, item_revision_id links to a different item at the same path that replaced the item specified by source_item_revision_id.
Likewise, the VERSIONCONTROL_ACTION_ADDED action is considered the beginning, with source_item_revision_id being 0 in that case.',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'line_changes_recorded' => array(
'description' =>
'Specifies whether line-change information is available (1 as value) or not (0 as value). Naturally, this should only apply to file items, not to directory items. VERSIONCONTROL_ACTION_DELETED and VERSIONCONTROL_ACTION_REPLACED actions are also not supposed to contain line-change information.',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'line_changes_added' => array(
'description' =>
'If the line_changes_recorded column is 1 then this column contains the amount of lines that was added to the file compared to its source revision. (Equivalent to the "plus" lines in a unified diff.)',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'line_changes_removed' => array(
'description' =>
'If the line_changes_recorded column is 1 then this column contains the amount of lines that was removed from the file compared to its source revision. (Equivalent to the "minus" lines in a unified diff.)',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
),
'primary key' => array('item_revision_id', 'source_item_revision_id'),
);
$schema['versioncontrol_item_revisions'] = array(
'description' =>
'This table contains all known different versions of a file or directory item. For version control systems using global revisions, only the revisions should be recorded in here when the item was actually changed, i.e. part of a commit operation. (Not every revision needs to have all associated items recorded in here, that would be insane.) Non-versioned items, such as directories in CVS or Git, should not be recorded in this table.',
'fields' => array(
'item_revision_id' => array(
'description' =>
'Unique identifier for this item revision. The same item in a different revision gets a different item_revision_id. Equivalent to the (also unique) repo_id/path/revision combination in the same row.',
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
),
'repo_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_repositories}.repo_id) for the repository that this item is located in.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'path' => array(
'description' =>
'Path of the item, relative to the repository root. Always starts with a slash, and never ends with one (not even if the item is a directory). Examples: "/" (root directory), "/contributions", "/sandbox/jpetso/evil-plans.txt". The slash is only used for separating the parts of the path, so it is safe to use explode("/", $path).',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'revision' => array(
'description' =>
'(File-level) revision of the item, such as "1.12.4.3" for CVS. If the version control system supports global revisions, this should contain the same revision as the "revision" property of the associated commit operation. Contrary to {versioncontrol_operations}.revision which may be empty, this column must always contain a revision because every changed item has a revision assigned. (If it lacks a revision, it should not be recorded as operation item in the first place.)',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'type' => array(
'description' =>
'Specifies whether the item is a file or directory, and whether it exists or is deleted. Deleted items might exist for real, such as in CVS repositories (the "Attic") or they might just be recorded as part of a commit operation where the item was deleted, even though the version control system does not know about this revision. In Version Control API, deleted items only exist for display purposes, backends are expected not to retrieve information about them other than item history. Possible values for the item type are VERSIONCONTROL_ITEM_FILE, VERSIONCONTROL_ITEM_FILE_DELETED, VERSIONCONTROL_ITEM_DIRECTORY and VERSIONCONTROL_ITEM_DIRECTORY_DELETED. Usually though, API users should only use the functions versioncontrol_is_file_item(), versioncontrol_is_directory_item() and versioncontrol_is_deleted_item() for testing these constants.',
'type' => 'int',
'size' => 'tiny',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
),
// Key too long, cannot create an index for this unique key.
//'unique keys' => array(
// 'repo_id_path_revision' => array('repo_id', 'path', 'revision'),
//),
// So instead, we roll two separate indexes.
'indexes' => array(
'repo_id_path' => array('repo_id', 'path'),
'revision' => array('revision'),
),
'primary key' => array('item_revision_id'),
);
$schema['versioncontrol_repositories'] = array(
'description' => 'This table contains the set of repositories known to the Version Control API.',
'fields' => array(
'repo_id' => array(
'description' => 'Primary key, the unique identifier for the repository.',
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
),
'name' => array(
'description' => 'User visible name of the repository, to be run through check_plain().',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'vcs' => array(
'description' => 'Unique string identifier of the backend, e.g. "cvs", "svn" or "git".',
'type' => 'varchar',
'length' => 8,
'not null' => TRUE,
'default' => '',
),
'root' => array(
'description' => 'Root URL/path of the repository, to be interpreted by the VCS backend when it interfaces with the repository.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'authorization_method' => array(
'description' => 'Unique string identifier of the authorization method. (For more information on authorization methods, see hook_versioncontrol.php for functions marked with "@ingroup Authorization".)',
'type' => 'varchar',
'length' => 64,
'not null' => TRUE,
'default' => '',
),
'url_backend' => array(
'description' => 'Repository URL backend. Intended to be pluggable, but for now this is hardcoded to "versioncontrol_default_urls" (which uses the values in the {versioncontrol_repository_urls} table).',
'type' => 'varchar',
'length' => 64,
'not null' => TRUE,
'default' => '',
),
'data' => array(
'description' => t('A serialized array of additional per-repository settings, mostly populated by third-party modules.'),
'type' => 'text',
'size' => 'medium',
'not null' => TRUE,
'serialize' => TRUE,
),
),
'unique keys' => array(
'name' => array('name'),
),
'primary key' => array('repo_id'),
);
$schema['versioncontrol_repository_urls'] = array(
'description' =>
'Repository URLs for repositories using the "versioncontrol_default_urls" backend. (Until the URL backend is made pluggable, all repositories will be using this default backend.)',
'fields' => array(
'repo_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_repositories}.repo_id) for the repository that uses these URLs.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'commit_view' => array(
'description' => 'The URL of the repository viewer that displays a given commit in the repository. "%revision" is used as placeholder for the revision/commit/changeset identifier.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'file_log_view' => array(
'description' =>
'The URL of the repository viewer that displays the commit log of a given file in the repository. "%path" is used as placeholder for the file path, "%revision" will be replaced by the file-level revision (the one in {versioncontrol_item_revisions}.revision), and "%branch" will be replaced by the branch name that the file is on.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'file_view' => array(
'description' =>
'The URL of the repository viewer that displays the contents of a given file in the repository. "%path" is used as placeholder for the file path, "%revision" will be replaced by the file-level revision (the one in {versioncontrol_item_revisions}.revision), and "%branch" will be replaced by the branch name that the file is on.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'directory_view' => array(
'description' =>
'The URL of the repository viewer that displays the contents of a given directory in the repository. "%path" is used as placeholder for the directory path, "%revision" will be replaced by the file-level revision (the one in {versioncontrol_item_revisions}.revision - only makes sense if directories are versioned, of course), and "%branch" will be replaced by the branch name that the directory is on.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'diff' => array(
'description' =>
'The URL of the repository viewer that displays the diff between two given files in the repository. "%path" and "%old-path" are used as placeholders for the new and old paths (for some version control systems, like CVS, those paths will always be the same). "%new-revision" and "%old-revision" will be replaced by the respective file-level revisions (from {versioncontrol_item_revisions}.revision), and "%branch" will be replaced by the branch name that the file is on.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'tracker' => array(
'description' =>
'The URL of the issue tracker that displays the issue/case/bug page of an issue id which presumably has been mentioned in a commit message. As issue tracker URLs are likely specific to each repository, this is also a per-repository setting. (Although... maybe it would make sense to have per-project rather than per-repository. Oh well.)',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
),
'primary key' => array('repo_id'),
);
$schema['versioncontrol_accounts'] = array(
'description' =>
'Association table of VCS account usernames (in a specific repository) to Drupal user ids. A Drupal user can be associated to multiple VCS accounts. Ideally, multiple VCS accounts per repository should be possible too, but clumsy array data structures and assumptions in the admin interface (elsewhere, too? don\'t know) currently make it necessary to restrict the number of VCS accounts to a maximum of 1 per repository and Drupal user.',
'fields' => array(
'uid' => array(
'description' => 'The {users}.uid of the Drupal user associated with the VCS-specific username in {versioncontrol_accounts}.username.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'repo_id' => array(
'description' => 'Foreign key (referring to {versioncontrol_repositories}.repo_id) for the repository that contains the VCS account.',
'type' => 'int',
'unsigned' => TRUE,
'not null' => TRUE,
'default' => 0,
),
'username' => array(
'description' => 'VCS-specific username of the VCS account associated with the Drupal user in {versioncontrol_accounts}.uid.',
'type' => 'varchar',
'length' => 64,
'not null' => TRUE,
'default' => '',
),
),
'unique keys' => array(
'repo_id_username' => array('repo_id', 'username'),
),
'primary key' => array('uid', 'repo_id'),
);
return $schema;
}
/**
* Implementation of hook_install().
*/
function versioncontrol_install() {
// Create tables.
drupal_install_schema('versioncontrol');
}
/**
* Implementation of hook_uninstall().
*/
function versioncontrol_uninstall() {
$variables = array(
'versioncontrol_email_address',
'versioncontrol_registration_message_unauthorized',
'versioncontrol_registration_message_authorized',
'versioncontrol_admin_account_pager',
);
foreach ($variables as $variable) {
variable_del($variable);
}
// Remove tables.
drupal_uninstall_schema('versioncontrol');
}
// Update functions. To be named versioncontrol_update_xyzz(), where x is the
// major version of Drupal core, y is the major version of Version Control API
// for this version of Drupal core, and zz is a consecutive number.
// versioncontrol_update_9() was the last update on Drupal 5.x (-2.x).
/**
* Original update from 5.x-2.x to 6.x-2.x:
* Change 5.x pure integer types to 6.x serial types.
*/
function versioncontrol_update_6100() {
$ret = array();
// Auto-increment fields don't like 0 values.
// So let's remove the "empty" item and implement it in some other way.
$ret = update_sql('DELETE FROM {versioncontrol_item_revisions}
WHERE item_revision_id = 0');
db_drop_primary_key($ret, 'versioncontrol_operations');
db_change_field($ret, 'versioncontrol_operations', 'vc_op_id', 'vc_op_id',
array('type' => 'serial', 'unsigned' => TRUE, 'not null' => TRUE),
array('primary key' => array('vc_op_id'))
);
db_drop_primary_key($ret, 'versioncontrol_labels');
db_change_field($ret, 'versioncontrol_labels', 'label_id', 'label_id',
array('type' => 'serial', 'unsigned' => TRUE, 'not null' => TRUE),
array('primary key' => array('label_id'))
);
db_drop_primary_key($ret, 'versioncontrol_item_revisions');
db_change_field($ret, 'versioncontrol_item_revisions', 'item_revision_id', 'item_revision_id',
array('type' => 'serial', 'unsigned' => TRUE, 'not null' => TRUE),
array('primary key' => array('item_revision_id'))
);
db_drop_primary_key($ret, 'versioncontrol_repositories');
db_change_field($ret, 'versioncontrol_repositories', 'repo_id', 'repo_id',
array('type' => 'serial', 'unsigned' => TRUE, 'not null' => TRUE),
array('primary key' => array('repo_id'))
);
return $ret;
}
/**
* Update from 6.x-1.0-rc1 to rc2:
* String deltas for the "active developers" block.
*/
function versioncontrol_update_6101() {
$ret = array();
$ret[] = update_sql("
UPDATE {blocks} SET delta = 'site_active_developers'
WHERE delta = '0' AND module = 'versioncontrol'");
return $ret;
}
/**
* Update from 6.x-1.0-rc2 to 6.x-1.0-rc3:
* Add a "data" column for modules to put their per-repository settings,
* and migrate the registration texts as well as the previously global option
* "allow unauthorized commit access" to the data column for all repositories.
*
* Per-repository settings of the Commit Restrictions module is also migrated
* in this function - for convenience, as otherwise we would need some extra
* logic to prevent its updates as long as the data column doesn't yet exist.
*/
function versioncontrol_update_6102() {
$ret = array();
$spec = array(
'description' => t('A serialized array of additional per-repository settings, mostly populated by third-party modules.'),
'type' => 'text',
'size' => 'medium',
'not null' => TRUE,
'serialize' => TRUE,
);
db_add_field($ret, 'versioncontrol_repositories', 'data', $spec);
$global_access = (bool) variable_get('versioncontrol_allow_unauthorized_access', 0);
$data_template = array(
'versioncontrol' => array('allow_unauthorized_access' => $global_access),
);
// Get all repository ids. Some of the data arrays might get changed still,
// so we don't write them all at once.
$result = db_query('
SELECT r.repo_id, m.registration_message
FROM {versioncontrol_repositories} r
LEFT JOIN {versioncontrol_repository_metadata} m
ON r.repo_id = m.repo_id'
);
while ($repository = db_fetch_object($result)) {
$repository_data[$repository->repo_id] = $data_template;
$repository_data[$repository->repo_id]['versioncontrol']['registration_message'] =
$repository->registration_message;
}
// Migrate Commit Restrictions module settings into the $data array,
// and delete the module's table after all data has been migrated.
if (db_table_exists('commit_restrictions')) {
$result = db_query('
SELECT repo_id, allowed_paths, forbidden_paths, deny_undefined_paths,
valid_branch_tag_paths, valid_branches, valid_tags
FROM {commit_restrictions}'
);
while ($restrictions = db_fetch_array($result)) {
$repo_id = $restrictions['repo_id'];
$restrictions = array_filter(array(
'allowed_paths' => array_filter(explode(' ', $restrictions['allowed_paths'])),
'forbidden_paths' => array_filter(explode(' ', $restrictions['forbidden_paths'])),
'valid_branch_tag_paths' => array_filter(explode(' ', $restrictions['valid_branch_tag_paths'])),
'valid_branches' => array_filter(explode(' ', $restrictions['valid_branches'])),
'valid_tags' => array_filter(explode(' ', $restrictions['valid_tags'])),
));
if (!empty($restrictions['deny_undefined_paths'])) {
$restrictions['deny_undefined_paths'] = (bool) $restrictions['deny_undefined_paths'];
}
if (!empty($restrictions)) {
$repository_data[$repo_id]['commit_restrictions'] = $restrictions;
}
}
db_drop_table($ret, 'commit_restrictions');
}
// Write the $data array to the respective repositories.
foreach ($repository_data as $repo_id => $data) {
$ret[] = update_sql("UPDATE {versioncontrol_repositories}
SET data = '". db_escape_string(serialize($data)) ."'
WHERE repo_id = ". $repo_id);
}
db_drop_table($ret, 'versioncontrol_repository_metadata');
variable_del('versioncontrol_allow_unauthorized_access');
$ret[] = array(
'success' => TRUE,
'query' => 'Deleted the global "versioncontrol_allow_unauthorized_access" variable, and migrated it to be a per-repository setting.',
);
return $ret;
}