Commit | Line | Data |
---|---|---|
3a2a6e86 TO |
1 | <?php |
2 | ||
067907d7 EM |
3 | use Civi\Api4\ACL; |
4 | use Civi\Api4\ACLEntityRole; | |
5 | use Civi\Api4\Contact; | |
6 | use Civi\Api4\Email; | |
7 | use Civi\Api4\Group; | |
8 | use Civi\Api4\OptionValue; | |
9 | ||
3a2a6e86 TO |
10 | class CRM_Core_CodeGen_GenerateData { |
11 | ||
12 | /** | |
13 | * Constants | |
14 | */ | |
15 | ||
16 | // Set ADD_TO_DB = FALSE to do a dry run | |
17 | const ADD_TO_DB = TRUE; | |
18 | ||
19 | const DATA_FILENAME = "sample_data.xml"; | |
20 | const NUM_DOMAIN = 1; | |
21 | const NUM_CONTACT = 200; | |
22 | const INDIVIDUAL_PERCENT = 80; | |
23 | const HOUSEHOLD_PERCENT = 10; | |
24 | const ORGANIZATION_PERCENT = 10; | |
25 | const NUM_INDIVIDUAL_PER_HOUSEHOLD = 4; | |
26 | const NUM_ACTIVITY = 150; | |
27 | ||
28 | // Location types from the table crm_location_type | |
29 | const HOME = 1; | |
30 | const WORK = 2; | |
31 | const MAIN = 3; | |
32 | const OTHER = 4; | |
33 | ||
34 | /** | |
35 | * Class constructor | |
38b93530 TO |
36 | * |
37 | * @param string|int $seed | |
38 | * Some scalar value used as the starting point for random-number generation. | |
39 | * @param int $time | |
40 | * A timestamp; some facsimile of "now". | |
3a2a6e86 | 41 | */ |
38b93530 | 42 | public function __construct($seed, $time) { |
3a2a6e86 | 43 | // initialize all the vars |
849e0b97 | 44 | $this->seed = $seed; |
38b93530 | 45 | $this->time = $time; |
3a2a6e86 TO |
46 | $this->numIndividual = self::INDIVIDUAL_PERCENT * self::NUM_CONTACT / 100; |
47 | $this->numHousehold = self::HOUSEHOLD_PERCENT * self::NUM_CONTACT / 100; | |
48 | $this->numOrganization = self::ORGANIZATION_PERCENT * self::NUM_CONTACT / 100; | |
49 | $this->numStrictIndividual = $this->numIndividual - ($this->numHousehold * self::NUM_INDIVIDUAL_PER_HOUSEHOLD); | |
50 | ||
51 | // Parse data file | |
d94d506c | 52 | foreach ((array) simplexml_load_file(self::getCivicrmDir() . '/sql/' . self::DATA_FILENAME) as $key => $val) { |
3a2a6e86 TO |
53 | $val = (array) $val; |
54 | $this->sampleData[$key] = (array) $val['item']; | |
55 | } | |
56 | // Init DB | |
57 | $config = CRM_Core_Config::singleton(); | |
58 | ||
59 | // Relationship types indexed by name_a_b from the table civicrm_relationship_type | |
156ca3ec | 60 | $this->relTypes = CRM_Utils_Array::index(['name_a_b'], CRM_Core_PseudoConstant::relationshipType('name')); |
6397fe92 | 61 | } |
3a2a6e86 | 62 | |
6397fe92 TO |
63 | /** |
64 | * Create a full, standard set of random data. | |
65 | */ | |
66 | public function generateAll() { | |
67 | $this->initID(); | |
68 | $this->generate('Domain'); | |
69 | $this->generate('Contact'); | |
70 | $this->generate('Individual'); | |
71 | $this->generate('Household'); | |
72 | $this->generate('Organization'); | |
73 | $this->generate('Relationship'); | |
74 | $this->generate('EntityTag'); | |
75 | $this->generate('Group'); | |
067907d7 | 76 | $this->generate('ACL'); |
6397fe92 TO |
77 | $this->generate('Note'); |
78 | $this->generate('Activity'); | |
79 | $this->generate('Event'); | |
80 | $this->generate('Contribution'); | |
81 | $this->generate('ContributionLineItem'); | |
82 | $this->generate('Membership'); | |
83 | $this->generate('MembershipPayment'); | |
84 | $this->generate('MembershipLog'); | |
85 | $this->generate('PCP'); | |
86 | $this->generate('SoftContribution'); | |
87 | $this->generate('Pledge'); | |
88 | $this->generate('PledgePayment'); | |
89 | $this->generate('Participant'); | |
90 | $this->generate('ParticipantPayment'); | |
91 | $this->generate('LineItemParticipants'); | |
92 | $this->generate('AccountingEntries'); | |
3a2a6e86 TO |
93 | } |
94 | ||
07e41513 TO |
95 | /** |
96 | * Write a log message. | |
97 | * | |
98 | * @param string $message | |
99 | */ | |
100 | public function write($message) { | |
101 | echo $message; | |
102 | } | |
103 | ||
3a2a6e86 TO |
104 | /** |
105 | * Public wrapper for calling private "add" functions | |
106 | * Provides user feedback | |
156ca3ec | 107 | * |
3a2a6e86 TO |
108 | * @param $itemName |
109 | */ | |
110 | public function generate($itemName) { | |
07e41513 | 111 | $this->write("Generating $itemName\n"); |
3a2a6e86 TO |
112 | $fn = "add$itemName"; |
113 | $this->$fn(); | |
114 | } | |
115 | ||
116 | /** | |
117 | * this function creates arrays for the following | |
118 | * | |
119 | * domain id | |
120 | * contact id | |
121 | * contact_location id | |
122 | * contact_contact_location id | |
123 | * contact_email uuid | |
124 | * contact_phone_uuid | |
125 | * contact_instant_message uuid | |
126 | * contact_relationship uuid | |
127 | * contact_task uuid | |
128 | * contact_note uuid | |
129 | */ | |
130 | public function initID() { | |
131 | // get the domain and contact id arrays | |
132 | $this->domain = range(1, self::NUM_DOMAIN); | |
0049e17a | 133 | $this->domain = $this->shuffle($this->domain); |
3a2a6e86 TO |
134 | |
135 | // Get first contact id | |
136 | $this->startCid = $cid = CRM_Core_DAO::singleValueQuery("SELECT MAX(id) FROM civicrm_contact"); | |
137 | $this->contact = range($cid + 1, $cid + self::NUM_CONTACT); | |
0049e17a | 138 | $this->contact = $this->shuffle($this->contact); |
3a2a6e86 TO |
139 | |
140 | // get the individual, household and organizaton contacts | |
141 | $offset = 0; | |
142 | $this->Individual = array_slice($this->contact, $offset, $this->numIndividual); | |
143 | $offset += $this->numIndividual; | |
144 | $this->Household = array_slice($this->contact, $offset, $this->numHousehold); | |
145 | $offset += $this->numHousehold; | |
146 | $this->Organization = array_slice($this->contact, $offset, $this->numOrganization); | |
147 | ||
148 | // get the strict individual contacts (i.e individual contacts not belonging to any household) | |
149 | $this->strictIndividual = array_slice($this->Individual, 0, $this->numStrictIndividual); | |
150 | ||
151 | // get the household to individual mapping array | |
152 | $this->householdIndividual = array_slice($this->Individual, $this->numStrictIndividual); | |
153 | $this->householdIndividual = array_chunk($this->householdIndividual, self::NUM_INDIVIDUAL_PER_HOUSEHOLD); | |
154 | $this->householdIndividual = array_combine($this->Household, $this->householdIndividual); | |
155 | } | |
156 | ||
157 | /* | |
158 | * private members | |
159 | * | |
160 | */ | |
161 | ||
849e0b97 TO |
162 | /** |
163 | * @var int | |
164 | */ | |
165 | private $seed; | |
166 | ||
3a2a6e86 TO |
167 | /** |
168 | * enum's from database | |
156ca3ec | 169 | * |
3a2a6e86 TO |
170 | * @var array |
171 | */ | |
156ca3ec EM |
172 | private $preferredCommunicationMethod = ['1', '2', '3', '4', '5']; |
173 | ||
174 | private $contactType = ['Individual', 'Household', 'Organization']; | |
175 | ||
176 | private $phoneType = ['1', '2', '3', '4']; | |
3a2a6e86 TO |
177 | |
178 | /** | |
179 | * customizable enums (foreign keys) | |
156ca3ec | 180 | * |
3a2a6e86 TO |
181 | * @var array |
182 | */ | |
156ca3ec | 183 | private $prefix = [ |
3a2a6e86 | 184 | // Female |
156ca3ec | 185 | 1 => [ |
3a2a6e86 TO |
186 | 1 => 'Mrs.', |
187 | 2 => 'Ms.', | |
188 | 4 => 'Dr.', | |
156ca3ec | 189 | ], |
3a2a6e86 | 190 | // Male |
156ca3ec | 191 | 2 => [ |
3a2a6e86 TO |
192 | 3 => 'Mr.', |
193 | 4 => 'Dr.', | |
156ca3ec EM |
194 | ], |
195 | ]; | |
196 | ||
3a2a6e86 TO |
197 | /** |
198 | * @var array | |
199 | */ | |
156ca3ec EM |
200 | private $suffix = [1 => 'Jr.', 2 => 'Sr.', 3 => 'II', 4 => 'III']; |
201 | ||
202 | private $gender = [1 => 'female', 2 => 'male']; | |
3a2a6e86 TO |
203 | |
204 | /** | |
205 | * store domain id's | |
156ca3ec | 206 | * |
3a2a6e86 TO |
207 | * @var array |
208 | */ | |
156ca3ec | 209 | private $domain = []; |
3a2a6e86 TO |
210 | |
211 | /** | |
212 | * store contact id's | |
156ca3ec | 213 | * |
3a2a6e86 TO |
214 | * @var array |
215 | */ | |
156ca3ec EM |
216 | private $contact = []; |
217 | ||
218 | private $Individual = []; | |
219 | ||
220 | private $Household = []; | |
221 | ||
222 | private $Organization = []; | |
3a2a6e86 TO |
223 | |
224 | // store which contacts have a location entity | |
156ca3ec | 225 | |
3a2a6e86 TO |
226 | /** |
227 | * for automatic management of is_primary field | |
156ca3ec | 228 | * |
3a2a6e86 TO |
229 | * @var array |
230 | */ | |
156ca3ec EM |
231 | private $location = [ |
232 | 'Email' => [], | |
233 | 'Phone' => [], | |
234 | 'Address' => [], | |
235 | ]; | |
3a2a6e86 TO |
236 | |
237 | /** | |
238 | * stores the strict individual id and household id to individual id mapping | |
156ca3ec | 239 | * |
3a2a6e86 TO |
240 | * @var array |
241 | */ | |
156ca3ec EM |
242 | private $strictIndividual = []; |
243 | ||
244 | private $householdIndividual = []; | |
245 | ||
246 | private $householdName = []; | |
3a2a6e86 TO |
247 | |
248 | /** | |
249 | * sample data in xml format | |
156ca3ec | 250 | * |
3a2a6e86 TO |
251 | * @var array |
252 | */ | |
156ca3ec | 253 | private $sampleData = []; |
3a2a6e86 TO |
254 | |
255 | /** | |
256 | * private vars | |
156ca3ec | 257 | * |
3a2a6e86 TO |
258 | * @var array |
259 | */ | |
260 | private $startCid; | |
156ca3ec | 261 | |
3a2a6e86 | 262 | private $numIndividual = 0; |
156ca3ec | 263 | |
3a2a6e86 | 264 | private $numHousehold = 0; |
156ca3ec | 265 | |
3a2a6e86 | 266 | private $numOrganization = 0; |
156ca3ec | 267 | |
3a2a6e86 | 268 | private $numStrictIndividual = 0; |
3a2a6e86 | 269 | |
156ca3ec EM |
270 | private $stateMap = []; |
271 | ||
272 | private $states = []; | |
273 | ||
274 | private $groupMembershipStatus = ['Added', 'Removed', 'Pending']; | |
275 | ||
276 | private $subscriptionHistoryMethod = ['Admin', 'Email']; | |
277 | ||
278 | private $deceasedContactIds = []; | |
3a2a6e86 TO |
279 | |
280 | /********************************* | |
281 | * private methods | |
282 | * ******************************* | |
3a2a6e86 TO |
283 | */ |
284 | ||
38cdbfc7 TO |
285 | /** |
286 | * Random number generator. | |
287 | * | |
288 | * All other random() functions should derive from this. | |
289 | * | |
849e0b97 TO |
290 | * This is very weak RNG. The goal is to provide a reproducible sequence of |
291 | * random-ish values for generating dummy-data. | |
292 | * | |
38cdbfc7 TO |
293 | * @param int $min |
294 | * @param int $max | |
156ca3ec | 295 | * |
38cdbfc7 TO |
296 | * @return int |
297 | */ | |
298 | private function randomInt($min, $max) { | |
849e0b97 TO |
299 | $range = min(1 + $max - $min, mt_getrandmax()); |
300 | $this->seed = md5($this->seed . chr(0) . $min . chr(0) . $max); | |
301 | return $min + (hexdec(substr($this->seed, 20, 8)) % $range); | |
38cdbfc7 TO |
302 | } |
303 | ||
3a2a6e86 TO |
304 | /** |
305 | * Get a randomly generated string. | |
306 | * | |
307 | * @param int $size | |
308 | * | |
309 | * @return string | |
310 | */ | |
311 | private function randomString($size = 32) { | |
312 | $string = ""; | |
313 | ||
314 | // get an ascii code for each character | |
315 | for ($i = 0; $i < $size; $i++) { | |
38cdbfc7 | 316 | $random_int = $this->randomInt(65, 122); |
3a2a6e86 TO |
317 | if (($random_int < 97) && ($random_int > 90)) { |
318 | // if ascii code between 90 and 97 substitute with space | |
319 | $random_int = 32; | |
320 | } | |
321 | $random_char = chr($random_int); | |
322 | $string .= $random_char; | |
323 | } | |
324 | return $string; | |
325 | } | |
326 | ||
327 | /** | |
328 | * @return string | |
329 | */ | |
330 | private function randomChar() { | |
38cdbfc7 | 331 | return chr($this->randomInt(65, 90)); |
3a2a6e86 TO |
332 | } |
333 | ||
334 | /** | |
335 | * Get a random item from the sample data or any other array | |
336 | * | |
156ca3ec EM |
337 | * @param $items (array or string) - if string, used as key for sample data, |
338 | * if array, used as data source | |
3a2a6e86 TO |
339 | * |
340 | * @return mixed (element from array) | |
341 | * | |
342 | * @private | |
343 | */ | |
344 | private function randomItem($items) { | |
345 | if (!is_array($items)) { | |
346 | $key = $items; | |
347 | $items = $this->sampleData[$key]; | |
348 | } | |
349 | if (!$items) { | |
07e41513 | 350 | $this->write("Error: no items found for '$key'\n"); |
3a2a6e86 TO |
351 | return FALSE; |
352 | } | |
38cdbfc7 | 353 | return $items[$this->randomInt(0, count($items) - 1)]; |
3a2a6e86 TO |
354 | } |
355 | ||
356 | /** | |
357 | * @param $items | |
358 | * | |
359 | * @return mixed | |
360 | */ | |
361 | private function randomIndex($items) { | |
362 | return $this->randomItem(array_keys($items)); | |
363 | } | |
364 | ||
365 | /** | |
366 | * @param $items | |
367 | * | |
368 | * @return array | |
369 | */ | |
370 | private function randomKeyValue($items) { | |
371 | $key = $this->randomIndex($items); | |
156ca3ec | 372 | return [$key, $items[$key]]; |
3a2a6e86 TO |
373 | } |
374 | ||
0049e17a TO |
375 | private function shuffle($array) { |
376 | for ($i = count($array) - 1; $i >= 1; $i--) { | |
377 | $j = $this->randomInt(0, $i); | |
378 | $tmp = $array[$i]; | |
379 | $array[$i] = $array[$j]; | |
380 | $array[$j] = $tmp; | |
381 | } | |
382 | return $array; | |
383 | } | |
384 | ||
3a2a6e86 TO |
385 | /** |
386 | * @param $chance | |
387 | * | |
388 | * @return int | |
389 | */ | |
390 | private function probability($chance) { | |
38cdbfc7 | 391 | if ($this->randomInt(0, 100) < ($chance * 100)) { |
3a2a6e86 TO |
392 | return 1; |
393 | } | |
394 | return 0; | |
395 | } | |
396 | ||
397 | /** | |
398 | * Generate a random date. | |
399 | * | |
400 | * If both $startDate and $endDate are defined generate | |
401 | * date between them. | |
402 | * | |
403 | * If only startDate is specified then date generated is | |
404 | * between startDate + 1 year. | |
405 | * | |
406 | * if only endDate is specified then date generated is | |
407 | * between endDate - 1 year. | |
408 | * | |
409 | * if none are specified - date is between today - 1year | |
410 | * and today | |
411 | * | |
156ca3ec EM |
412 | * @param int $startDate Start Date in Unix timestamp |
413 | * @param int $endDate End Date in Unix timestamp | |
414 | * | |
3a2a6e86 TO |
415 | * @access private |
416 | * | |
417 | * @return string randomly generated date in the format "Ymd" | |
418 | * | |
419 | */ | |
420 | private function randomDate($startDate = 0, $endDate = 0) { | |
421 | ||
422 | // number of seconds per year | |
423 | $numSecond = 31536000; | |
424 | $dateFormat = "YmdHis"; | |
82d32482 | 425 | $today = $this->time; |
3a2a6e86 TO |
426 | |
427 | // both are defined | |
428 | if ($startDate && $endDate) { | |
38cdbfc7 | 429 | return date($dateFormat, $this->randomInt($startDate, $endDate)); |
3a2a6e86 TO |
430 | } |
431 | ||
432 | // only startDate is defined | |
433 | if ($startDate) { | |
38cdbfc7 | 434 | return date($dateFormat, $this->randomInt($startDate, $startDate + $numSecond)); |
3a2a6e86 TO |
435 | } |
436 | ||
437 | // only endDate is defined | |
438 | if ($startDate) { | |
38cdbfc7 | 439 | return date($dateFormat, $this->randomInt($endDate - $numSecond, $endDate)); |
3a2a6e86 TO |
440 | } |
441 | ||
442 | // none are defined | |
38cdbfc7 | 443 | return date($dateFormat, $this->randomInt($today - $numSecond, $today)); |
3a2a6e86 TO |
444 | } |
445 | ||
446 | /** | |
156ca3ec EM |
447 | * Automatically manage the is_primary field by tracking which contacts have |
448 | * each item | |
449 | * | |
3a2a6e86 TO |
450 | * @param $cid |
451 | * @param $type | |
156ca3ec | 452 | * |
3a2a6e86 TO |
453 | * @return int |
454 | */ | |
455 | private function isPrimary($cid, $type) { | |
456 | if (empty($this->location[$type][$cid])) { | |
457 | $this->location[$type][$cid] = TRUE; | |
458 | return 1; | |
459 | } | |
460 | return 0; | |
461 | } | |
462 | ||
463 | /** | |
464 | * Execute a query unless we are doing a dry run | |
465 | * Note: this wrapper should not be used for SELECT queries | |
156ca3ec | 466 | * |
3a2a6e86 TO |
467 | * @param $query |
468 | * @param array $params | |
156ca3ec | 469 | * |
3a2a6e86 TO |
470 | * @return \CRM_Core_DAO |
471 | */ | |
156ca3ec | 472 | private function _query($query, $params = []) { |
3a2a6e86 TO |
473 | if (self::ADD_TO_DB) { |
474 | return CRM_Core_DAO::executeQuery($query, $params); | |
475 | } | |
476 | } | |
477 | ||
478 | /** | |
479 | * Call dao insert method unless we are doing a dry run | |
156ca3ec | 480 | * |
3a2a6e86 TO |
481 | * @param $dao |
482 | */ | |
483 | private function _insert(&$dao) { | |
484 | if (self::ADD_TO_DB) { | |
07e41513 | 485 | $dao->insert(); |
3a2a6e86 TO |
486 | } |
487 | } | |
488 | ||
489 | /** | |
490 | * Call dao update method unless we are doing a dry run | |
156ca3ec | 491 | * |
3a2a6e86 TO |
492 | * @param $dao |
493 | */ | |
494 | private function _update(&$dao) { | |
495 | if (self::ADD_TO_DB) { | |
07e41513 | 496 | $dao->update(); |
3a2a6e86 TO |
497 | } |
498 | } | |
499 | ||
500 | /** | |
501 | * Add core DAO object | |
156ca3ec | 502 | * |
3a2a6e86 TO |
503 | * @param $type |
504 | * @param $params | |
505 | */ | |
506 | private function _addDAO($type, $params) { | |
507 | $daoName = "CRM_Core_DAO_$type"; | |
508 | $obj = new $daoName(); | |
509 | foreach ($params as $key => $value) { | |
510 | $obj->$key = $value; | |
511 | } | |
512 | if (isset($this->location[$type])) { | |
513 | $obj->is_primary = $this->isPrimary($params['contact_id'], $type); | |
514 | } | |
515 | $this->_insert($obj); | |
516 | } | |
517 | ||
518 | /** | |
519 | * Fetch contact type based on stored mapping | |
156ca3ec | 520 | * |
3a2a6e86 | 521 | * @param $id |
156ca3ec | 522 | * |
3a2a6e86 TO |
523 | * @return string $type |
524 | */ | |
525 | private function getContactType($id) { | |
156ca3ec | 526 | foreach (['Individual', 'Household', 'Organization'] as $type) { |
3a2a6e86 TO |
527 | if (in_array($id, $this->$type)) { |
528 | return $type; | |
529 | } | |
530 | } | |
531 | } | |
532 | ||
533 | /** | |
534 | * This method adds NUM_DOMAIN domains and then adds NUM_REVISION | |
535 | * revisions for each domain with the latest revision being the last one.. | |
536 | */ | |
537 | private function addDomain() { | |
538 | ||
539 | /* Add a location for domain 1 */ | |
540 | ||
541 | $domain = new CRM_Core_DAO_Domain(); | |
542 | for ($id = 2; $id <= self::NUM_DOMAIN; $id++) { | |
543 | // domain name is pretty simple. it is "Domain $id" | |
544 | $domain->name = "Domain $id"; | |
545 | $domain->description = "Description $id"; | |
546 | $domain->contact_name = $this->randomName(); | |
547 | ||
548 | // insert domain | |
549 | $this->_insert($domain); | |
550 | } | |
551 | } | |
552 | ||
553 | /** | |
554 | * @return string | |
555 | */ | |
556 | public function randomName() { | |
557 | $first_name = $this->randomItem(($this->probability(.5) ? 'fe' : '') . 'male_name'); | |
558 | $middle_name = ucfirst($this->randomChar()); | |
559 | $last_name = $this->randomItem('last_name'); | |
560 | return "$first_name $middle_name. $last_name"; | |
561 | } | |
562 | ||
563 | /** | |
564 | * This method adds data to the contact table | |
565 | * | |
566 | * id - from $contact | |
567 | * contact_type 'Individual' 'Household' 'Organization' | |
568 | * preferred_communication (random 1 to 3) | |
569 | */ | |
570 | private function addContact() { | |
571 | $contact = new CRM_Contact_DAO_Contact(); | |
572 | $cid = $this->startCid; | |
573 | ||
574 | for ($id = $cid + 1; $id <= $cid + self::NUM_CONTACT; $id++) { | |
575 | $contact->contact_type = $this->getContactType($id); | |
576 | $contact->do_not_phone = $this->probability(.2); | |
577 | $contact->do_not_email = $this->probability(.2); | |
578 | $contact->do_not_post = $this->probability(.2); | |
579 | $contact->do_not_trade = $this->probability(.2); | |
580 | $contact->preferred_communication_method = NULL; | |
581 | if ($this->probability(.5)) { | |
582 | $contact->preferred_communication_method = CRM_Core_DAO::VALUE_SEPARATOR . $this->randomItem($this->preferredCommunicationMethod) . CRM_Core_DAO::VALUE_SEPARATOR; | |
583 | } | |
584 | $contact->source = 'Sample Data'; | |
585 | $this->_insert($contact); | |
586 | } | |
587 | } | |
588 | ||
589 | /** | |
590 | * addIndividual() | |
591 | * | |
592 | * This method adds individual's data to the contact table | |
593 | * | |
594 | * The following fields are generated and added. | |
595 | * | |
596 | * contact_uuid - individual | |
597 | * contact_rid - latest one | |
598 | * first_name 'First Name $contact_uuid' | |
599 | * middle_name 'Middle Name $contact_uuid' | |
600 | * last_name 'Last Name $contact_uuid' | |
601 | * job_title 'Job Title $contact_uuid' | |
602 | * | |
603 | */ | |
604 | private function addIndividual() { | |
605 | ||
606 | $contact = new CRM_Contact_DAO_Contact(); | |
607 | $year = 60 * 60 * 24 * 365.25; | |
82d32482 | 608 | $now = $this->time; |
3a2a6e86 TO |
609 | |
610 | foreach ($this->Individual as $cid) { | |
611 | $contact->is_deceased = $contact->gender_id = $contact->birth_date = $contact->deceased_date = $email = NULL; | |
be946912 | 612 | [$gender_id, $gender] = $this->randomKeyValue($this->gender); |
38cdbfc7 | 613 | $birth_date = $this->randomInt($now - 90 * $year, $now - 10 * $year); |
3a2a6e86 TO |
614 | |
615 | $contact->last_name = $this->randomItem('last_name'); | |
616 | ||
617 | // Manage household names | |
618 | if (!in_array($contact->id, $this->strictIndividual)) { | |
619 | // Find position in household | |
620 | foreach ($this->householdIndividual as $householdId => $house) { | |
621 | foreach ($house as $position => $memberId) { | |
622 | if ($memberId == $cid) { | |
623 | break 2; | |
624 | } | |
625 | } | |
626 | } | |
627 | // Head of household: set name | |
628 | if (empty($this->householdName[$householdId])) { | |
629 | $this->householdName[$householdId] = $contact->last_name; | |
630 | } | |
631 | // Kids get household name, spouse might get it | |
632 | if ($position > 1 || $this->probability(.5)) { | |
633 | $contact->last_name = $this->householdName[$householdId]; | |
634 | } | |
635 | elseif ($this->householdName[$householdId] != $contact->last_name) { | |
636 | // Spouse might hyphenate name | |
637 | if ($this->probability(.5)) { | |
638 | $contact->last_name .= '-' . $this->householdName[$householdId]; | |
639 | } | |
640 | // Kids might hyphenate name | |
641 | else { | |
642 | $this->householdName[$householdId] .= '-' . $contact->last_name; | |
643 | } | |
644 | } | |
645 | // Sensible ages and genders | |
38cdbfc7 | 646 | $offset = $this->randomInt($now - 40 * $year, $now); |
3a2a6e86 TO |
647 | // Parents |
648 | if ($position < 2) { | |
38cdbfc7 | 649 | $birth_date = $this->randomInt($offset - 35 * $year, $offset - 20 * $year); |
3a2a6e86 TO |
650 | if ($this->probability(.8)) { |
651 | $gender_id = 2 - $position; | |
652 | $gender = $this->gender[$gender_id]; | |
653 | } | |
654 | } | |
655 | // Kids | |
656 | else { | |
38cdbfc7 | 657 | $birth_date = $this->randomInt($offset - 10 * $year, $offset); |
3a2a6e86 TO |
658 | } |
659 | } | |
660 | // Non household people | |
661 | else { | |
662 | if ($this->probability(.6)) { | |
663 | $this->_addAddress($cid); | |
664 | } | |
665 | } | |
666 | ||
667 | $contact->first_name = $this->randomItem($gender . '_name'); | |
668 | $contact->middle_name = $this->probability(.5) ? '' : ucfirst($this->randomChar()); | |
669 | $age = intval(($now - $birth_date) / $year); | |
670 | ||
671 | // Prefix and suffix by gender and age | |
672 | $contact->prefix_id = $contact->suffix_id = $prefix = $suffix = NULL; | |
673 | if ($this->probability(.5) && $age > 20) { | |
be946912 | 674 | [$contact->prefix_id, $prefix] = $this->randomKeyValue($this->prefix[$gender_id]); |
3a2a6e86 TO |
675 | $prefix .= ' '; |
676 | } | |
156ca3ec | 677 | if ($gender === 'male' && $this->probability(.50)) { |
be946912 | 678 | [$contact->suffix_id, $suffix] = $this->randomKeyValue($this->suffix); |
3a2a6e86 TO |
679 | $suffix = ' ' . $suffix; |
680 | } | |
681 | if ($this->probability(.7)) { | |
682 | $contact->gender_id = $gender_id; | |
683 | } | |
684 | if ($this->probability(.7)) { | |
685 | $contact->birth_date = date("Ymd", $birth_date); | |
686 | } | |
687 | ||
688 | // Deceased probability based on age | |
689 | if ($contact->gender_id && $contact->gender_id == 2) { | |
690 | $checkAge = 64; | |
691 | } | |
692 | else { | |
693 | $checkAge = 68; | |
694 | } | |
695 | if ($age > $checkAge && count($this->deceasedContactIds) < 4) { | |
696 | $contact->is_deceased = $this->probability(($age - 30) / 100); | |
697 | if ($contact->is_deceased && $this->probability(.7)) { | |
698 | $contact->deceased_date = $this->randomDate(); | |
699 | } | |
700 | } | |
701 | ||
702 | // Add 0, 1 or 2 email address | |
38cdbfc7 | 703 | $count = $this->randomInt(0, 2); |
3a2a6e86 TO |
704 | for ($i = 0; $i < $count; ++$i) { |
705 | $email = $this->_individualEmail($contact); | |
706 | $this->_addEmail($cid, $email, self::HOME); | |
707 | } | |
708 | ||
709 | // Add 0, 1 or 2 phones | |
38cdbfc7 | 710 | $count = $this->randomInt(0, 2); |
3a2a6e86 TO |
711 | for ($i = 0; $i < $count; ++$i) { |
712 | $this->_addPhone($cid); | |
713 | } | |
714 | ||
715 | // Occasionally you get contacts with just an email in the db | |
716 | if ($this->probability(.2) && $email) { | |
717 | $contact->first_name = $contact->last_name = $contact->middle_name = NULL; | |
718 | $contact->is_deceased = $contact->gender_id = $contact->birth_date = $contact->deceased_date = NULL; | |
719 | $contact->display_name = $contact->sort_name = $email; | |
720 | $contact->postal_greeting_display = $contact->email_greeting_display = "Dear $email"; | |
721 | } | |
722 | else { | |
723 | $contact->display_name = $prefix . $contact->first_name . ' ' . $contact->last_name . $suffix; | |
724 | $contact->sort_name = $contact->last_name . ', ' . $contact->first_name; | |
725 | $contact->postal_greeting_display = $contact->email_greeting_display = 'Dear ' . $contact->first_name; | |
726 | } | |
727 | $contact->addressee_id = $contact->postal_greeting_id = $contact->email_greeting_id = 1; | |
728 | $contact->addressee_display = $contact->display_name; | |
729 | $contact->hash = crc32($contact->sort_name); | |
730 | $contact->id = $cid; | |
731 | $this->_update($contact); | |
732 | if ($contact->is_deceased) { | |
733 | $this->deceasedContactIds[] = $cid; | |
734 | } | |
735 | } | |
736 | } | |
737 | ||
738 | /** | |
739 | * This method adds household's data to the contact table | |
740 | * | |
741 | * The following fields are generated and added. | |
742 | * | |
743 | * contact_uuid - household_individual | |
744 | * contact_rid - latest one | |
156ca3ec EM |
745 | * household_name 'household $contact_uuid primary contact |
746 | * $primary_contact_uuid' nick_name 'nick $contact_uuid' primary_contact_uuid | |
747 | * = $household_individual[$contact_uuid][0]; | |
3a2a6e86 TO |
748 | * |
749 | */ | |
750 | private function addHousehold() { | |
751 | ||
752 | $contact = new CRM_Contact_DAO_Contact(); | |
753 | foreach ($this->Household as $cid) { | |
754 | // Add address | |
755 | $this->_addAddress($cid); | |
756 | ||
757 | $contact->id = $cid; | |
758 | $contact->household_name = $this->householdName[$cid] . " family"; | |
759 | // need to update the sort name for the main contact table | |
760 | $contact->display_name = $contact->sort_name = $contact->household_name; | |
761 | $contact->postal_greeting_id = $contact->email_greeting_id = 5; | |
762 | $contact->postal_greeting_display = $contact->email_greeting_display = 'Dear ' . $contact->household_name; | |
763 | $contact->addressee_id = 2; | |
764 | $contact->addressee_display = $contact->display_name; | |
765 | $contact->hash = crc32($contact->sort_name); | |
766 | $this->_update($contact); | |
767 | } | |
768 | } | |
769 | ||
770 | /** | |
771 | * This method adds organization data to the contact table | |
772 | * | |
773 | * The following fields are generated and added. | |
774 | * | |
775 | * contact_uuid - organization | |
776 | * contact_rid - latest one | |
777 | * organization_name 'organization $contact_uuid' | |
778 | * legal_name 'legal $contact_uuid' | |
779 | * nick_name 'nick $contact_uuid' | |
780 | * sic_code 'sic $contact_uuid' | |
781 | * primary_contact_id - random individual contact uuid | |
782 | * | |
783 | */ | |
784 | private function addOrganization() { | |
785 | ||
786 | $org = new CRM_Contact_DAO_Contact(); | |
787 | $employees = $this->Individual; | |
0049e17a | 788 | $employees = $this->shuffle($employees); |
3a2a6e86 TO |
789 | |
790 | foreach ($this->Organization as $key => $id) { | |
791 | $org->primary_contact_id = $website = $email = NULL; | |
792 | $org->id = $id; | |
793 | $address = $this->_addAddress($id); | |
794 | ||
795 | $namePre = $this->randomItem('organization_prefix'); | |
796 | $nameMid = $this->randomItem('organization_name'); | |
797 | $namePost = $this->randomItem('organization_suffix'); | |
798 | ||
799 | // Some orgs are named after their location | |
800 | if ($this->probability(.7)) { | |
156ca3ec | 801 | $place = $this->randomItem(['city', 'street_name', 'state']); |
3a2a6e86 TO |
802 | $namePre = $address[$place]; |
803 | } | |
804 | $org->organization_name = "$namePre $nameMid $namePost"; | |
805 | ||
806 | // Most orgs have a website and email | |
807 | if ($this->probability(.8)) { | |
808 | $website = $this->_addWebsite($id, $org->organization_name); | |
809 | $url = str_replace('http://', '', $website['url']); | |
810 | $email = $this->randomItem('email_address') . '@' . $url; | |
811 | $this->_addEmail($id, $email, self::MAIN); | |
812 | } | |
813 | ||
814 | // current employee | |
815 | if ($this->probability(.8)) { | |
816 | $indiv = new CRM_Contact_DAO_Contact(); | |
817 | $org->primary_contact_id = $indiv->id = $employees[$key]; | |
818 | $indiv->organization_name = $org->organization_name; | |
819 | $indiv->employer_id = $id; | |
820 | $this->_update($indiv); | |
821 | // Share address with employee | |
822 | if ($this->probability(.8)) { | |
823 | $this->_addAddress($indiv->id, $id); | |
824 | } | |
825 | // Add work email for employee | |
826 | if ($website) { | |
827 | $indiv->find(TRUE); | |
828 | $email = $this->_individualEmail($indiv, $url); | |
829 | $this->_addEmail($indiv->id, $email, self::WORK); | |
830 | } | |
831 | } | |
832 | ||
833 | // need to update the sort name for the main contact table | |
834 | $org->display_name = $org->sort_name = $org->organization_name; | |
835 | $org->addressee_id = 3; | |
836 | $org->addressee_display = $org->display_name; | |
837 | $org->hash = crc32($org->sort_name); | |
838 | $this->_update($org); | |
839 | } | |
840 | } | |
841 | ||
842 | /** | |
843 | * This method adds data to the contact_relationship table | |
844 | */ | |
845 | private function addRelationship() { | |
846 | ||
847 | $relationship = new CRM_Contact_DAO_Relationship(); | |
848 | ||
849 | // Household relationships | |
850 | foreach ($this->householdIndividual as $household_id => $household_member) { | |
851 | // Default active | |
852 | $relationship->is_active = 1; | |
853 | ||
854 | // add child_of relationship for each child | |
855 | $relationship->relationship_type_id = $this->relTypes['Child of']['id']; | |
156ca3ec EM |
856 | foreach ([0, 1] as $parent) { |
857 | foreach ([2, 3] as $child) { | |
3a2a6e86 TO |
858 | $relationship->contact_id_a = $household_member[$child]; |
859 | $relationship->contact_id_b = $household_member[$parent]; | |
860 | $this->_insert($relationship); | |
861 | } | |
862 | } | |
863 | ||
864 | // add sibling_of relationship | |
865 | $relationship->relationship_type_id = $this->relTypes['Sibling of']['id']; | |
866 | $relationship->contact_id_a = $household_member[3]; | |
867 | $relationship->contact_id_b = $household_member[2]; | |
868 | $this->_insert($relationship); | |
869 | ||
870 | // add member_of_household relationships and shared address | |
871 | $relationship->relationship_type_id = $this->relTypes['Household Member of']['id']; | |
872 | $relationship->contact_id_b = $household_id; | |
873 | for ($i = 1; $i < 4; ++$i) { | |
874 | $relationship->contact_id_a = $household_member[$i]; | |
875 | $this->_insert($relationship); | |
876 | $this->_addAddress($household_member[$i], $household_id); | |
877 | } | |
878 | ||
879 | // Divorced/separated couples - end relationship and different address | |
880 | if ($this->probability(.4)) { | |
881 | $relationship->is_active = 0; | |
882 | $this->_addAddress($household_member[0]); | |
883 | } | |
884 | else { | |
885 | $this->_addAddress($household_member[0], $household_id); | |
886 | } | |
887 | ||
888 | // add head_of_household relationship 1 for head of house | |
889 | $relationship->relationship_type_id = $this->relTypes['Head of Household for']['id']; | |
890 | $relationship->contact_id_a = $household_member[0]; | |
891 | $relationship->contact_id_b = $household_id; | |
892 | $this->_insert($relationship); | |
893 | ||
894 | // add spouse_of relationship 1 for both the spouses | |
895 | $relationship->relationship_type_id = $this->relTypes['Spouse of']['id']; | |
896 | $relationship->contact_id_a = $household_member[1]; | |
897 | $relationship->contact_id_b = $household_member[0]; | |
898 | $this->_insert($relationship); | |
899 | } | |
900 | ||
901 | // Add current employer relationships | |
902 | $this->_query("INSERT INTO civicrm_relationship | |
903 | (contact_id_a, contact_id_b, relationship_type_id, is_active) | |
904 | (SELECT id, employer_id, " . $this->relTypes['Employee of']['id'] . ", 1 FROM civicrm_contact WHERE employer_id IN (" . implode(',', $this->Organization) . "))" | |
905 | ); | |
906 | } | |
907 | ||
908 | /** | |
909 | * Create an address for a contact | |
910 | * | |
911 | * @param $cid int: contact id | |
912 | * @param $masterContactId int: set if this is a shared address | |
913 | * | |
914 | * @return array | |
915 | */ | |
916 | private function _addAddress($cid, $masterContactId = NULL) { | |
917 | ||
918 | // Share existing address | |
919 | if ($masterContactId) { | |
920 | $dao = new CRM_Core_DAO_Address(); | |
921 | $dao->is_primary = 1; | |
922 | $dao->contact_id = $masterContactId; | |
923 | $dao->find(TRUE); | |
924 | $dao->master_id = $dao->id; | |
925 | $dao->id = NULL; | |
926 | $dao->contact_id = $cid; | |
927 | $dao->is_primary = $this->isPrimary($cid, 'Address'); | |
928 | $dao->location_type_id = $this->getContactType($masterContactId) == 'Organization' ? self::WORK : self::HOME; | |
929 | $this->_insert($dao); | |
930 | } | |
931 | ||
932 | // Generate new address | |
933 | else { | |
156ca3ec | 934 | $params = [ |
3a2a6e86 TO |
935 | 'contact_id' => $cid, |
936 | 'location_type_id' => $this->getContactType($cid) == 'Organization' ? self::MAIN : self::HOME, | |
38cdbfc7 | 937 | 'street_number' => $this->randomInt(1, 1000), |
3a2a6e86 TO |
938 | 'street_number_suffix' => ucfirst($this->randomChar()), |
939 | 'street_name' => $this->randomItem('street_name'), | |
940 | 'street_type' => $this->randomItem('street_type'), | |
941 | 'street_number_postdirectional' => $this->randomItem('address_direction'), | |
942 | 'county_id' => 1, | |
156ca3ec | 943 | ]; |
3a2a6e86 TO |
944 | |
945 | $params['street_address'] = $params['street_number'] . $params['street_number_suffix'] . " " . $params['street_name'] . " " . $params['street_type'] . " " . $params['street_number_postdirectional']; | |
946 | ||
947 | if ($params['location_type_id'] == self::MAIN) { | |
948 | $params['supplemental_address_1'] = $this->randomItem('supplemental_addresses_1'); | |
949 | } | |
950 | ||
951 | // Hack to add lat/long (limited to USA based addresses) | |
be946912 | 952 | $params = array_merge($params, $this->getZipCodeInfo()); |
3a2a6e86 TO |
953 | |
954 | $this->_addDAO('Address', $params); | |
955 | $params['state'] = $this->states[$params['state_province_id']]; | |
956 | return $params; | |
957 | } | |
958 | } | |
959 | ||
960 | /** | |
961 | * Add a phone number for a contact | |
962 | * | |
963 | * @param $cid int: contact id | |
964 | * | |
965 | * @return array | |
966 | */ | |
967 | private function _addPhone($cid) { | |
38cdbfc7 TO |
968 | $area = $this->probability(.5) ? '' : $this->randomInt(201, 899); |
969 | $pre = $this->randomInt(201, 899); | |
970 | $post = $this->randomInt(1000, 9999); | |
156ca3ec | 971 | $params = [ |
3a2a6e86 TO |
972 | 'location_type_id' => $this->getContactType($cid) == 'Organization' ? self::MAIN : self::HOME, |
973 | 'contact_id' => $cid, | |
974 | 'phone' => ($area ? "($area) " : '') . "$pre-$post", | |
975 | 'phone_numeric' => $area . $pre . $post, | |
38cdbfc7 | 976 | 'phone_type_id' => $this->randomInt(1, 2), |
156ca3ec | 977 | ]; |
3a2a6e86 TO |
978 | $this->_addDAO('Phone', $params); |
979 | return $params; | |
980 | } | |
981 | ||
982 | /** | |
983 | * Add an email for a contact | |
984 | * | |
985 | * @param $cid int: contact id | |
986 | * @param $email | |
987 | * @param $locationType | |
988 | * | |
989 | * @return array | |
990 | */ | |
991 | private function _addEmail($cid, $email, $locationType) { | |
156ca3ec | 992 | $params = [ |
3a2a6e86 TO |
993 | 'location_type_id' => $locationType, |
994 | 'contact_id' => $cid, | |
995 | 'email' => $email, | |
156ca3ec | 996 | ]; |
3a2a6e86 TO |
997 | $this->_addDAO('Email', $params); |
998 | return $params; | |
999 | } | |
1000 | ||
1001 | /** | |
1002 | * Add a website based on organization name | |
1003 | * Using common naming patterns | |
1004 | * | |
1005 | * @param $cid int: contact id | |
1006 | * @param $name str: contact name | |
1007 | * | |
1008 | * @return array | |
1009 | */ | |
1010 | private function _addWebsite($cid, $name) { | |
1011 | $part = array_pad(explode(' ', strtolower($name)), 3, ''); | |
1012 | if (count($part) > 3) { | |
1013 | // Abbreviate the place name if it's two words | |
1014 | $domain = $part[0][0] . $part[1][0] . $part[2] . $part[3]; | |
1015 | } | |
1016 | else { | |
1017 | // Common naming patterns | |
38cdbfc7 | 1018 | switch ($this->randomInt(1, 3)) { |
3a2a6e86 TO |
1019 | case 1: |
1020 | $domain = $part[0] . $part[1] . $part[2]; | |
1021 | break; | |
1022 | ||
1023 | case 2: | |
1024 | $domain = $part[0] . $part[1]; | |
1025 | break; | |
1026 | ||
1027 | case 3: | |
1028 | $domain = $part[0] . $part[2]; | |
1029 | break; | |
1030 | } | |
1031 | } | |
156ca3ec | 1032 | $params = [ |
3a2a6e86 TO |
1033 | 'website_type_id' => 1, |
1034 | 'location_type_id' => self::MAIN, | |
1035 | 'contact_id' => $cid, | |
1036 | 'url' => "http://$domain.org", | |
156ca3ec | 1037 | ]; |
3a2a6e86 TO |
1038 | $this->_addDAO('Website', $params); |
1039 | return $params; | |
1040 | } | |
1041 | ||
1042 | /** | |
1043 | * Create an email address based on a person's name | |
1044 | * Using common naming patterns | |
1045 | * | |
1046 | * @param $contact obj: individual contact record | |
1047 | * @param $domain str: supply a domain (i.e. for a work address) | |
1048 | * | |
1049 | * @return string | |
1050 | */ | |
1051 | private function _individualEmail($contact, $domain = NULL) { | |
1052 | $first = $contact->first_name; | |
1053 | $last = $contact->last_name; | |
1054 | $f = $first[0]; | |
1055 | $l = $last[0]; | |
1056 | $m = $contact->middle_name ? $contact->middle_name[0] . '.' : ''; | |
1057 | // Common naming patterns | |
38cdbfc7 | 1058 | switch ($this->randomInt(1, 6)) { |
3a2a6e86 TO |
1059 | case 1: |
1060 | $email = $first . $last; | |
1061 | break; | |
1062 | ||
1063 | case 2: | |
1064 | $email = "$last.$first"; | |
1065 | break; | |
1066 | ||
1067 | case 3: | |
1068 | $email = $last . $f; | |
1069 | break; | |
1070 | ||
1071 | case 4: | |
1072 | $email = $first . $l; | |
1073 | break; | |
1074 | ||
1075 | case 5: | |
1076 | $email = "$last.$m$first"; | |
1077 | break; | |
1078 | ||
1079 | case 6: | |
1080 | $email = "$f$m$last"; | |
1081 | break; | |
1082 | } | |
1083 | //to ensure we dont insert | |
1084 | //invalid characters in email | |
1085 | $email = preg_replace("([^a-zA-Z0-9_\.-]*)", "", $email); | |
1086 | ||
1087 | // Some people have numbers in their address | |
1088 | if ($this->probability(.4)) { | |
38cdbfc7 | 1089 | $email .= $this->randomInt(1, 99); |
3a2a6e86 TO |
1090 | } |
1091 | // Generate random domain if not specified | |
1092 | if (!$domain) { | |
1093 | $domain = $this->randomItem('email_domain') . '.' . $this->randomItem('email_tld'); | |
1094 | } | |
1095 | return strtolower($email) . '@' . $domain; | |
1096 | } | |
1097 | ||
1098 | /** | |
1099 | * This method populates the civicrm_entity_tag table | |
1100 | */ | |
1101 | private function addEntityTag() { | |
1102 | ||
1103 | $entity_tag = new CRM_Core_DAO_EntityTag(); | |
1104 | ||
1105 | // add categories 1,2,3 for Organizations. | |
1106 | for ($i = 0; $i < $this->numOrganization; $i += 2) { | |
1107 | $org_id = $this->Organization[$i]; | |
1108 | // echo "org_id = $org_id\n"; | |
1109 | $entity_tag->entity_id = $this->Organization[$i]; | |
1110 | $entity_tag->entity_table = 'civicrm_contact'; | |
38cdbfc7 | 1111 | $entity_tag->tag_id = $this->randomInt(1, 3); |
3a2a6e86 TO |
1112 | $this->_insert($entity_tag); |
1113 | } | |
1114 | ||
1115 | // add categories 4,5 for Individuals. | |
1116 | for ($i = 0; $i < $this->numIndividual; $i += 2) { | |
1117 | $entity_tag->entity_table = 'civicrm_contact'; | |
1118 | $entity_tag->entity_id = $this->Individual[$i]; | |
1119 | if (($entity_tag->entity_id) % 3) { | |
38cdbfc7 | 1120 | $entity_tag->tag_id = $this->randomInt(4, 5); |
3a2a6e86 TO |
1121 | $this->_insert($entity_tag); |
1122 | } | |
1123 | else { | |
1124 | // some of the individuals are in both categories (4 and 5). | |
1125 | $entity_tag->tag_id = 4; | |
1126 | $this->_insert($entity_tag); | |
1127 | $entity_tag->tag_id = 5; | |
1128 | $this->_insert($entity_tag); | |
1129 | } | |
1130 | } | |
1131 | } | |
1132 | ||
1133 | /** | |
1134 | * This method populates the civicrm_group_contact table | |
067907d7 EM |
1135 | * |
1136 | * @throws \API_Exception | |
3a2a6e86 TO |
1137 | */ |
1138 | private function addGroup() { | |
1139 | // add the 3 groups first | |
1140 | foreach ($this->sampleData['group'] as $groupName) { | |
1141 | $group = new CRM_Contact_BAO_Group(); | |
1142 | $group->name = $group->title = $groupName; | |
1143 | $group->group_type = "\ 11\ 12\ 1"; | |
1144 | $group->visibility = 'Public Pages'; | |
1145 | $group->is_active = 1; | |
1146 | $group->save(); | |
1147 | } | |
1148 | ||
1149 | // 60 are for newsletter | |
1150 | for ($i = 0; $i < 60; $i++) { | |
1151 | $groupContact = new CRM_Contact_DAO_GroupContact(); | |
1152 | // newsletter subscribers | |
1153 | $groupContact->group_id = 2; | |
1154 | $groupContact->contact_id = $this->Individual[$i]; | |
1155 | // always add members | |
1156 | $groupContact->status = 'Added'; | |
1157 | ||
1158 | $subscriptionHistory = new CRM_Contact_DAO_SubscriptionHistory(); | |
1159 | $subscriptionHistory->contact_id = $groupContact->contact_id; | |
1160 | ||
1161 | $subscriptionHistory->group_id = $groupContact->group_id; | |
1162 | $subscriptionHistory->status = $groupContact->status; | |
1163 | // method | |
1164 | $subscriptionHistory->method = $this->randomItem($this->subscriptionHistoryMethod); | |
1165 | $subscriptionHistory->date = $this->randomDate(); | |
067907d7 | 1166 | if ($groupContact->status !== 'Pending') { |
3a2a6e86 TO |
1167 | $this->_insert($groupContact); |
1168 | } | |
1169 | $this->_insert($subscriptionHistory); | |
1170 | } | |
1171 | ||
1172 | // 15 volunteers | |
1173 | for ($i = 0; $i < 15; $i++) { | |
1174 | $groupContact = new CRM_Contact_DAO_GroupContact(); | |
1175 | // Volunteers | |
1176 | $groupContact->group_id = 3; | |
1177 | $groupContact->contact_id = $this->Individual[$i + 60]; | |
1178 | // membership status | |
1179 | $groupContact->status = 'Added'; | |
1180 | ||
1181 | $subscriptionHistory = new CRM_Contact_DAO_SubscriptionHistory(); | |
1182 | $subscriptionHistory->contact_id = $groupContact->contact_id; | |
1183 | $subscriptionHistory->group_id = $groupContact->group_id; | |
1184 | $subscriptionHistory->status = $groupContact->status; | |
1185 | // method | |
1186 | $subscriptionHistory->method = $this->randomItem($this->subscriptionHistoryMethod); | |
1187 | $subscriptionHistory->date = $this->randomDate(); | |
1188 | ||
067907d7 | 1189 | if ($groupContact->status !== 'Pending') { |
3a2a6e86 TO |
1190 | $this->_insert($groupContact); |
1191 | } | |
1192 | $this->_insert($subscriptionHistory); | |
1193 | } | |
1194 | ||
067907d7 EM |
1195 | // 8 advisory board group + 1 with a login |
1196 | for ($i = 0; $i < 9; $i++) { | |
3a2a6e86 TO |
1197 | $groupContact = new CRM_Contact_DAO_GroupContact(); |
1198 | // advisory board group | |
1199 | $groupContact->group_id = 4; | |
067907d7 EM |
1200 | if ($i !== 8) { |
1201 | $groupContact->contact_id = $this->Individual[$i * 7]; | |
1202 | } | |
1203 | else { | |
1204 | $advisorID = Contact::create(FALSE)->setValues([ | |
1205 | 'first_name' => 'Jenny', | |
1206 | 'last_name' => 'Lee', | |
1207 | 'contact_type' => 'Individual', | |
1208 | 'job_title' => 'Volunteer coordinator', | |
1209 | ])->addChain('email', Email::create(FALSE)->setValues([ | |
1210 | 'contact_id' => '$id', | |
1211 | 'email' => 'jenny@example.com', | |
1212 | ])) | |
1213 | ->execute()->first()['id']; | |
1214 | $groupContact->contact_id = $advisorID; | |
1215 | } | |
3a2a6e86 TO |
1216 | // membership status |
1217 | $groupContact->status = 'Added'; | |
1218 | ||
1219 | $subscriptionHistory = new CRM_Contact_DAO_SubscriptionHistory(); | |
1220 | $subscriptionHistory->contact_id = $groupContact->contact_id; | |
1221 | $subscriptionHistory->group_id = $groupContact->group_id; | |
1222 | $subscriptionHistory->status = $groupContact->status; | |
1223 | // method | |
1224 | $subscriptionHistory->method = $this->randomItem($this->subscriptionHistoryMethod); | |
1225 | $subscriptionHistory->date = $this->randomDate(); | |
1226 | ||
067907d7 | 1227 | if ($groupContact->status !== 'Pending') { |
3a2a6e86 TO |
1228 | $this->_insert($groupContact); |
1229 | } | |
1230 | $this->_insert($subscriptionHistory); | |
1231 | } | |
1232 | ||
1233 | //In this function when we add groups that time we are cache the contact fields | |
1234 | //But at the end of setup we are appending sample custom data, so for consistency | |
1235 | //reset the cache. | |
1236 | Civi::cache('fields')->flush(); | |
1237 | CRM_Core_BAO_Cache::resetCaches(); | |
1238 | } | |
1239 | ||
067907d7 EM |
1240 | /** |
1241 | * This method sets up a basic ACL. | |
1242 | * | |
1243 | * It allows the members of the advisory group to edit the Summer volunteers group. | |
1244 | * | |
1245 | * @throws \API_Exception | |
1246 | */ | |
1247 | private function addACL(): void { | |
1248 | $optionValueID = OptionValue::create(FALSE)->setValues([ | |
1249 | 'option_group_id:name' => 'acl_role', | |
1250 | 'value' => 3, | |
1251 | 'name' => 'Advisory Board', | |
1252 | 'label' => 'Advisory Board', | |
1253 | ]) | |
1254 | ->execute()->first()['id']; | |
1255 | $advisoryGroupID = Group::get(FALSE) | |
1256 | ->addWhere('name', '=', 'Advisory Board') | |
1257 | ->execute()->first()['id']; | |
1258 | $roleID = ACLEntityRole::create(FALSE)->setValues([ | |
1259 | 'entity_table' => 'civicrm_group', | |
1260 | 'acl_role_id' => $optionValueID, | |
1261 | 'entity_id' => $advisoryGroupID, | |
1262 | ])->execute()->first()['id']; | |
1263 | $volunteerID = Group::get(FALSE) | |
1264 | ->addWhere('name', '=', 'Summer Program Volunteers') | |
1265 | ->execute()->first()['id']; | |
1266 | ||
1267 | ACL::create(FALSE)->setValues([ | |
1268 | 'name' => 'Advisory board access to volunteers', | |
1269 | 'entity_table' => 'civicrm_acl_role', | |
1270 | 'operation' => 'Edit', | |
1271 | 'object_table' => 'civicrm_saved_search', | |
1272 | 'entity_id' => $roleID, | |
1273 | 'object_id' => $volunteerID, | |
1274 | ])->execute(); | |
1275 | } | |
1276 | ||
3a2a6e86 TO |
1277 | /** |
1278 | * This method populates the civicrm_note table | |
1279 | */ | |
1280 | private function addNote() { | |
156ca3ec | 1281 | $params = [ |
3a2a6e86 TO |
1282 | 'entity_table' => 'civicrm_contact', |
1283 | 'contact_id' => 1, | |
1284 | 'privacy' => 0, | |
156ca3ec | 1285 | ]; |
3a2a6e86 TO |
1286 | for ($i = 0; $i < self::NUM_CONTACT; $i += 10) { |
1287 | $params['entity_id'] = $this->randomItem($this->contact); | |
1288 | $params['note'] = $this->randomItem('note'); | |
1289 | $params['modified_date'] = $this->randomDate(); | |
1290 | $this->_addDAO('Note', $params); | |
1291 | } | |
1292 | } | |
1293 | ||
1294 | /** | |
1295 | * This method populates the civicrm_activity_history table | |
1296 | */ | |
1297 | private function addActivity() { | |
1298 | $contactDAO = new CRM_Contact_DAO_Contact(); | |
1299 | $contactDAO->contact_type = 'Individual'; | |
1300 | $contactDAO->selectAdd(); | |
1301 | $contactDAO->selectAdd('id'); | |
1302 | $contactDAO->orderBy('sort_name'); | |
1303 | $contactDAO->find(); | |
1304 | ||
1305 | $count = 0; | |
1306 | $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); | |
1307 | while ($contactDAO->fetch()) { | |
1308 | if ($count++ > 2) { | |
1309 | break; | |
1310 | } | |
1311 | for ($i = 0; $i < self::NUM_ACTIVITY; $i++) { | |
1312 | $activityDAO = new CRM_Activity_DAO_Activity(); | |
1313 | $activityId = CRM_Core_OptionGroup::values('activity_type', NULL, NULL, NULL, ' AND v.name IN ("Tell A Friend", "Pledge Acknowledgment")'); | |
0049e17a | 1314 | $activityTypeID = $this->randomIndex($activityId); |
3a2a6e86 TO |
1315 | $activity = CRM_Core_PseudoConstant::activityType(); |
1316 | $activityDAO->activity_type_id = $activityTypeID; | |
1317 | $activityDAO->subject = "Subject for $activity[$activityTypeID]"; | |
1318 | $activityDAO->activity_date_time = $this->randomDate(); | |
1319 | $activityDAO->status_id = 2; | |
1320 | $this->_insert($activityDAO); | |
1321 | ||
1322 | $activityContactDAO = new CRM_Activity_DAO_ActivityContact(); | |
1323 | $activityContactDAO->activity_id = $activityDAO->id; | |
1324 | $activityContactDAO->contact_id = $contactDAO->id; | |
1325 | $activityContactDAO->record_type_id = CRM_Utils_Array::key('Activity Source', $activityContacts); | |
1326 | $this->_insert($activityContactDAO); | |
1327 | ||
1328 | if ($activityTypeID == 9) { | |
1329 | $activityContactDAO = new CRM_Activity_DAO_ActivityContact(); | |
1330 | $activityContactDAO->activity_id = $activityDAO->id; | |
38cdbfc7 | 1331 | $activityContactDAO->contact_id = $this->randomInt(1, 101); |
3a2a6e86 TO |
1332 | $activityContactDAO->record_type_id = CRM_Utils_Array::key('Activity Targets', $activityContacts); |
1333 | $this->_insert($activityContactDAO); | |
1334 | } | |
1335 | } | |
1336 | } | |
1337 | } | |
1338 | ||
1339 | /** | |
1340 | * @return array | |
1341 | */ | |
1342 | public function getZipCodeInfo() { | |
1343 | ||
1344 | if (!$this->stateMap) { | |
156ca3ec | 1345 | $query = 'SELECT id, name, abbreviation FROM civicrm_state_province WHERE country_id = 1228'; |
3a2a6e86 TO |
1346 | $dao = new CRM_Core_DAO(); |
1347 | $dao->query($query); | |
156ca3ec | 1348 | $this->stateMap = []; |
3a2a6e86 TO |
1349 | while ($dao->fetch()) { |
1350 | $this->stateMap[$dao->abbreviation] = $dao->id; | |
1351 | $this->states[$dao->id] = $dao->name; | |
1352 | } | |
1353 | } | |
1354 | ||
1355 | static $zipCodes = NULL; | |
1356 | if ($zipCodes === NULL) { | |
d94d506c | 1357 | $zipCodes = json_decode(file_get_contents(self::getCivicrmDir() . '/sql/zipcodes.json')); |
3a2a6e86 TO |
1358 | } |
1359 | ||
38cdbfc7 | 1360 | $zipCode = $zipCodes[$this->randomInt(0, count($zipCodes))]; |
3a2a6e86 TO |
1361 | |
1362 | if ($this->stateMap[$zipCode->state]) { | |
1363 | $stateID = $this->stateMap[$zipCode->state]; | |
1364 | } | |
1365 | else { | |
1366 | $stateID = 1004; | |
1367 | } | |
1368 | ||
1369 | $zip = str_pad($zipCode->zip, 5, '0', STR_PAD_LEFT); | |
be946912 EM |
1370 | return [ |
1371 | 'country_id' => 1228, | |
1372 | 'state_province_id' => $stateID, | |
1373 | 'city' => $zipCode->city, | |
1374 | 'postal_code' => $zip, | |
1375 | 'geo_code_1' => $zipCode->latitude, | |
1376 | 'geo_code_2' => $zipCode->longitude, | |
1377 | ]; | |
3a2a6e86 TO |
1378 | } |
1379 | ||
1380 | /** | |
1381 | * @param $zipCode | |
1382 | * | |
1383 | * @return array | |
1384 | */ | |
1385 | public static function getLatLong($zipCode) { | |
1386 | $query = "http://maps.google.com/maps?q=$zipCode&output=js"; | |
1387 | $userAgent = "Mozilla/5.0 (Macintosh; U; PPC Mac OS X Mach-O; en-US; rv:1.7.5) Gecko/20041107 Firefox/1.0"; | |
1388 | ||
1389 | $ch = curl_init(); | |
1390 | curl_setopt($ch, CURLOPT_URL, $query); | |
1391 | curl_setopt($ch, CURLOPT_HEADER, FALSE); | |
1392 | curl_setopt($ch, CURLOPT_USERAGENT, $userAgent); | |
1393 | curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); | |
1394 | ||
1395 | // grab URL and pass it to the browser | |
1396 | $outstr = curl_exec($ch); | |
1397 | ||
1398 | // close CURL resource, and free up system resources | |
1399 | curl_close($ch); | |
1400 | ||
1401 | $preg = "/'(<\?xml.+?)',/s"; | |
1402 | preg_match($preg, $outstr, $matches); | |
1403 | if ($matches[1]) { | |
1404 | $xml = simplexml_load_string($matches[1]); | |
1405 | $attributes = $xml->center->attributes(); | |
1406 | if (!empty($attributes)) { | |
156ca3ec | 1407 | return [(float ) $attributes['lat'], (float ) $attributes['lng']]; |
3a2a6e86 TO |
1408 | } |
1409 | } | |
156ca3ec | 1410 | return [NULL, NULL]; |
3a2a6e86 TO |
1411 | } |
1412 | ||
1413 | private function addMembershipType() { | |
1414 | $organizationDAO = new CRM_Contact_DAO_Contact(); | |
1415 | $organizationDAO->id = 5; | |
1416 | $organizationDAO->find(TRUE); | |
1417 | $contact_id = $organizationDAO->contact_id; | |
1418 | ||
1419 | $membershipType = "INSERT INTO civicrm_membership_type | |
1420 | (name, description, member_of_contact_id, financial_type_id, minimum_fee, duration_unit, duration_interval, period_type, fixed_period_start_day, fixed_period_rollover_day, relationship_type_id, relationship_direction, visibility, weight, is_active) | |
1421 | VALUES | |
1422 | ('General', 'Regular annual membership.', " . $contact_id . ", 2, 100, 'year', 1, 'rolling',null, null, 7, 'b_a', 'Public', 1, 1), | |
1423 | ('Student', 'Discount membership for full-time students.', " . $contact_id . ", 2, 50, 'year', 1, 'rolling', null, null, 7, 'b_a', 'Public', 2, 1), | |
1424 | ('Lifetime', 'Lifetime membership.', " . $contact_id . ", 2, 1200, 'lifetime', 1, 'rolling', null, null, 7, 'b_a', 'Admin', 3, 1); | |
1425 | "; | |
1426 | $this->_query($membershipType); | |
1427 | } | |
1428 | ||
1429 | private function addMembership() { | |
1430 | $contact = new CRM_Contact_DAO_Contact(); | |
156ca3ec | 1431 | $contact->query("SELECT id FROM civicrm_contact WHERE contact_type = 'Individual'"); |
3a2a6e86 TO |
1432 | $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); |
1433 | while ($contact->fetch()) { | |
1434 | $contacts[] = $contact->id; | |
1435 | } | |
0049e17a | 1436 | $contacts = $this->shuffle($contacts); |
3a2a6e86 TO |
1437 | |
1438 | $randomContacts = array_slice($contacts, 20, 30); | |
1439 | ||
156ca3ec EM |
1440 | $sources = ['Payment', 'Donation', 'Check']; |
1441 | $membershipTypes = [1, 2]; | |
1442 | $membershipTypeNames = ['General', 'Student']; | |
1443 | $statuses = [3, 4]; | |
3a2a6e86 TO |
1444 | |
1445 | $membership = " | |
1446 | INSERT INTO civicrm_membership | |
1447 | (contact_id, membership_type_id, join_date, start_date, end_date, source, status_id) | |
1448 | VALUES | |
1449 | "; | |
1450 | ||
1451 | $activity = " | |
1452 | INSERT INTO civicrm_activity | |
1453 | (source_record_id, activity_type_id, subject, activity_date_time, duration, location, phone_id, phone_number, details, priority_id,parent_id, is_test, status_id) | |
1454 | VALUES | |
1455 | "; | |
1456 | ||
1457 | $activityContact = " | |
1458 | INSERT INTO civicrm_activity_contact | |
1459 | (activity_id, contact_id, record_type_id) | |
1460 | VALUES | |
1461 | "; | |
1462 | ||
1463 | $currentActivityID = CRM_Core_DAO::singleValueQuery("SELECT MAX(id) FROM civicrm_activity"); | |
1464 | $sourceID = CRM_Utils_Array::key('Activity Source', $activityContacts); | |
1465 | foreach ($randomContacts as $count => $dontCare) { | |
1466 | $source = $this->randomItem($sources); | |
1467 | $activitySourceId = $count + 1; | |
1468 | $currentActivityID++; | |
1469 | $activityContact .= "( $currentActivityID, {$randomContacts[$count]}, {$sourceID} )"; | |
1470 | if ((($count + 1) % 11 == 0)) { | |
1471 | // lifetime membership, status can be anything | |
1472 | $startDate = date('Y-m-d', mktime(0, 0, 0, date('m'), (date('d') - $count), date('Y'))); | |
1473 | $membership .= "( {$randomContacts[$count]}, 3, '{$startDate}', '{$startDate}', null, '{$source}', 1)"; | |
1474 | $activity .= "( {$activitySourceId}, 7, 'Lifetime', '{$startDate} 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 )"; | |
1475 | } | |
1476 | elseif (($count + 1) % 5 == 0) { | |
1477 | // Grace or expired, memberhsip type is random of 1 & 2 | |
0049e17a | 1478 | $randIndex = $this->randomIndex($membershipTypes); |
3a2a6e86 TO |
1479 | $membershipTypeId = $membershipTypes[$randIndex]; |
1480 | $membershipStatusId = $statuses[$randIndex]; | |
1481 | $membershipTypeName = $membershipTypeNames[$randIndex]; | |
1482 | $YearFactor = $membershipTypeId * 2; | |
1483 | //reverse the type and consider as year factor. | |
1484 | if ($YearFactor != 2) { | |
1485 | $YearFactor = 1; | |
1486 | } | |
1487 | $dateFactor = ($count * ($YearFactor) * ($YearFactor) * ($YearFactor)); | |
1488 | $startDate = date('Y-m-d', mktime(0, 0, 0, | |
1489 | date('m'), | |
1490 | (date('d') - ($dateFactor)), | |
1491 | (date('Y') - ($YearFactor)) | |
1492 | )); | |
1493 | $partOfDate = explode('-', $startDate); | |
1494 | $endDate = date('Y-m-d', mktime(0, 0, 0, | |
1495 | $partOfDate[1], | |
1496 | ($partOfDate[2] - 1), | |
1497 | ($partOfDate[0] + ($YearFactor)) | |
1498 | )); | |
1499 | ||
1500 | $membership .= "( {$randomContacts[$count]}, {$membershipTypeId}, '{$startDate}', '{$startDate}', '{$endDate}', '{$source}', {$membershipStatusId})"; | |
1501 | $activity .= "( {$activitySourceId}, 7, '{$membershipTypeName}', '{$startDate} 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 )"; | |
1502 | } | |
1503 | elseif (($count + 1) % 2 == 0) { | |
1504 | // membership type 2 | |
1505 | $startDate = date('Y-m-d', mktime(0, 0, 0, date('m'), (date('d') - $count), date('Y'))); | |
1506 | $endDate = date('Y-m-d', mktime(0, 0, 0, date('m'), (date('d') - ($count + 1)), (date('Y') + 1))); | |
1507 | $membership .= "( {$randomContacts[$count]}, 2, '{$startDate}', '{$startDate}', '{$endDate}', '{$source}', 1)"; | |
1508 | $activity .= "( {$activitySourceId}, 7, 'Student', '{$startDate} 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 )"; | |
1509 | } | |
1510 | else { | |
1511 | // membership type 1 | |
1512 | $startDate = date('Y-m-d', mktime(0, 0, 0, date('m'), (date('d') - $count), date('Y'))); | |
1513 | $endDate = date('Y-m-d', mktime(0, 0, 0, date('m'), (date('d') - ($count + 1)), (date('Y') + 2))); | |
1514 | $membership .= "( {$randomContacts[$count]}, 1, '{$startDate}', '{$startDate}', '{$endDate}', '{$source}', 1)"; | |
1515 | $activity .= "( {$activitySourceId}, 7, 'General', '{$startDate} 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 )"; | |
1516 | } | |
1517 | ||
1518 | if ($count != 29) { | |
1519 | $membership .= ","; | |
1520 | $activity .= ","; | |
1521 | $activityContact .= ","; | |
1522 | } | |
1523 | } | |
1524 | ||
1525 | $this->_query($membership); | |
1526 | $this->_query($activity); | |
1527 | $this->_query($activityContact); | |
1528 | } | |
1529 | ||
1530 | /** | |
1531 | * @param $date | |
1532 | * | |
1533 | * @return string | |
1534 | */ | |
1535 | public static function repairDate($date) { | |
156ca3ec | 1536 | $dropArray = ['-' => '', ':' => '', ' ' => '']; |
3a2a6e86 TO |
1537 | return strtr($date, $dropArray); |
1538 | } | |
1539 | ||
1540 | private function addMembershipLog() { | |
1541 | $membership = new CRM_Member_DAO_Membership(); | |
1542 | $membership->query("SELECT id FROM civicrm_membership"); | |
1543 | while ($membership->fetch()) { | |
1544 | $ids[] = $membership->id; | |
1545 | } | |
1546 | foreach ($ids as $id) { | |
1547 | $membership = new CRM_Member_DAO_Membership(); | |
1548 | $membership->id = $id; | |
1549 | $membershipLog = new CRM_Member_DAO_MembershipLog(); | |
1550 | if ($membership->find(TRUE)) { | |
1551 | $membershipLog->membership_id = $membership->id; | |
1552 | $membershipLog->status_id = $membership->status_id; | |
1553 | $membershipLog->start_date = self::repairDate($membership->start_date); | |
1554 | $membershipLog->end_date = self::repairDate($membership->end_date); | |
1555 | $membershipLog->modified_id = $membership->contact_id; | |
1556 | $membershipLog->modified_date = date("Ymd"); | |
1557 | $membershipLog->membership_type_id = $membership->membership_type_id; | |
1558 | $membershipLog->save(); | |
1559 | } | |
1560 | $membershipLog = NULL; | |
1561 | } | |
1562 | } | |
1563 | ||
1564 | private function addEvent() { | |
1565 | $event = "INSERT INTO civicrm_address ( contact_id, location_type_id, is_primary, is_billing, street_address, street_number, street_number_suffix, street_number_predirectional, street_name, street_type, street_number_postdirectional, street_unit, supplemental_address_1, supplemental_address_2, supplemental_address_3, city, county_id, state_province_id, postal_code_suffix, postal_code, usps_adc, country_id, geo_code_1, geo_code_2, timezone) | |
1566 | VALUES | |
1567 | ( NULL, 1, 1, 1, '14S El Camino Way E', 14, 'S', NULL, 'El Camino', 'Way', NULL, NULL, NULL, NULL, NULL, 'Collinsville', NULL, 1006, NULL, '6022', NULL, 1228, 41.8328, -72.9253, NULL), | |
1568 | ( NULL, 1, 1, 1, '11B Woodbridge Path SW', 11, 'B', NULL, 'Woodbridge', 'Path', NULL, NULL, NULL, NULL, NULL, 'Dayton', NULL, 1034, NULL, '45417', NULL, 1228, 39.7531, -84.2471, NULL), | |
1569 | ( NULL, 1, 1, 1, '581O Lincoln Dr SW', 581, 'O', NULL, 'Lincoln', 'Dr', NULL, NULL, NULL, NULL, NULL, 'Santa Fe', NULL, 1030, NULL, '87594', NULL, 1228, 35.5212, -105.982, NULL) | |
1570 | "; | |
1571 | $this->_query($event); | |
1572 | ||
156ca3ec | 1573 | $sql = "SELECT id FROM civicrm_address WHERE street_address = '14S El Camino Way E'"; |
3a2a6e86 | 1574 | $eventAdd1 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1575 | $sql = "SELECT id FROM civicrm_address WHERE street_address = '11B Woodbridge Path SW'"; |
3a2a6e86 | 1576 | $eventAdd2 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1577 | $sql = "SELECT id FROM civicrm_address WHERE street_address = '581O Lincoln Dr SW'"; |
3a2a6e86 TO |
1578 | $eventAdd3 = CRM_Core_DAO::singleValueQuery($sql); |
1579 | ||
1580 | $event = "INSERT INTO civicrm_email (contact_id, location_type_id, email, is_primary, is_billing, on_hold, hold_date, reset_date) | |
1581 | VALUES | |
1582 | (NULL, 1, 'development@example.org', 0, 0, 0, NULL, NULL), | |
1583 | (NULL, 1, 'tournaments@example.org', 0, 0, 0, NULL, NULL), | |
1584 | (NULL, 1, 'celebration@example.org', 0, 0, 0, NULL, NULL) | |
1585 | "; | |
1586 | $this->_query($event); | |
1587 | ||
156ca3ec | 1588 | $sql = "SELECT id FROM civicrm_email WHERE email = 'development@example.org'"; |
3a2a6e86 | 1589 | $eventEmail1 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1590 | $sql = "SELECT id FROM civicrm_email WHERE email = 'tournaments@example.org'"; |
3a2a6e86 | 1591 | $eventEmail2 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1592 | $sql = "SELECT id FROM civicrm_email WHERE email = 'celebration@example.org'"; |
3a2a6e86 TO |
1593 | $eventEmail3 = CRM_Core_DAO::singleValueQuery($sql); |
1594 | ||
1595 | $event = "INSERT INTO civicrm_phone (contact_id, location_type_id, is_primary, is_billing, mobile_provider_id, phone, phone_numeric, phone_type_id) | |
1596 | VALUES | |
1597 | (NULL, 1, 0, 0, NULL, '204 222-1000', '2042221000', '1'), | |
1598 | (NULL, 1, 0, 0, NULL, '204 223-1000', '2042231000', '1'), | |
1599 | (NULL, 1, 0, 0, NULL, '303 323-1000', '3033231000', '1') | |
1600 | "; | |
1601 | $this->_query($event); | |
1602 | ||
156ca3ec | 1603 | $sql = "SELECT id FROM civicrm_phone WHERE phone = '204 222-1000'"; |
3a2a6e86 | 1604 | $eventPhone1 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1605 | $sql = "SELECT id FROM civicrm_phone WHERE phone = '204 223-1000'"; |
3a2a6e86 | 1606 | $eventPhone2 = CRM_Core_DAO::singleValueQuery($sql); |
156ca3ec | 1607 | $sql = "SELECT id FROM civicrm_phone WHERE phone = '303 323-1000'"; |
3a2a6e86 TO |
1608 | $eventPhone3 = CRM_Core_DAO::singleValueQuery($sql); |
1609 | ||
1610 | $event = "INSERT INTO civicrm_loc_block ( address_id, email_id, phone_id, address_2_id, email_2_id, phone_2_id) | |
1611 | VALUES | |
1612 | ( $eventAdd1, $eventEmail1, $eventPhone1, NULL,NULL,NULL), | |
1613 | ( $eventAdd2, $eventEmail2, $eventPhone2, NULL,NULL,NULL), | |
1614 | ( $eventAdd3, $eventEmail3, $eventPhone3, NULL,NULL,NULL) | |
1615 | "; | |
1616 | ||
1617 | $this->_query($event); | |
1618 | ||
1619 | $sql = "SELECT id from civicrm_loc_block where phone_id = $eventPhone1 AND email_id = $eventEmail1 AND address_id = $eventAdd1"; | |
1620 | $eventLok1 = CRM_Core_DAO::singleValueQuery($sql); | |
1621 | $sql = "SELECT id from civicrm_loc_block where phone_id = $eventPhone2 AND email_id = $eventEmail2 AND address_id = $eventAdd2"; | |
1622 | $eventLok2 = CRM_Core_DAO::singleValueQuery($sql); | |
1623 | $sql = "SELECT id from civicrm_loc_block where phone_id = $eventPhone3 AND email_id = $eventEmail3 AND address_id = $eventAdd3"; | |
1624 | $eventLok3 = CRM_Core_DAO::singleValueQuery($sql); | |
1625 | ||
1626 | $event = "INSERT INTO civicrm_event | |
1627 | ( title, summary, description, event_type_id, participant_listing_id, is_public, start_date, end_date, is_online_registration, registration_link_text, max_participants, event_full_text, is_monetary, financial_type_id, is_map, is_active, fee_label, is_show_location, loc_block_id,intro_text, footer_text, confirm_title, confirm_text, confirm_footer_text, is_email_confirm, confirm_email_text, confirm_from_name, confirm_from_email, cc_confirm, bcc_confirm, default_fee_id, thankyou_title, thankyou_text, thankyou_footer_text, is_pay_later, pay_later_text, pay_later_receipt, is_multiple_registrations, allow_same_participant_emails, currency ) | |
1628 | VALUES | |
82d32482 TO |
1629 | ( 'Fall Fundraiser Dinner', 'Kick up your heels at our Fall Fundraiser Dinner/Dance at Glen Echo Park! Come by yourself or bring a partner, friend or the entire family!', 'This event benefits our teen programs. Admission includes a full 3 course meal and wine or soft drinks. Grab your dancing shoes, bring the kids and come join the party!', 3, 1, 1, '" . date('Y-m-d 17:00:00', strtotime("+6 months", $this->time)) . "', '" . date('Y-m-d 17:00:00', strtotime("+6 months +2 days", $this->time)) . "', 1, 'Register Now', 100, 'Sorry! The Fall Fundraiser Dinner is full. Please call Jane at 204 222-1000 ext 33 if you want to be added to the waiting list.', 1, 4, 1, 1, 'Dinner Contribution', 1 ,$eventLok1,'Fill in the information below to join as at this wonderful dinner event.', NULL, 'Confirm Your Registration Information', 'Review the information below carefully.', NULL, 1, 'Contact the Development Department if you need to make any changes to your registration.', 'Fundraising Dept.', 'development@example.org', NULL, NULL, NULL, 'Thanks for Registering!', '<p>Thank you for your support. Your contribution will help us build even better tools.</p><p>Please tell your friends and colleagues about this wonderful event.</p>', '<p><a href=https://civicrm.org>Back to CiviCRM Home Page</a></p>', 1, 'I will send payment by check', 'Send a check payable to Our Organization within 3 business days to hold your reservation. Checks should be sent to: 100 Main St., Suite 3, San Francisco CA 94110', 1, 0, 'USD' ), |
1630 | ( 'Summer Solstice Festival Day Concert', 'Festival Day is coming! Join us and help support your parks.', 'We will gather at noon, learn a song all together, and then join in a joyous procession to the pavilion. We will be one of many groups performing at this wonderful concert which benefits our city parks.', 5, 1, 1, '" . date('Y-m-d 12:00:00', strtotime("-1 day", $this->time)) . "', '" . date('Y-m-d 17:00:00', strtotime("-1 day", $this->time)) . "', 1, 'Register Now', 50, 'We have all the singers we can handle. Come to the pavilion anyway and join in from the audience.', 1, 2, NULL, 1, 'Festival Fee', 1, $eventLok2, 'Complete the form below and click Continue to register online for the festival. Or you can register by calling us at 204 222-1000 ext 22.', '', 'Confirm Your Registration Information', '', '', 1, 'This email confirms your registration. If you have questions or need to change your registration - please do not hesitate to call us.', 'Event Dept.', 'events@example.org', '', NULL, NULL, 'Thanks for Your Joining In!', '<p>Thank you for your support. Your participation will help build new parks.</p><p>Please tell your friends and colleagues about the concert.</p>', '<p><a href=https://civicrm.org>Back to CiviCRM Home Page</a></p>', 0, NULL, NULL, 1, 0, 'USD' ), | |
1631 | ( 'Rain-forest Cup Youth Soccer Tournament', 'Sign up your team to participate in this fun tournament which benefits several Rain-forest protection groups in the Amazon basin.', 'This is a FYSA Sanctioned Tournament, which is open to all USSF/FIFA affiliated organizations for boys and girls in age groups: U9-U10 (6v6), U11-U12 (8v8), and U13-U17 (Full Sided).', 3, 1, 1, '" . date('Y-m-d 07:00:00', strtotime("+7 months", $this->time)) . "', '" . date('Y-m-d 17:00:00', strtotime("+7 months +3 days", $this->time)) . "', 1, 'Register Now', 500, 'Sorry! All available team slots for this tournament have been filled. Contact Jill Futbol for information about the waiting list and next years event.', 1, 4, NULL, 1, 'Tournament Fees',1, $eventLok3, 'Complete the form below to register your team for this year''s tournament.', '<em>A Soccer Youth Event</em>', 'Review and Confirm Your Registration Information', '', '<em>A Soccer Youth Event</em>', 1, 'Contact our Tournament Director for eligibility details.', 'Tournament Director', 'tournament@example.org', '', NULL, NULL, 'Thanks for Your Support!', '<p>Thank you for your support. Your participation will help save thousands of acres of rainforest.</p>', '<p><a href=https://civicrm.org>Back to CiviCRM Home Page</a></p>', 0, NULL, NULL, 0, 0, 'USD' ) | |
3a2a6e86 TO |
1632 | "; |
1633 | $this->_query($event); | |
1634 | ||
1635 | //CRM-4464 | |
1636 | $eventTemplates = "INSERT INTO civicrm_event | |
1637 | ( is_template, template_title, event_type_id, default_role_id, participant_listing_id, is_public, is_monetary, is_online_registration, is_multiple_registrations, allow_same_participant_emails, is_email_confirm, financial_type_id, fee_label, confirm_title, thankyou_title, confirm_from_name, confirm_from_email, is_active, currency ) | |
1638 | VALUES | |
156ca3ec EM |
1639 | ( 1, 'Free Meeting without Online Registration', 4, 1, 1, 1, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 1, 'USD' ), |
1640 | ( 1, 'Free Meeting with Online Registration', 4, 1, 1, 1, 0, 1, 1, 1, 0, NULL, NULL, 'Confirm Your Registration Information', 'Thanks for Registering!', NULL, NULL, 1, 'USD' ), | |
3a2a6e86 TO |
1641 | ( 1, 'Paid Conference with Online Registration', 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 'Conference Fee', 'Confirm Your Registration Information', 'Thanks for Registering!', 'Event Template Dept.', 'event_templates@example.org', 1, 'USD' )"; |
1642 | ||
1643 | $this->_query($eventTemplates); | |
1644 | ||
156ca3ec EM |
1645 | $ufJoinValues = $tellFriendValues = []; |
1646 | $profileID = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_uf_group WHERE name ='event_registration'"); | |
3a2a6e86 TO |
1647 | |
1648 | // grab id's for all events and event templates | |
1649 | $query = " | |
1650 | SELECT id | |
1651 | FROM civicrm_event"; | |
1652 | ||
1653 | $template = CRM_Core_DAO::executeQuery($query); | |
1654 | while ($template->fetch()) { | |
1655 | if ($profileID) { | |
1656 | $ufJoinValues[] = "( 1, 'CiviEvent', 'civicrm_event', {$template->id}, 1, {$profileID} )"; | |
1657 | } | |
1658 | $tellFriendValues[] = "( 'civicrm_event', {$template->id}, 'Tell A Friend', '<p>Help us spread the word about this event. Use the space below to personalize your email message - let your friends know why you''re attending. Then fill in the name(s) and email address(es) and click ''Send Your Message''.</p>', 'Thought you might be interested in checking out this event. I''m planning on attending.', NULL, 'Thanks for Spreading the Word', '<p>Thanks for spreading the word about this event to your friends.</p>', 1)"; | |
1659 | } | |
1660 | ||
1661 | //insert values in civicrm_uf_join for the required event_registration profile - CRM-9587 | |
1662 | if (!empty($ufJoinValues)) { | |
1663 | $includeProfile = "INSERT INTO civicrm_uf_join | |
1664 | (is_active, module, entity_table, entity_id, weight, uf_group_id ) | |
1665 | VALUES " . implode(',', $ufJoinValues); | |
1666 | $this->_query($includeProfile); | |
1667 | } | |
1668 | ||
1669 | //insert values in civicrm_tell_friend | |
1670 | if (!empty($tellFriendValues)) { | |
1671 | $tellFriend = "INSERT INTO civicrm_tell_friend | |
1672 | (entity_table, entity_id, title, intro, suggested_message, | |
1673 | general_link, thankyou_title, thankyou_text, is_active) | |
1674 | VALUES " . implode(',', $tellFriendValues); | |
1675 | $this->_query($tellFriend); | |
1676 | } | |
1677 | } | |
1678 | ||
1679 | private function addParticipant() { | |
1680 | $contact = new CRM_Contact_DAO_Contact(); | |
1681 | $contact->query("SELECT id FROM civicrm_contact"); | |
1682 | while ($contact->fetch()) { | |
1683 | $contacts[] = $contact->id; | |
1684 | } | |
0049e17a | 1685 | $contacts = $this->shuffle($contacts); |
3a2a6e86 TO |
1686 | $randomContacts = array_slice($contacts, 20, 50); |
1687 | ||
1688 | $participant = " | |
1689 | INSERT INTO civicrm_participant | |
1690 | (contact_id, event_id, status_id, role_id, register_date, source, fee_level, is_test, fee_amount, fee_currency) | |
1691 | VALUES | |
1692 | ( " . $randomContacts[0] . ", 1, 1, 1, '2009-01-21', 'Check', 'Single', 0, 50, 'USD'), | |
1693 | ( " . $randomContacts[1] . ", 2, 2, 2, '2008-05-07', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1694 | ( " . $randomContacts[2] . ", 3, 3, 3, '2008-05-05', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD') , | |
1695 | ( " . $randomContacts[3] . ", 1, 4, 4, '2008-10-21', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1696 | ( " . $randomContacts[4] . ", 2, 1, 1, '2008-01-10', 'Check', 'Soprano', 0, 50, 'USD'), | |
1697 | ( " . $randomContacts[5] . ", 3, 2, 2, '2008-03-05', 'Direct Transfer', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1698 | ( " . $randomContacts[6] . ", 1, 3, 3, '2009-07-21', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1699 | ( " . $randomContacts[7] . ", 2, 4, 4, '2009-03-07', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1700 | ( " . $randomContacts[8] . ", 3, 1, 1, '2008-02-05', 'Direct Transfer', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1701 | ( " . $randomContacts[9] . ", 1, 2, 2, '2008-02-01', 'Check', 'Single', 0, 50, 'USD'), | |
1702 | ( " . $randomContacts[10] . ", 2, 3, 3, '2009-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1703 | ( " . $randomContacts[11] . ", 3, 4, 4, '2009-03-06', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1704 | ( " . $randomContacts[12] . ", 1, 1, 2, '2008-06-04', 'Credit Card', 'Single', 0, 50, 'USD'), | |
1705 | ( " . $randomContacts[13] . ", 2, 2, 3, '2008-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1706 | ( " . $randomContacts[14] . ", 3, 4, 1, '2008-07-04', 'Check', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1707 | ( " . $randomContacts[15] . ", 1, 4, 2, '2009-01-21', 'Credit Card', 'Single', 0, 50, 'USD'), | |
1708 | ( " . $randomContacts[16] . ", 2, 2, 3, '2008-01-10', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1709 | ( " . $randomContacts[17] . ", 3, 3, 1, '2009-03-05', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1710 | ( " . $randomContacts[18] . ", 1, 2, 1, '2008-10-21', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1711 | ( " . $randomContacts[19] . ", 2, 4, 1, '2009-01-10', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1712 | ( " . $randomContacts[20] . ", 3, 1, 4, '2008-03-25', 'Check', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1713 | ( " . $randomContacts[21] . ", 1, 2, 3, '2009-10-21', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1714 | ( " . $randomContacts[22] . ", 2, 4, 1, '2008-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1715 | ( " . $randomContacts[23] . ", 3, 3, 1, '2008-03-11', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1716 | ( " . $randomContacts[24] . ", 3, 2, 2, '2008-04-05', 'Direct Transfer', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1717 | ( " . $randomContacts[25] . ", 1, 1, 1, '2009-01-21', 'Check', 'Single', 0, 50, 'USD'), | |
1718 | ( " . $randomContacts[26] . ", 2, 2, 2, '2008-05-07', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1719 | ( " . $randomContacts[27] . ", 3, 3, 3, '2009-12-12', 'Direct Transfer', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1720 | ( " . $randomContacts[28] . ", 1, 4, 4, '2009-12-13', 'Credit Card', 'Single', 0, 50, 'USD'), | |
1721 | ( " . $randomContacts[29] . ", 2, 1, 1, '2009-12-14', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1722 | ( " . $randomContacts[30] . ", 3, 2, 2, '2009-12-15', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1723 | ( " . $randomContacts[31] . ", 1, 3, 3, '2009-07-21', 'Check', 'Single', 0, 50, 'USD'), | |
1724 | ( " . $randomContacts[32] . ", 2, 4, 4, '2009-03-07', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1725 | ( " . $randomContacts[33] . ", 3, 1, 1, '2009-12-15', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1726 | ( " . $randomContacts[34] . ", 1, 2, 2, '2009-12-13', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1727 | ( " . $randomContacts[35] . ", 2, 3, 3, '2009-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1728 | ( " . $randomContacts[36] . ", 3, 4, 4, '2009-03-06', 'Check', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1729 | ( " . $randomContacts[37] . ", 1, 1, 2, '2009-12-13', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1730 | ( " . $randomContacts[38] . ", 2, 2, 3, '2008-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1731 | ( " . $randomContacts[39] . ", 3, 4, 1, '2009-12-14', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1732 | ( " . $randomContacts[40] . ", 1, 4, 2, '2009-01-21', 'Credit Card', 'Single', 0, 50, 'USD'), | |
1733 | ( " . $randomContacts[41] . ", 2, 2, 3, '2009-12-15', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1734 | ( " . $randomContacts[42] . ", 3, 3, 1, '2009-03-05', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1735 | ( " . $randomContacts[43] . ", 1, 2, 1, '2009-12-13', 'Direct Transfer', 'Single', 0, 50, 'USD'), | |
1736 | ( " . $randomContacts[44] . ", 2, 4, 1, '2009-01-10', 'Direct Transfer', 'Soprano', 0, 50, 'USD'), | |
1737 | ( " . $randomContacts[45] . ", 3, 1, 4, '2009-12-13', 'Check', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1738 | ( " . $randomContacts[46] . ", 1, 2, 3, '2009-10-21', 'Credit Card', 'Single', 0, 50, 'USD'), | |
1739 | ( " . $randomContacts[47] . ", 2, 4, 1, '2009-12-10', 'Credit Card', 'Soprano', 0, 50, 'USD'), | |
1740 | ( " . $randomContacts[48] . ", 3, 3, 1, '2009-03-11', 'Credit Card', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'), | |
1741 | ( " . $randomContacts[49] . ", 3, 2, 2, '2009-04-05', 'Check', 'Tiny-tots (ages 5-8)', 0, 800, 'USD'); | |
1742 | "; | |
1743 | $this->_query($participant); | |
1744 | ||
1745 | $query = " | |
1746 | INSERT INTO civicrm_activity | |
1747 | (source_record_id, activity_type_id, subject, activity_date_time, duration, location, phone_id, phone_number, details, priority_id,parent_id, is_test, status_id) | |
1748 | VALUES | |
1749 | (01, 5, 'NULL', '2009-01-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1750 | (02, 5, 'NULL', '2008-05-07 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1751 | (03, 5, 'NULL', '2008-05-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1752 | (04, 5, 'NULL', '2008-10-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1753 | (05, 5, 'NULL', '2008-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1754 | (06, 5, 'NULL', '2008-03-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1755 | (07, 5, 'NULL', '2009-07-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1756 | (08, 5, 'NULL', '2009-03-07 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1757 | (09, 5, 'NULL', '2008-02-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1758 | (10, 5, 'NULL', '2008-02-01 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1759 | (11, 5, 'NULL', '2009-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1760 | (12, 5, 'NULL', '2009-03-06 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1761 | (13, 5, 'NULL', '2008-06-04 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1762 | (14, 5, 'NULL', '2008-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1763 | (15, 5, 'NULL', '2008-07-04 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1764 | (16, 5, 'NULL', '2009-01-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1765 | (17, 5, 'NULL', '2008-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1766 | (18, 5, 'NULL', '2009-03-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1767 | (19, 5, 'NULL', '2008-10-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1768 | (20, 5, 'NULL', '2009-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1769 | (21, 5, 'NULL', '2008-03-25 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1770 | (22, 5, 'NULL', '2009-10-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1771 | (23, 5, 'NULL', '2008-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1772 | (24, 5, 'NULL', '2008-03-11 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1773 | (25, 5, 'NULL', '2008-04-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1774 | (26, 5, 'NULL', '2009-01-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1775 | (27, 5, 'NULL', '2008-05-07 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1776 | (28, 5, 'NULL', '2009-12-12 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1777 | (29, 5, 'NULL', '2009-12-13 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1778 | (30, 5, 'NULL', '2009-12-14 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1779 | (31, 5, 'NULL', '2009-12-15 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1780 | (32, 5, 'NULL', '2009-07-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1781 | (33, 5, 'NULL', '2009-03-07 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1782 | (34, 5, 'NULL', '2009-12-15 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1783 | (35, 5, 'NULL', '2009-12-13 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1784 | (36, 5, 'NULL', '2009-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1785 | (37, 5, 'NULL', '2009-03-06 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1786 | (38, 5, 'NULL', '2009-12-13 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1787 | (39, 5, 'NULL', '2008-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1788 | (40, 5, 'NULL', '2009-12-14 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1789 | (41, 5, 'NULL', '2009-01-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1790 | (42, 5, 'NULL', '2009-12-15 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1791 | (43, 5, 'NULL', '2009-03-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1792 | (44, 5, 'NULL', '2009-12-13 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1793 | (45, 5, 'NULL', '2009-01-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1794 | (46, 5, 'NULL', '2009-12-13 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1795 | (47, 5, 'NULL', '2009-10-21 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1796 | (48, 5, 'NULL', '2009-12-10 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1797 | (49, 5, 'NULL', '2009-03-11 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ), | |
1798 | (50, 5, 'NULL', '2009-04-05 00:00:00', NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 ) | |
1799 | "; | |
1800 | $this->_query($query); | |
1801 | ||
1802 | $activityContact = " | |
1803 | INSERT INTO civicrm_activity_contact | |
1804 | (contact_id, activity_id, record_type_id) | |
1805 | VALUES | |
1806 | "; | |
1807 | $activityContacts = CRM_Activity_BAO_ActivityContact::buildOptions('record_type_id', 'validate'); | |
1808 | $currentActivityID = CRM_Core_DAO::singleValueQuery("SELECT MAX(id) FROM civicrm_activity"); | |
1809 | $currentActivityID -= 50; | |
1810 | $sourceID = CRM_Utils_Array::key('Activity Source', $activityContacts); | |
1811 | for ($i = 0; $i < 50; $i++) { | |
1812 | $currentActivityID++; | |
1813 | $activityContact .= "({$randomContacts[$i]}, $currentActivityID, $sourceID)"; | |
1814 | if ($i != 49) { | |
1815 | $activityContact .= ", "; | |
1816 | } | |
1817 | } | |
1818 | $this->_query($activityContact); | |
1819 | } | |
1820 | ||
1821 | private function addPCP() { | |
1822 | $query = " | |
1823 | INSERT INTO `civicrm_pcp` | |
1824 | (contact_id, status_id, title, intro_text, page_text, donate_link_text, page_id, page_type, is_thermometer, is_honor_roll, goal_amount, currency, is_active, pcp_block_id, is_notify) | |
1825 | VALUES | |
1826 | ({$this->Individual[3]}, 2, 'My Personal Civi Fundraiser', 'I''m on a mission to get all my friends and family to help support my favorite open-source civic sector CRM.', '<p>Friends and family - please help build much needed infrastructure for the civic sector by supporting my personal campaign!</p>\r\n<p><a href=\"https://civicrm.org\">You can learn more about CiviCRM here</a>.</p>\r\n<p>Then click the <strong>Contribute Now</strong> button to go to our easy-to-use online contribution form.</p>', 'Contribute Now', 1, 'contribute', 1, 1, 5000.00, 'USD', 1, 1, 1); | |
1827 | "; | |
1828 | $this->_query($query); | |
1829 | } | |
1830 | ||
1831 | private function addContribution() { | |
be946912 EM |
1832 | $defaults = [ |
1833 | 'financial_type_id' => 1, | |
1834 | 'payment_instrument_id' => 4, | |
1835 | 'receive_date' => 'now', | |
1836 | 'non_deductible_amount' => 0, | |
1837 | 'total_amount' => 25, | |
1838 | 'trxn_id' => '', | |
1839 | 'check_number' => '', | |
1840 | 'currency' => 'USD', | |
1841 | 'cancel_date' => NULL, | |
1842 | 'cancel_reason' => NULL, | |
1843 | 'receipt_date' => NULL, | |
1844 | 'thankyou_date' => NULL, | |
1845 | 'source' => 'April Mailer 1', | |
1846 | 'contribution_recur_id' => NULL, | |
1847 | ]; | |
1848 | $contributions = [ | |
1849 | 1 => [ | |
1850 | 'contact_id' => 2, | |
1851 | 'receive_date' => '10 years ago', | |
1852 | 'total_amount' => 125, | |
1853 | 'check_number' => '1041', | |
1854 | ], | |
1855 | 2 => [ | |
1856 | 'contact_id' => 4, | |
1857 | 'payment_instrument_id' => 1, | |
1858 | 'receive_date' => '2 years 3 months ago', | |
1859 | 'total_amount' => 50, | |
1860 | 'trxn_id' => 'P20901X1', | |
1861 | 'source' => 'Online: Save the Penguins', | |
1862 | ], | |
1863 | 3 => [ | |
1864 | 'contact_id' => 6, | |
1865 | 'receive_date' => '6 years 25 days 780 minutes ago', | |
1866 | 'total_amount' => 25, | |
1867 | 'trxn_id' => 'GBP12', | |
1868 | 'check_number' => '2095', | |
1869 | 'currency' => 'GBP', | |
1870 | ], | |
1871 | 4 => [ | |
1872 | 'contact_id' => 8, | |
1873 | 'receive_date' => '2 years 3 months ago', | |
1874 | 'total_amount' => 50, | |
1875 | 'check_number' => '10552', | |
1876 | 'source' => 'Online: Save the Penguins', | |
1877 | ], | |
1878 | 5 => [ | |
1879 | 'contact_id' => 4, | |
1880 | 'payment_instrument_id' => 1, | |
1881 | 'receive_date' => '2 years 3 months ago', | |
1882 | 'total_amount' => 50, | |
1883 | 'trxn_id' => 'Q90901X1', | |
1884 | 'source' => 'Online: Save the Penguins', | |
1885 | ], | |
1886 | 6 => [ | |
1887 | 'contact_id' => 16, | |
1888 | 'receive_date' => '85 days 42 minutes ago', | |
1889 | 'total_amount' => 500, | |
1890 | 'check_number' => '509', | |
1891 | ], | |
1892 | 7 => [ | |
1893 | 'contact_id' => 19, | |
1894 | 'payment_instrument_id' => 1, | |
1895 | 'receive_date' => '2 days ago', | |
1896 | 'total_amount' => 1750, | |
1897 | 'check_number' => '102', | |
1898 | 'source' => 'Online: Save the Penguins', | |
1899 | ], | |
1900 | 8 => [ | |
1901 | 'contact_id' => 82, | |
1902 | 'payment_instrument_id' => 1, | |
1903 | 'receive_date' => '340789 minutes ago', | |
1904 | 'total_amount' => 50, | |
1905 | 'trxn_id' => 'P20193L2', | |
1906 | 'source' => 'Online: Save the Penguins', | |
1907 | ], | |
1908 | 9 => [ | |
1909 | 'contact_id' => 92, | |
1910 | 'payment_instrument_id' => 1, | |
1911 | 'receive_date' => '11 months ago', | |
1912 | 'total_amount' => 10, | |
1913 | 'trxn_id' => 'P40232Y3', | |
1914 | 'source' => 'Online: Help CiviCRM', | |
1915 | ], | |
1916 | 10 => [ | |
1917 | 'contact_id' => 34, | |
1918 | 'payment_instrument_id' => 1, | |
1919 | 'receive_date' => '52 months 33000 minutes ago', | |
1920 | 'total_amount' => 250, | |
1921 | 'trxn_id' => 'P20193L6', | |
1922 | 'source' => 'Online: Help CiviCRM', | |
1923 | ], | |
1924 | 11 => [ | |
1925 | 'contact_id' => 71, | |
1926 | 'payment_instrument_id' => 1, | |
1927 | 'receive_date' => '28 hours ago', | |
1928 | 'total_amount' => 500, | |
1929 | 'trxn_id' => 'PL71', | |
1930 | 'source' => '', | |
1931 | 'currency' => 'JPY', | |
1932 | ], | |
1933 | ||
1934 | 12 => [ | |
1935 | 'contact_id' => 43, | |
1936 | 'payment_instrument_id' => 1, | |
1937 | 'receive_date' => '15 months 38000 seconds ago', | |
1938 | 'total_amount' => 50, | |
1939 | 'trxn_id' => 'P291X1', | |
1940 | 'source' => 'Online: Save the Penguins', | |
1941 | ], | |
1942 | 13 => [ | |
1943 | 'contact_id' => 32, | |
1944 | 'payment_instrument_id' => 1, | |
1945 | 'receive_date' => 'midnight 3 months ago', | |
1946 | 'total_amount' => 50, | |
1947 | 'trxn_id' => 'PL32I', | |
1948 | 'source' => '', | |
1949 | ], | |
1950 | 14 => [ | |
1951 | 'contact_id' => 32, | |
1952 | 'payment_instrument_id' => 1, | |
1953 | 'receive_date' => 'midnight 2 months ago', | |
1954 | 'total_amount' => 50, | |
1955 | 'trxn_id' => 'PL32II', | |
1956 | 'source' => '', | |
1957 | ], | |
1958 | ]; | |
1959 | $recurrings = [ | |
1960 | [ | |
1961 | 'contact_id' => 59, | |
1962 | 'amount' => 25, | |
1963 | 'currency' => 'USD', | |
1964 | 'frequency_interval' => 1, | |
1965 | 'frequency_unit' => 'month', | |
1966 | 'installments' => 12, | |
1967 | 'start_date' => '15 months ago', | |
1968 | 'processor_id' => 'CLC45', | |
1969 | 'trxn_id' => '56799', | |
1970 | 'contribution_status_id' => 1, | |
1971 | 'payment_processor_id' => 1, | |
1972 | ], | |
1973 | [ | |
1974 | 'contact_id' => 99, | |
1975 | 'amount' => 10, | |
1976 | 'currency' => 'CAD', | |
1977 | 'frequency_interval' => 1, | |
1978 | 'frequency_unit' => 'month', | |
1979 | 'installments' => 6, | |
1980 | 'start_date' => '8 months ago', | |
1981 | 'cancel_date' => '1 month ago', | |
1982 | 'cancel_reason' => 'No longer interested', | |
1983 | 'processor_id' => 'CLR35', | |
1984 | 'trxn_id' => '22799', | |
1985 | 'contribution_status_id' => 3, | |
1986 | 'payment_processor_id' => 1, | |
1987 | ], | |
1988 | [ | |
1989 | 'contact_id' => 103, | |
1990 | 'amount' => 5, | |
1991 | 'currency' => 'EUR', | |
1992 | 'frequency_interval' => 3, | |
1993 | 'frequency_unit' => 'month', | |
1994 | 'installments' => 3, | |
1995 | 'start_date' => '1 month ago', | |
1996 | 'processor_id' => 'EGR12', | |
1997 | 'trxn_id' => '44889', | |
1998 | 'contribution_status_id' => 5, | |
1999 | 'next_sched_contribution_date' => '+ 2 months', | |
2000 | 'payment_processor_id' => 1, | |
2001 | ], | |
2002 | ]; | |
64cc9df0 EM |
2003 | // The process is a bit weird & the payment processor gets added later... |
2004 | // so we need to disable foreign key checks here. | |
2005 | $this->_query('SET foreign_key_checks = 0'); | |
be946912 EM |
2006 | $contributionRecurID = 1; |
2007 | foreach ($recurrings as $recur) { | |
2008 | $startDate = date('Y-m-d H:i:s', strtotime($recur['start_date'])); | |
2009 | $cancelDate = empty($recur['cancel_date']) ? 'NULL' : "'" . date('Y-m-d H:i:s', strtotime($recur['cancel_date'])) . "'"; | |
2010 | $nextScheduledDate = empty($recur['next_sched_contribution_date']) ? 'NULL' : "'" . date('Y-m-d H:i:s', strtotime($recur['next_sched_contribution_date'])) . "'"; | |
2011 | $this->_query(" | |
2012 | INSERT INTO civicrm_contribution_recur ( | |
2013 | contact_id, amount, currency, frequency_unit, | |
2014 | frequency_interval, installments, | |
2015 | start_date, cancel_date, cancel_reason, processor_id, | |
2016 | trxn_id, contribution_status_id, next_sched_contribution_date, payment_processor_id) | |
2017 | VALUES ( | |
2018 | %1, %2, %3, %4, %5, %6, | |
2019 | %7, {$cancelDate}, %8, %9, | |
2020 | %10, %11, {$nextScheduledDate}, 1 | |
2021 | )", [ | |
2022 | 1 => [$recur['contact_id'] ?? NULL, 'Integer'], | |
2023 | 2 => [$recur['amount'], 'Money'], | |
2024 | 3 => [$recur['currency'], 'String'], | |
2025 | 4 => [$recur['frequency_unit'], 'String'], | |
2026 | 5 => [$recur['frequency_interval'], 'Integer'], | |
2027 | 6 => [$recur['installments'], 'Integer'], | |
2028 | 7 => [date('Y-m-d H:i:s', strtotime($recur['start_date'])), 'String'], | |
2029 | 8 => [$recur['cancel_reason'] ?? '', 'String'], | |
2030 | 9 => [$recur['processor_id'] ?? '', 'String'], | |
2031 | 10 => [$recur['trxn_id'], 'String'], | |
2032 | 11 => [$recur['contribution_status_id'], 'Integer'], | |
2033 | ] | |
2034 | ); | |
2035 | $contributionNumber = 1; | |
2036 | $receive_date = $startDate; | |
2037 | while ($contributionNumber < $recur['installments'] && strtotime($receive_date) < time()) { | |
2038 | if (!empty($recur['cancel_date']) && strtotime($receive_date) > strtotime($recur['cancel_date'])) { | |
2039 | continue; | |
2040 | } | |
2041 | $contributions[] = [ | |
2042 | 'contact_id' => $recur['contact_id'], | |
2043 | 'payment_instrument_id' => 1, | |
2044 | 'receive_date' => $receive_date, | |
2045 | 'total_amount' => $recur['amount'], | |
2046 | 'currency' => $recur['currency'], | |
2047 | 'trxn_id' => 'PL32I' . $recur['contact_id'] . $contributionNumber, | |
2048 | 'source' => 'Recurring contribution', | |
2049 | 'contribution_recur_id' => $contributionRecurID, | |
2050 | ]; | |
2051 | $receive_date = date('Y-m-d H:i:s', strtotime("+ {$recur['frequency_interval']} {$recur['frequency_unit']}", strtotime($receive_date))); | |
2052 | $contributionNumber++; | |
2053 | } | |
2054 | $contributionRecurID++; | |
2055 | } | |
64cc9df0 | 2056 | $this->_query('SET foreign_key_checks = 1'); |
be946912 EM |
2057 | $contributionID = 1; |
2058 | $currentActivityID = CRM_Core_DAO::singleValueQuery('SELECT MAX(id) FROM civicrm_activity') + 1; | |
2059 | foreach ($contributions as $contribution) { | |
2060 | $contribution = array_merge($defaults, $contribution); | |
2061 | $contribution['receive_date'] = date('Y-m-d H:i:s', strtotime($contribution['receive_date'])); | |
2062 | $contributionObject = new CRM_Contribute_BAO_Contribution(); | |
2063 | $contributionObject->copyValues($contribution); | |
2064 | $contributionObject->save(); | |
2065 | ||
2066 | $symbols = [ | |
2067 | 'USD' => '$', | |
2068 | 'CAD' => '$', | |
2069 | 'EUR' => '€', | |
2070 | 'GBP' => '£', | |
2071 | 'JPY' => 'Â¥', | |
2072 | ]; | |
2073 | $subject = $symbols[$contribution['currency']] . ' ' . $contribution['total_amount'] . ' ' . $contribution['source']; | |
2074 | $this->_query(' | |
3a2a6e86 TO |
2075 | INSERT INTO civicrm_activity |
2076 | (source_record_id, activity_type_id, subject, activity_date_time, duration, location, phone_id, phone_number, details, priority_id,parent_id, is_test, status_id) | |
be946912 EM |
2077 | VALUES ( |
2078 | %1, 6, %2, %3, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 2 | |
2079 | )', | |
2080 | [ | |
2081 | 1 => [$contributionID, 'Integer'], | |
2082 | 2 => [$subject, 'String'], | |
2083 | 3 => [$receive_date, 'String'], | |
2084 | ] | |
2085 | ); | |
2086 | $this->_query("INSERT INTO civicrm_activity_contact | |
3a2a6e86 | 2087 | (contact_id, activity_id, record_type_id) |
be946912 EM |
2088 | VALUES ({$contribution['contact_id']}, $currentActivityID, 2)"); |
2089 | $contributionID++; | |
3a2a6e86 | 2090 | $currentActivityID++; |
3a2a6e86 | 2091 | } |
3a2a6e86 TO |
2092 | } |
2093 | ||
2094 | private function addSoftContribution() { | |
2095 | ||
156ca3ec | 2096 | $sql = "SELECT id FROM civicrm_contribution WHERE contact_id = 92"; |
3a2a6e86 TO |
2097 | $contriId1 = CRM_Core_DAO::singleValueQuery($sql); |
2098 | ||
156ca3ec | 2099 | $sql = "SELECT id FROM civicrm_contribution WHERE contact_id = 34"; |
3a2a6e86 TO |
2100 | $contriId2 = CRM_Core_DAO::singleValueQuery($sql); |
2101 | ||
2102 | $sql = "SELECT cov.value FROM civicrm_option_value cov LEFT JOIN civicrm_option_group cog ON cog.id = cov.option_group_id WHERE cov.name = 'pcp' AND cog.name = 'soft_credit_type'"; | |
2103 | ||
2104 | $pcpId = CRM_Core_DAO::singleValueQuery($sql); | |
2105 | ||
2106 | $query = " | |
2107 | INSERT INTO `civicrm_contribution_soft` | |
2108 | ( contribution_id, contact_id ,amount , currency, pcp_id , pcp_display_in_roll ,pcp_roll_nickname,pcp_personal_note, soft_credit_type_id ) | |
2109 | VALUES | |
2110 | ( $contriId1, {$this->Individual[3]}, 10.00, 'USD', 1, 1, 'Jones Family', 'Helping Hands', $pcpId), | |
2111 | ( $contriId2, {$this->Individual[3]}, 250.00, 'USD', 1, 1, 'Annie and the kids', 'Annie Helps', $pcpId); | |
2112 | "; | |
2113 | ||
2114 | $this->_query($query); | |
2115 | } | |
2116 | ||
2117 | private function addPledge() { | |
2118 | $pledge = "INSERT INTO civicrm_pledge | |
2119 | (contact_id, financial_type_id, contribution_page_id, amount, original_installment_amount, currency,frequency_unit, frequency_interval, frequency_day, installments, start_date, create_date, acknowledge_date, modified_date, cancel_date, end_date, status_id, is_test) | |
2120 | VALUES | |
2121 | (71, 1, 1, 500.00, '500', 'USD', 'month', 1, 1, 1, '2009-07-01 00:00:00', '2009-06-26 00:00:00', NULL, NULL, NULL,'2009-07-01 00:00:00', 1, 0), | |
2122 | (43, 1, 1, 800.00, '200', 'USD', 'month', 3, 1, 4, '2009-07-01 00:00:00', '2009-06-23 00:00:00', '2009-06-23 00:00:00', NULL, NULL, '2009-04-01 10:11:40', 5, 0), | |
2123 | (32, 1, 1, 600.00, '200', 'USD', 'month', 1, 1, 3, '2009-10-01 00:00:00', '2009-09-14 00:00:00', '2009-09-14 00:00:00', NULL, NULL, '2009-12-01 00:00:00', 5, 0); | |
2124 | "; | |
2125 | $this->_query($pledge); | |
2126 | } | |
2127 | ||
2128 | private function addPledgePayment() { | |
2129 | $pledgePayment = "INSERT INTO civicrm_pledge_payment | |
2130 | ( pledge_id, contribution_id, scheduled_amount, actual_amount, currency, scheduled_date, reminder_date, reminder_count, status_id) | |
2131 | VALUES | |
156ca3ec EM |
2132 | (1, 10, 500.00, 500.00, 'USD','2009-07-01 00:00:00', NULL, 0, 1 ), |
2133 | (2, 11, 200.00, 200.00, 'USD','2009-07-01 00:00:00', NULL, 0, 1 ), | |
2134 | (2, NULL, 200.00, NULL, 'USD', '2009-10-01 00:00:00', NULL, 0, 2 ), | |
2135 | (2, NULL, 200.00, NULL, 'USD', '2009-01-01 00:00:00', NULL, 0, 2 ), | |
2136 | (2, NULL, 200.00, NULL, 'USD', '2009-04-01 00:00:00', NULL, 0, 2 ), | |
3a2a6e86 | 2137 | |
156ca3ec | 2138 | (3, 12, 200.00, 200.00, 'USD', '2009-10-01 00:00:00', NULL, 0, 1 ), |
3a2a6e86 | 2139 | (3, 13, 200.00, 200.00, 'USD', '2009-11-01 00:0:00', '2009-10-28 00:00:00', 1, 1), |
156ca3ec | 2140 | (3, NULL, 200.00, NULL, 'USD', '2009-12-01 00:00:00', NULL, 0, 2 ); |
3a2a6e86 TO |
2141 | "; |
2142 | $this->_query($pledgePayment); | |
2143 | } | |
2144 | ||
2145 | private function addContributionLineItem() { | |
2146 | $query = " INSERT INTO civicrm_line_item (`entity_table`, `entity_id`, contribution_id, `price_field_id`, `label`, `qty`, `unit_price`, `line_total`, `participant_count`, `price_field_value_id`, `financial_type_id`) | |
156ca3ec | 2147 | SELECT 'civicrm_contribution', cc.id, cc.id contribution_id, cpf.id AS price_field, cpfv.label, 1, cc.total_amount, cc.total_amount line_total, 0, cpfv.id AS price_field_value, cpfv.financial_type_id |
3a2a6e86 TO |
2148 | FROM civicrm_contribution cc |
2149 | LEFT JOIN civicrm_price_set cps ON cps.name = 'default_contribution_amount' | |
2150 | LEFT JOIN civicrm_price_field cpf ON cpf.price_set_id = cps.id | |
2151 | LEFT JOIN civicrm_price_field_value cpfv ON cpfv.price_field_id = cpf.id | |
156ca3ec | 2152 | ORDER BY cc.id; "; |
3a2a6e86 TO |
2153 | $this->_query($query); |
2154 | } | |
2155 | ||
2156 | private function addAccountingEntries() { | |
156ca3ec | 2157 | $components = ['contribution', 'membership', 'participant']; |
3a2a6e86 TO |
2158 | $select = 'SELECT contribution.id contribution_id, cli.id as line_item_id, contribution.contact_id, contribution.receive_date, contribution.total_amount, contribution.currency, cli.label, |
2159 | cli.financial_type_id, cefa.financial_account_id, contribution.payment_instrument_id, contribution.check_number, contribution.trxn_id'; | |
2160 | $where = 'WHERE cefa.account_relationship = 1'; | |
2161 | $financialAccountId = CRM_Financial_BAO_FinancialTypeAccount::getInstrumentFinancialAccount(4); | |
2162 | foreach ($components as $component) { | |
2163 | if ($component == 'contribution') { | |
2164 | $from = 'FROM `civicrm_contribution` contribution'; | |
2165 | } | |
2166 | else { | |
2167 | $from = " FROM `civicrm_{$component}` {$component} | |
2168 | INNER JOIN civicrm_{$component}_payment cpp ON cpp.{$component}_id = {$component}.id | |
2169 | INNER JOIN civicrm_contribution contribution on contribution.id = cpp.contribution_id"; | |
2170 | } | |
2171 | $from .= " INNER JOIN civicrm_line_item cli ON cli.entity_id = {$component}.id and cli.entity_table = 'civicrm_{$component}' | |
2172 | INNER JOIN civicrm_entity_financial_account cefa ON cefa.entity_id = cli.financial_type_id "; | |
2173 | $sql = " {$select} {$from} {$where} "; | |
2174 | $result = CRM_Core_DAO::executeQuery($sql); | |
2175 | $this->addFinancialItem($result, $financialAccountId); | |
2176 | } | |
2177 | } | |
2178 | ||
2179 | /** | |
2180 | * @param $result | |
2181 | * @param null $financialAccountId | |
2182 | */ | |
2183 | private function addFinancialItem($result, $financialAccountId) { | |
2184 | $defaultFinancialAccount = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_financial_account WHERE is_default = 1 AND financial_account_type_id = 1"); | |
2185 | while ($result->fetch()) { | |
156ca3ec | 2186 | $trxnParams = [ |
3a2a6e86 TO |
2187 | 'trxn_date' => CRM_Utils_Date::processDate($result->receive_date), |
2188 | 'total_amount' => $result->total_amount, | |
2189 | 'currency' => $result->currency, | |
2190 | 'status_id' => 1, | |
2191 | 'trxn_id' => $result->trxn_id, | |
2192 | 'contribution_id' => $result->contribution_id, | |
2193 | 'to_financial_account_id' => empty($financialAccountId[$result->payment_instrument_id]) ? $defaultFinancialAccount : $financialAccountId[$result->payment_instrument_id], | |
2194 | 'payment_instrument_id' => $result->payment_instrument_id, | |
2195 | 'check_number' => $result->check_number, | |
2196 | 'is_payment' => 1, | |
156ca3ec | 2197 | ]; |
3a2a6e86 | 2198 | $trxn = CRM_Core_BAO_FinancialTrxn::create($trxnParams); |
156ca3ec | 2199 | $financialItem = [ |
3a2a6e86 TO |
2200 | 'transaction_date' => CRM_Utils_Date::processDate($result->receive_date), |
2201 | 'amount' => $result->total_amount, | |
2202 | 'currency' => $result->currency, | |
2203 | 'status_id' => 1, | |
2204 | 'entity_id' => $result->line_item_id, | |
2205 | 'contact_id' => $result->contact_id, | |
2206 | 'entity_table' => 'civicrm_line_item', | |
2207 | 'description' => $result->label, | |
2208 | 'financial_account_id' => $result->financial_account_id, | |
156ca3ec | 2209 | ]; |
3a2a6e86 TO |
2210 | $trxnId['id'] = $trxn->id; |
2211 | CRM_Financial_BAO_FinancialItem::create($financialItem, NULL, $trxnId); | |
2212 | } | |
2213 | } | |
2214 | ||
2215 | private function addLineItemParticipants() { | |
2216 | $participant = new CRM_Event_DAO_Participant(); | |
2217 | $participant->query("INSERT INTO civicrm_line_item (`entity_table`, `entity_id`, contribution_id, `price_field_id`, `label`, `qty`, `unit_price`, `line_total`, `participant_count`, `price_field_value_id`, `financial_type_id`) | |
156ca3ec | 2218 | SELECT 'civicrm_participant', cp.id, cpp.contribution_id, cpfv.price_field_id, cpfv.label, 1, cpfv.amount, cpfv.amount AS line_total, 0, cpfv.id, cpfv.financial_type_id FROM civicrm_participant cp LEFT JOIN civicrm_participant_payment cpp ON cpp.participant_id = cp.id |
3a2a6e86 TO |
2219 | LEFT JOIN civicrm_price_set_entity cpe ON cpe.entity_id = cp.event_id LEFT JOIN civicrm_price_field cpf ON cpf.price_set_id = cpe.price_set_id LEFT JOIN civicrm_price_field_value cpfv ON cpfv.price_field_id = cpf.id WHERE cpfv.label = cp.fee_level"); |
2220 | } | |
2221 | ||
2222 | private function addMembershipPayment() { | |
156ca3ec EM |
2223 | $maxContribution = CRM_Core_DAO::singleValueQuery("SELECT MAX(id) FROM civicrm_contribution"); |
2224 | $financialTypeID = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_financial_type WHERE name = 'Member Dues'"); | |
2225 | $paymentInstrumentID = CRM_Core_DAO::singleValueQuery("SELECT value FROM civicrm_option_value WHERE name = 'Credit Card' AND option_group_id = (SELECT id FROM civicrm_option_group WHERE name = 'payment_instrument')"); | |
47ca44f4 SL |
2226 | $sql = "INSERT INTO civicrm_contribution (contact_id,financial_type_id,payment_instrument_id, receive_date, total_amount, currency, source, contribution_status_id, trxn_id) |
2227 | SELECT cm.contact_id, $financialTypeID, $paymentInstrumentID, now(), cmt.minimum_fee, 'USD', CONCAT(cmt.name, ' Membership: Offline signup'), 1, SUBSTRING(MD5(RAND()) FROM 1 FOR 16) FROM `civicrm_membership` cm | |
3a2a6e86 TO |
2228 | LEFT JOIN civicrm_membership_type cmt ON cmt.id = cm.membership_type_id;"; |
2229 | ||
2230 | $this->_query($sql); | |
2231 | ||
2232 | $sql = "INSERT INTO civicrm_membership_payment (contribution_id,membership_id) | |
2233 | SELECT cc.id, cm.id FROM civicrm_contribution cc | |
2234 | LEFT JOIN civicrm_membership cm ON cm.contact_id = cc.contact_id | |
2235 | WHERE cc.id > $maxContribution;"; | |
2236 | ||
2237 | $this->_query($sql); | |
2238 | ||
2239 | $sql = "INSERT INTO civicrm_line_item (entity_table, entity_id, contribution_id, price_field_value_id, price_field_id, label, qty, unit_price, line_total, financial_type_id) | |
156ca3ec | 2240 | SELECT 'civicrm_membership', cm.id, cmp.contribution_id, cpfv.id, cpfv.price_field_id, cpfv.label, 1, cpfv.amount, cpfv.amount AS unit_price, cpfv.financial_type_id FROM `civicrm_membership` cm |
3a2a6e86 TO |
2241 | LEFT JOIN civicrm_membership_payment cmp ON cmp.membership_id = cm.id |
2242 | LEFT JOIN civicrm_price_field_value cpfv ON cpfv.membership_type_id = cm.membership_type_id | |
2243 | LEFT JOIN civicrm_price_field cpf ON cpf.id = cpfv.price_field_id | |
2244 | LEFT JOIN civicrm_price_set cps ON cps.id = cpf.price_set_id | |
2245 | WHERE cps.name = 'default_membership_type_amount'"; | |
2246 | $this->_query($sql); | |
2247 | ||
2248 | $sql = "INSERT INTO civicrm_activity(source_record_id, activity_type_id, subject, activity_date_time, status_id, details) | |
2249 | SELECT id, 6, CONCAT('$ ', total_amount, ' - ', source), now(), 2, 'Membership Payment' FROM civicrm_contribution WHERE id > $maxContribution"; | |
2250 | $this->_query($sql); | |
2251 | ||
2252 | $sql = "INSERT INTO civicrm_activity_contact(contact_id, activity_id, record_type_id) | |
2253 | SELECT c.contact_id, a.id, 2 | |
2254 | FROM civicrm_contribution c, civicrm_activity a | |
2255 | WHERE c.id > $maxContribution | |
2256 | AND a.source_record_id = c.id | |
2257 | AND a.details = 'Membership Payment' | |
2258 | "; | |
2259 | $this->_query($sql); | |
2260 | } | |
2261 | ||
2262 | private function addParticipantPayment() { | |
156ca3ec EM |
2263 | $maxContribution = CRM_Core_DAO::singleValueQuery("SELECT MAX(id) FROM civicrm_contribution"); |
2264 | $financialTypeID = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_financial_type WHERE name = 'Event Fee'"); | |
2265 | $paymentInstrumentID = CRM_Core_DAO::singleValueQuery("SELECT value FROM civicrm_option_value WHERE name = 'Credit Card' AND option_group_id = (SELECT id FROM civicrm_option_group WHERE name = 'payment_instrument')"); | |
47ca44f4 SL |
2266 | $sql = "INSERT INTO civicrm_contribution (contact_id, financial_type_id, payment_instrument_id, receive_date, total_amount, currency, receipt_date, source, contribution_status_id, trxn_id) |
2267 | SELECT `contact_id`, $financialTypeID, $paymentInstrumentID, now(), `fee_amount`, 'USD', now(), CONCAT(ce.title, ' : Offline registration'), 1, SUBSTRING(MD5(RAND()) FROM 1 FOR 16) FROM `civicrm_participant` cp | |
3a2a6e86 TO |
2268 | LEFT JOIN civicrm_event ce ON ce.id = cp.event_id |
2269 | group by `contact_id`, `fee_amount`, `title`;"; | |
2270 | ||
2271 | $this->_query($sql); | |
2272 | ||
2273 | $sql = "INSERT INTO civicrm_participant_payment (contribution_id,participant_id) | |
2274 | SELECT cc.id, cp.id FROM civicrm_contribution cc | |
2275 | LEFT JOIN civicrm_participant cp ON cp.contact_id = cc.contact_id | |
2276 | WHERE cc.id > $maxContribution"; | |
2277 | ||
2278 | $this->_query($sql); | |
2279 | ||
2280 | $sql = "INSERT INTO civicrm_activity(source_record_id, activity_type_id, subject, activity_date_time, status_id, details) | |
2281 | SELECT id, 6, CONCAT('$ ', total_amount, ' - ', source), now(), 2, 'Participant' FROM `civicrm_contribution` WHERE id > $maxContribution"; | |
2282 | $this->_query($sql); | |
2283 | ||
2284 | $sql = "INSERT INTO civicrm_activity_contact(contact_id, activity_id, record_type_id) | |
2285 | SELECT c.contact_id, a.id, 2 | |
2286 | FROM civicrm_contribution c, civicrm_activity a | |
2287 | WHERE c.id > $maxContribution | |
2288 | AND a.source_record_id = c.id | |
2289 | AND a.details = 'Participant Payment' | |
2290 | "; | |
2291 | $this->_query($sql); | |
2292 | } | |
2293 | ||
d94d506c TO |
2294 | /** |
2295 | * @return string | |
2296 | */ | |
156ca3ec | 2297 | protected static function getCivicrmDir(): string { |
d94d506c TO |
2298 | return dirname(dirname(dirname(__DIR__))); |
2299 | } | |
2300 | ||
3a2a6e86 | 2301 | } |