www/export_yeasts.php

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

mercurial