www/export_mashs.php

changeset 563
acdd54144838
child 788
812ce4c5da2a
equal deleted inserted replaced
562:ee28b3303da2 563:acdd54144838
1 <?php
2 require_once($_SERVER['DOCUMENT_ROOT'].'/config.php');
3 require_once($_SERVER['DOCUMENT_ROOT'].'/includes/formulas.php');
4
5
6 $link = mysqli_connect(DBASE_HOST,DBASE_USER,DBASE_PASS,DBASE_NAME);
7 if (! $link) {
8 die('Connect Error (' . mysqli_connect_errno() . ') ' . mysqli_connect_error());
9 }
10 if (! mysqli_set_charset($link, "utf8" )) {
11 echo "error";
12 return 1;
13 }
14
15 $result = mysqli_query($link, "SELECT * FROM profile_mash ORDER BY name");
16 $row = mysqli_fetch_array($result);
17
18
19 $mashsteptype = array( 'Infusion', 'Temperature', 'Decoction' );
20
21
22 /*
23 * Create beerxml output
24 */
25 $xw = xmlwriter_open_memory();
26 xmlwriter_set_indent($xw, 1);
27 $res = xmlwriter_set_indent_string($xw, ' ');
28
29 xmlwriter_start_document($xw, '1.0', 'UTF-8');
30
31
32 xmlwriter_start_element($xw, 'MASHS');
33 while ($row = mysqli_fetch_array($result)) {
34
35 xmlwriter_start_element($xw, 'MASH');
36
37 xmlwriter_start_element($xw, 'VERSION');
38 xmlwriter_text($xw, '1');
39 xmlwriter_end_element($xw);
40
41 xmlwriter_start_element($xw, 'NAME');
42 xmlwriter_text($xw, $row['name']);
43 xmlwriter_end_element($xw);
44
45 if (strlen($row['notes'])) {
46 xmlwriter_start_element($xw, 'NOTES');
47 xmlwriter_text($xw, $row['notes']);
48 xmlwriter_end_element($xw);
49 }
50
51 xmlwriter_start_element($xw, 'MASH_STEPS');
52 $arr = json_decode($row['steps'], true);
53 foreach($arr as $item) { //foreach element in $arr
54 xmlwriter_start_element($xw, 'MASH_STEP');
55
56 xmlwriter_start_element($xw, 'VERSION');
57 xmlwriter_text($xw, '1');
58 xmlwriter_end_element($xw);
59
60 xmlwriter_start_element($xw, 'NAME');
61 xmlwriter_text($xw, $item['step_name']);
62 xmlwriter_end_element($xw);
63
64 xmlwriter_start_element($xw, 'TYPE');
65 xmlwriter_text($xw, $mashsteptype[$item['step_type']]);
66 xmlwriter_end_element($xw);
67
68 xmlwriter_start_element($xw, 'STEP_TEMP');
69 xmlwriter_text($xw, sprintf("%.4f",floatval($item['step_temp'])));
70 xmlwriter_end_element($xw);
71
72 xmlwriter_start_element($xw, 'STEP_TIME');
73 xmlwriter_text($xw, sprintf("%.3f",floatval($item['step_time'])));
74 xmlwriter_end_element($xw);
75
76 xmlwriter_start_element($xw, 'RAMP_TIME');
77 xmlwriter_text($xw, sprintf("%.3f",floatval($item['ramp_time'])));
78 xmlwriter_end_element($xw);
79
80 xmlwriter_start_element($xw, 'END_TEMP');
81 xmlwriter_text($xw, sprintf("%.4f",floatval($item['end_temp'])));
82 xmlwriter_end_element($xw);
83
84 xmlwriter_end_element($xw); // MASH_STEP
85 }
86
87 xmlwriter_end_element($xw); // MASH_STEPS
88 xmlwriter_end_element($xw); // MASH
89 }
90 xmlwriter_end_element($xw); // MASHS
91
92 $beerxml = xmlwriter_output_memory($xw);
93
94 Header('Content-type: text/xml');
95 header('Content-Disposition: attachment; filename="mashs.xml"');
96 header('Content-Transfer-Encoding: binary');
97 header('Expires: 0');
98 header('Pragma: no-cache');
99 header('Content-Length: '.strlen($beerxml));
100 exit($beerxml);

mercurial