-
Notifications
You must be signed in to change notification settings - Fork 112
/
Copy pathVERSIONS.php
155 lines (155 loc) · 7.52 KB
/
VERSIONS.php
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
<?php
/**
* @file
* A readme for the packages directory and the package versions.
*
* Table of Contents
* =================
* + Introduction
* + License Abbreviations
* + How-To: Manual upgrade of a forked package
* + How-To: Migrate a package to composer
* + Package List: PEAR
* + Package List: Manually installed
* + Package List: Payment processors
* + Package List: Unknown status
*
*
* Introduction
* ============
*
* The "packages" directory (aka civicrm-packages.git) is a collection of
* third-party libraries required by CiviCRM. Some of the libraries have are
* downloaded and added by hand; other libraries are added using tools. This
* file provides all the notes about how/where to download/upgrade third-party
* library.
*
* Note that the packages directory is generally deprecated for
* managing dependencies. Instead, one should update a config file
* in the main civicrm-core project:
*
* - For PHP dependencies, use composer.json
* - For client-side CSS/JS resources, use bower.json
* - For CLI JS tools, use package.json
*
* License Abbreviations
* =====================
*
* Apache 2 Apache License 2.0
* BSD 2-cl. two-clause BSD license
* BSD 3-cl. three-clause BSD license
* GPL 2 GNU General Public License 2
* GPL 2+ GNU General Public License 2 or later
* GPL 3 GNU General Public License 3
* LGPL 2.1 GNU Lesser General Public License 2.1
* LGPL 2.1+ GNU Lesser General Public License 2.1 or later
* LGPL 3 GNU Lesser General Public License 3
* LGPL 3+ GNU Lesser General Public License 3 or later
* PUBDOM Public domain
* PHP 2 PHP License 2.*
* PHP 3 PHP License 3.*
* X11 X11 (a.k.a. MIT) license
*
*
* How-To: Manual upgrade of a forked package
* ==========================================
*
* 1. download old version of upstream and overwrite packages with it (pear install Archive_Tar-1.3.3).
* If the version is not obvious, you may need to check a few different versions.
* 2. if there are differences, it means we patched the package – do a *reverse* diff and save to a patch file (git diff -R > /tmp/Archive_Tar.diff)
* 3. download current version and overwrite
* 4. if there were differences, copy any files that we patched in the old version to packages.orig
* 5. if there were differences, apply the patch from 2. (patch -p1 < /tmp/Archive_Tar.diff)
* 6. update this file and commit
*
*
* How-To: Migrate a package to composer
* =====================================
*
* To improve maintainability, it is desirable to migrate PHP dependencies from `civicrm-packages.git`
* to `civicrm-core.git:composer.json`. This is a somewhat painstaking process, but it makes future
* upgrades easier.
*
* A. Assess situation
* 1. Determine the old/active version of the package `Foo`.
* 2. Download the old/active version of package `Foo`, overwriting the copy in `packages/Foo`
* 3. Check for for differences. If there are some, it means we patched the package – do
* a *reverse* diff and save to a patch file (`git diff -R > /tmp/Archive_Tar.diff`)
* 4. Determine if the patches are still relevent in newer releases of the package.
* 5. Determine if changing the live path of the package will impact anything.
* In particular, look out for hard-coded references to `packages/Foo`. Ideally, check `universe`.
* 6. Revert/undo any changes you made during assessment.
* B. Prepare PRs
* 1. For `civicrm-core.git`, prepare a branch with a few commits:
*
* Update `composer.json` and `composer.lock`. Be careful to *only* update necessary packages
* and to use versions that work in Civi's minimum requirements (PHP/MySQL versions).
*
* If your assessment found important patches, then use `composer.json` to re-apply
* those patches (e.g.`extra: patches: ...` or `post-install-cmd`).
*
* Cleanup any hard-coded references to `packages/Foo`.
*
* 2. For `civicrm-packages.git`, prepare a branch. Remove the old code.
* 3. Locally, test that the new combination works.
* 4. Submit two PRs for `civicrm-core.git` and `civicrm-packages.git`. In the description
* or comments, provide cross-links. (Reviewers will need to be aware of both PRs so they
* can test appropriately.)
* C. Review the PRs
* The reviewer will need to setup both patches and include them in a test-run.
* There is no fully automatic bot for this test scenario.
* One way to test this is with civibuild and civi-test-run:
* civibuild create mytest --type drupal-clean --patch <github-pr-url-1> --patch <github-pr-url-2> ...
* civi-test-run -b mytest -j /tmp/junit-output
*
* Package List: PEAR
* ==================
* Contact_Vcard_Build 1.1.2 PHP 3 local changes
* Contact_Vcard_Parse 1.32.0 PHP 3.0
* Date 1.4.7 BSD 3-cl.
* DB_DataObject 1.11.3 PHP 3 local changes
* HTML_Common 1.2.5 PHP 3
* HTML_QuickForm 3.2.16 PHP 3 local changes, hierselect.php from a very old version (PHP 2)
* HTML_QuickForm_advmultiselect 1.5.1 BSD 3-cl. local changes
* HTML_QuickForm_Controller 1.0.9 PHP 3 local changes
* HTML_Template_IT 1.2.1 BSD 3-cl.
* Mail_mimeDecode 1.5.6 BSD 3-cl.
* Pager 2.4.8 BSD 3-cl.
* PHP_Beautifier 0.1.14 PHP 3.0
* Services_Twilio 3.10.0 MIT
* Validate 0.8.2 BSD 3-cl.
* Validate_Finance 0.5.4 BSD 3-cl.
*
*
* Package List: Manually installed
* ================================
* PHP gettext 1.0.7 GPL 2+ http://savannah.nongnu.org/projects/php-gettext/
* PHPIDS 0.7 LGPL 3+ http://phpids.org/
* Smarty 2.6.27 LGPL 2.1+ http://smarty.php.net/ local changes ( use only lib )
* Smarty Gettext 1.0b1 LGPL 2.1+ http://smarty.incutio.com/?page=SmartyGettext
* TCPDF 6.0.020 GPL 3+ http://www.tcpdf.org/ doc, examples, images and most of fonts removed
* eZ Components 2009.1.2 BSD 3-cl. http://ezcomponents.org/ local changes
* html2text 0.9.1 GPL 3+ http://roundcube.net/download copied from program/lib/Roundcube/rcube_html2text.php
* reCAPTCHA 1.10 X11 http://recaptcha.net/
* Backbone 0.9.9 X11/MIT http://backbonejs.org/
* Backone Forms c6920b3c89 X11/MIT https://github.com/powmedia/backbone-forms
* Backbon.Collectionsubset d3de0d6804 X11/MIT https://github.com/anthonyshort/backbone.collectionsubset
* Backbone.ModelBinder 448472f X11/MIT https://github.com/theironcook/Backbone.ModelBinder
* git-footnote 2013-03-27 LGPL 3 https://github.com/totten/git-footnote
* json2 2012-10-08 PUBDOM https://github.com/douglascrockford/JSON-js
* Marionette 1.0.0-rc2 X11/MIT http://marionettejs.com/
* Moment.js 2.5..0 X11/MIT http://momentjs.com/
* Simple HTML DOM 1.5 X11/MIT http://simplehtmldom.sourceforge.net/
*
*
* Package List: Payment processors
* ================================
* PayJunction AGPL 3 by Phase2 Technology
* PaymentExpress AGPL 3 by Lucas Baker
*
*
* Package List: Unknown status
* ============================
* Facebook BSD 2-cl.
* Google Apache 2/GPL 2+
*/