|
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 inventory_yeasts ORDER BY laboratory,product_id,name"); |
|
16 $row = mysqli_fetch_array($result); |
|
17 |
|
18 function field($x, $field, $value) { |
|
19 xmlwriter_start_element($x, $field); |
|
20 xmlwriter_text($x, $value); |
|
21 xmlwriter_end_element($x); |
|
22 } |
|
23 |
|
24 $yeasttype = array( 'Lager', 'Ale', 'Wheat', 'Wine', 'Champagne', 'Other', 'Other', 'Other', 'Other', 'Other' ); |
|
25 $yeastform = array( 'Liquid', 'Dry', 'Slant', 'Culture', 'Frozen', 'Bottle', 'Dry' ); |
|
26 $yeastflocculation = array( 'Low', 'Medium', 'High', 'Very high' ); |
|
27 |
|
28 |
|
29 /* |
|
30 * Create beerxml output |
|
31 */ |
|
32 $xw = xmlwriter_open_memory(); |
|
33 xmlwriter_set_indent($xw, 1); |
|
34 $res = xmlwriter_set_indent_string($xw, ' '); |
|
35 |
|
36 xmlwriter_start_document($xw, '1.0', 'UTF-8'); |
|
37 |
|
38 |
|
39 xmlwriter_start_element($xw, 'YEASTS'); |
|
40 while ($row = mysqli_fetch_array($result)) { |
|
41 |
|
42 xmlwriter_start_element($xw, 'YEAST'); |
|
43 |
|
44 field($xw, 'VERSION', '1'); |
|
45 field($xw, 'NAME', $row['name']); |
|
46 field($xw, 'TYPE', $yeasttype[$row['type']]); |
|
47 field($xw, 'FORM', $yeastform[$row['form']]); |
|
48 field($xw, 'AMOUNT_IS_WEIGHT', ($row['form'] == '1' || $row['form'] == '6') ? 'TRUE':'FALSE'); |
|
49 field($xw, 'LABORATORY', $row['laboratory']); |
|
50 if (strlen($row['product_id'])) |
|
51 field($xw, 'PRODUCT_ID', $row['product_id']); |
|
52 field($xw, 'MIN_TEMPERATURE', sprintf("%.4f",floatval($row['min_temperature']))); |
|
53 field($xw, 'MAX_TEMPERATURE', sprintf("%.4f",floatval($row['max_temperature']))); |
|
54 field($xw, 'ATTENUATION', sprintf("%.4f",floatval($row['attenuation']))); |
|
55 field($xw, 'ADD_TO_SECONDARY', ($row['use'] == 0) ? 'FALSE':'TRUE'); |
|
56 field($xw, 'FLOCCULATION', $yeastflocculation[$row['flocculation']]); |
|
57 field($xw, 'MAX_REUSE', $row['max_reuse']); |
|
58 if (floatval($row['cost']) > 0) |
|
59 field($xw, 'COST', sprintf("%.5f",floatval($row['cost']))); |
|
60 if (strlen($row['notes'])) |
|
61 field($xw, 'NOTES', $row['notes']); |
|
62 |
|
63 xmlwriter_end_element($xw); // YEAST |
|
64 } |
|
65 xmlwriter_end_element($xw); // YEASTS |
|
66 |
|
67 $beerxml = xmlwriter_output_memory($xw); |
|
68 |
|
69 Header('Content-type: text/xml'); |
|
70 header('Content-Disposition: attachment; filename="yeasts.xml"'); |
|
71 header('Content-Transfer-Encoding: binary'); |
|
72 header('Expires: 0'); |
|
73 header('Pragma: no-cache'); |
|
74 header('Content-Length: '.strlen($beerxml)); |
|
75 exit($beerxml); |