Thu, 28 Feb 2019 15:40:14 +0100
Renamed xxx_export.php scripts to xxx_beerxml.php
www/js/prod_edit.js | file | annotate | diff | comparison | revisions | |
www/js/rec_edit.js | file | annotate | diff | comparison | revisions | |
www/prod_beerxml.php | file | annotate | diff | comparison | revisions | |
www/prod_export.php | file | annotate | diff | comparison | revisions | |
www/rec_beerxml.php | file | annotate | diff | comparison | revisions | |
www/rec_export.php | file | annotate | diff | comparison | revisions |
--- a/www/js/prod_edit.js Wed Feb 27 22:14:03 2019 +0100 +++ b/www/js/prod_edit.js Thu Feb 28 15:40:14 2019 +0100 @@ -5307,7 +5307,7 @@ $("#Export").jqxButton({ template: "info", width: '80px', theme: theme }); $("#Export").click(function () { saveRecord(); - var url="prod_export.php?record=" + my_record; + var url="prod_beerxml.php?record=" + my_record; window.open(url); });
--- a/www/js/rec_edit.js Wed Feb 27 22:14:03 2019 +0100 +++ b/www/js/rec_edit.js Thu Feb 28 15:40:14 2019 +0100 @@ -3678,7 +3678,7 @@ $("#Export").jqxButton({ template: "info", width: '80px', theme: theme }); $("#Export").click(function () { saveRecord(); - var url="rec_export.php?record=" + my_record; + var url="rec_beerxml.php?record=" + my_record; window.open(url); });
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/www/prod_beerxml.php Thu Feb 28 15:40:14 2019 +0100 @@ -0,0 +1,614 @@ +<?php +require_once('config.php'); +require_once('includes/formulas.php'); +//require_once($_SERVER['DOCUMENT_ROOT'].'/config.php'); +//require_once($_SERVER['DOCUMENT_ROOT'].'/includes/formulas.php'); + + +$link = mysqli_connect(DBASE_HOST,DBASE_USER,DBASE_PASS,DBASE_NAME); +if (! $link) { + die('Connect Error (' . mysqli_connect_errno() . ') ' . mysqli_connect_error()); +} +if (! mysqli_set_charset($link, "utf8" )) { + echo "error"; + return 1; +} + +//setlocale ( LC_ALL, 'nl_NL.UTF-8'); +if (isset($_GET["record"])) + $record = $_GET["record"]; +else + $record = 78; +$result = mysqli_query($link, "SELECT * FROM products WHERE record='".$record."'"); +$row = mysqli_fetch_array($result); + + +$recipetype = array( 'Extract', 'Partial Mash', 'All Grain' ); +$styletype = array( 'Lager', 'Ale', 'Mead', 'Wheat', 'Mixed', 'Cider' ); +$hoptype = array( 'Bittering', 'Aroma', 'Both' ); +$hopform = array( 'Pellet', 'Plug', 'Leaf' ); +$hopuse = array( 'Mash', 'First wort', 'Boil', 'Aroma', 'Whirlpool', 'Dry hop' ); +$fermentabletype = array( 'Grain', 'Sugar', 'Extract', 'Dry extract', 'Adjunct' ); +$graintype = array( 'Base', 'Roast', 'Crystal', 'Kilned', 'Sour malt', 'Special', 'No malt' ); +$yeasttype = array( 'Lager', 'Ale', 'Wheat', 'Wine', 'Champagne' ); +$yeastform = array( 'Liquid', 'Dry', 'Slant', 'Culture', 'Frozen', 'Bottle' ); +$yeastuse = array( 'Primary', 'Secondary', 'Tertiary', 'Bottle' ); +$misctype = array( 'Spice', 'Herb', 'Flavor', 'Fining', 'Water agent', 'Yeast nutrient', 'Other' ); +$miscuse = array( 'Starter', 'Mash', 'Boil', 'Primary', 'Secondary', 'Bottling' ); +$mashsteptype = array( 'Infusion', 'Temperature', 'Decoction' ); + + + +/* + * Create beerxml output + */ +$xw = xmlwriter_open_memory(); +xmlwriter_set_indent($xw, 1); +$res = xmlwriter_set_indent_string($xw, ' '); + +xmlwriter_start_document($xw, '1.0', 'UTF-8'); + +xmlwriter_start_element($xw, 'RECIPES'); +xmlwriter_start_element($xw, 'RECIPE'); + +// Recipe basics +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NOTES'); +xmlwriter_text($xw, $row['notes']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TYPE'); +xmlwriter_text($xw, $recipetype[$row['type']]); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BREWER'); +xmlwriter_text($xw, 'Anonymous'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BATCH_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_TIME'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'EFFICIENCY'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['efficiency']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['og']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'FG'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['fg']))); +xmlwriter_end_element($xw); + +// Style +xmlwriter_start_element($xw, 'STYLE'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['st_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CATEGORY'); +xmlwriter_text($xw, $row['st_category']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CATEGORY_NUMBER'); +xmlwriter_text($xw, $row['st_category_number']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'STYLE_LETTER'); +xmlwriter_text($xw, $row['st_letter']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'STYLE_GUIDE'); +xmlwriter_text($xw, $row['st_guide']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TYPE'); +xmlwriter_text($xw, $styletype[$row['st_type']]); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MIN'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MAX'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'FG_MIN'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MAX'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_fg_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'IBU_MIN'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'IBU_MAX'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'COLOR_MIN'); +xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_min'])))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'COLOR_MAX'); +xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_max'])))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CARB_MIN'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CARB_MAX'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'ABV_MIN'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'ABV_MAX'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_max']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // STYLE + +xmlwriter_start_element($xw, 'EQUIPMENT'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['eq_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NOTES'); +xmlwriter_text($xw, $row['eq_notes']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BATCH_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['eq_batch_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['eq_boil_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_TIME'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['eq_boil_time']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // EQUIPMENT + +xmlwriter_start_element($xw, 'HOPS'); +$arr = json_decode($row['json_hops'], true); +foreach($arr as $item) { //foreach element in $arr + + xmlwriter_start_element($xw, 'HOP'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['h_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ALPHA'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_alpha']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['h_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'USE'); + xmlwriter_text($xw, $hopuse[$item['h_useat']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TIME'); + xmlwriter_text($xw, $item['h_time']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $hoptype[$item['h_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'FORM'); + xmlwriter_text($xw, $hopform[$item['h_form']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'BETA'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_beta']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'HSI'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_hsi']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ORIGIN'); + xmlwriter_text($xw, $item['h_origin']); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // HOP +} +xmlwriter_end_element($xw); // HOPS + +xmlwriter_start_element($xw, 'FERMENTABLES'); +$arr = json_decode($row['json_fermentables'], true); +foreach($arr as $item) { //foreach element in $arr + xmlwriter_start_element($xw, 'FERMENTABLE'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['f_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $fermentabletype[$item['f_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'YIELD'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_yield']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'COLOR'); + xmlwriter_text($xw, sprintf("%.1f",ebc_to_srm(floatval($item['f_color'])))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ADD_AFTER_BOIL'); + ($item['f_add_after_boil']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ORIGIN'); + xmlwriter_text($xw, $item['f_origin']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SUPPLIER'); + xmlwriter_text($xw, $item['f_supplier']); + xmlwriter_end_element($xw); + + if (floatval($item['f_coarse_fine_diff'])) { + xmlwriter_start_element($xw, 'COARSE_FINE_DIFF'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_coarse_fine_diff']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_moisture'])) { + xmlwriter_start_element($xw, 'MOISTURE'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_moisture']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_diastatic_power'])) { + xmlwriter_start_element($xw, 'DIASTATIC_POWER'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_diastatic_power']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_protein'])) { + xmlwriter_start_element($xw, 'PROTEIN'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_protein']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_max_in_batch'])) { + xmlwriter_start_element($xw, 'MAX_IN_BATCH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_max_in_batch']))); + xmlwriter_end_element($xw); + } + + xmlwriter_start_element($xw, 'RECOMMEND_MASH'); + ($item['f_recommend_mash']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'GRAINTYPE'); + xmlwriter_text($xw, $graintype[$item['f_graintype']]); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // FERMENTABLE +} +xmlwriter_end_element($xw); // FERMENTABLES + +xmlwriter_start_element($xw, 'MISCS'); +$arr = json_decode($row['json_miscs'], true); +foreach($arr as $item) { + + xmlwriter_start_element($xw, 'MISC'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['m_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $misctype[$item['m_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.5f",floatval($item['m_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); + ($item['m_amount_is_weight']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'USE'); + xmlwriter_text($xw, $miscuse[$item['m_use_use']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TIME'); + xmlwriter_text($xw, sprintf("%.0f",floatval($item['m_time']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // MISC +} +xmlwriter_end_element($xw); // MISCS + +xmlwriter_start_element($xw, 'YEASTS'); +$arr = json_decode($row['json_yeasts'], true); +foreach($arr as $item) { //foreach element in $arr + + xmlwriter_start_element($xw, 'YEAST'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['y_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $yeasttype[$item['y_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'FORM'); + xmlwriter_text($xw, $yeastform[$item['y_form']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.5f",floatval($item['y_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); + ($item['y_form'] == 1) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'LABORATORY'); + xmlwriter_text($xw, $item['y_laboratory']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PRODUCT_ID'); + xmlwriter_text($xw, $item['y_product_id']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'MIN_TEMPERATURE'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_min_temperature']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'MAX_TEMPERATURE'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_max_temperature']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ATTENUATION'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_attenuation']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ADD_TO_SECONDARY'); + ($item['y_use'] == 0) ? xmlwriter_text($xw, 'FALSE') : xmlwriter_text($xw, 'TRUE'); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // YEAST +} +xmlwriter_end_element($xw); // YEASTS + +xmlwriter_start_element($xw, 'WATERS'); +xmlwriter_start_element($xw, 'WATER'); // Source 1 + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['w1_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'AMOUNT'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_amount']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CALCIUM'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_calcium']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BICARBONATE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']) * 1.22)); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SULFATE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sulfate']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CHLORIDE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_chloride']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SODIUM'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sodium']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'PH'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['w1_ph']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // WATER + +if (strlen($row['w2_name'])) { + xmlwriter_start_element($xw, 'WATER'); // Source 2 + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $row['w2_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'CALCIUM'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_calcium']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'BICARBONATE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']) * 1.22)); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SULFATE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sulfate']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'CHLORIDE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_chloride']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SODIUM'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sodium']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($row['w2_ph']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // WATER +} +xmlwriter_end_element($xw); // WATERS + +xmlwriter_start_element($xw, 'MASH'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['mash_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'GRAIN_TEMP'); +xmlwriter_text($xw, '10.0'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'PH'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_ph']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SPARGE_TEMP'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_temp']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'MASH_STEPS'); +$arr = json_decode($row['json_mashs'], true); +foreach($arr as $item) { //foreach element in $arr + xmlwriter_start_element($xw, 'MASH_STEP'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['step_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $mashsteptype[$item['step_type']]); + xmlwriter_end_element($xw); + + if ($item['step_type'] == 0) { + xmlwriter_start_element($xw, 'INFUSE_AMOUNT'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_infuse_amount']))); + xmlwriter_end_element($xw); + } + + xmlwriter_start_element($xw, 'STEP_TEMP'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_temp']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'STEP_TIME'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_time']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'RAMP_TIME'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['ramp_time']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'END_TEMP'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['end_temp']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($row['mash_ph']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // MASH_STEP +} +xmlwriter_end_element($xw); // MASH_STEPS +xmlwriter_end_element($xw); // MASH +xmlwriter_end_element($xw); // RECIPE +xmlwriter_end_element($xw); // RECIPES +xmlwriter_end_document($xw); + +$beerxml = xmlwriter_output_memory($xw); + +Header('Content-type: text/xml'); +header('Content-Disposition: attachment; filename="' . $row['code'] . ' ' . $row['name'] . '.xml"'); +header('Content-Transfer-Encoding: binary'); +header('Expires: 0'); +header('Pragma: no-cache'); +header('Content-Length: '.strlen($beerxml)); +exit($beerxml);
--- a/www/prod_export.php Wed Feb 27 22:14:03 2019 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,614 +0,0 @@ -<?php -require_once('config.php'); -require_once('includes/formulas.php'); -//require_once($_SERVER['DOCUMENT_ROOT'].'/config.php'); -//require_once($_SERVER['DOCUMENT_ROOT'].'/includes/formulas.php'); - - -$link = mysqli_connect(DBASE_HOST,DBASE_USER,DBASE_PASS,DBASE_NAME); -if (! $link) { - die('Connect Error (' . mysqli_connect_errno() . ') ' . mysqli_connect_error()); -} -if (! mysqli_set_charset($link, "utf8" )) { - echo "error"; - return 1; -} - -//setlocale ( LC_ALL, 'nl_NL.UTF-8'); -if (isset($_GET["record"])) - $record = $_GET["record"]; -else - $record = 78; -$result = mysqli_query($link, "SELECT * FROM products WHERE record='".$record."'"); -$row = mysqli_fetch_array($result); - - -$recipetype = array( 'Extract', 'Partial Mash', 'All Grain' ); -$styletype = array( 'Lager', 'Ale', 'Mead', 'Wheat', 'Mixed', 'Cider' ); -$hoptype = array( 'Bittering', 'Aroma', 'Both' ); -$hopform = array( 'Pellet', 'Plug', 'Leaf' ); -$hopuse = array( 'Mash', 'First wort', 'Boil', 'Aroma', 'Whirlpool', 'Dry hop' ); -$fermentabletype = array( 'Grain', 'Sugar', 'Extract', 'Dry extract', 'Adjunct' ); -$graintype = array( 'Base', 'Roast', 'Crystal', 'Kilned', 'Sour malt', 'Special', 'No malt' ); -$yeasttype = array( 'Lager', 'Ale', 'Wheat', 'Wine', 'Champagne' ); -$yeastform = array( 'Liquid', 'Dry', 'Slant', 'Culture', 'Frozen', 'Bottle' ); -$yeastuse = array( 'Primary', 'Secondary', 'Tertiary', 'Bottle' ); -$misctype = array( 'Spice', 'Herb', 'Flavor', 'Fining', 'Water agent', 'Yeast nutrient', 'Other' ); -$miscuse = array( 'Starter', 'Mash', 'Boil', 'Primary', 'Secondary', 'Bottling' ); -$mashsteptype = array( 'Infusion', 'Temperature', 'Decoction' ); - - - -/* - * Create beerxml output - */ -$xw = xmlwriter_open_memory(); -xmlwriter_set_indent($xw, 1); -$res = xmlwriter_set_indent_string($xw, ' '); - -xmlwriter_start_document($xw, '1.0', 'UTF-8'); - -xmlwriter_start_element($xw, 'RECIPES'); -xmlwriter_start_element($xw, 'RECIPE'); - -// Recipe basics -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NOTES'); -xmlwriter_text($xw, $row['notes']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TYPE'); -xmlwriter_text($xw, $recipetype[$row['type']]); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BREWER'); -xmlwriter_text($xw, 'Anonymous'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BATCH_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_TIME'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'EFFICIENCY'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['efficiency']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['og']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'FG'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['fg']))); -xmlwriter_end_element($xw); - -// Style -xmlwriter_start_element($xw, 'STYLE'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['st_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CATEGORY'); -xmlwriter_text($xw, $row['st_category']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CATEGORY_NUMBER'); -xmlwriter_text($xw, $row['st_category_number']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'STYLE_LETTER'); -xmlwriter_text($xw, $row['st_letter']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'STYLE_GUIDE'); -xmlwriter_text($xw, $row['st_guide']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TYPE'); -xmlwriter_text($xw, $styletype[$row['st_type']]); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MIN'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MAX'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'FG_MIN'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MAX'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_fg_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'IBU_MIN'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'IBU_MAX'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'COLOR_MIN'); -xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_min'])))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'COLOR_MAX'); -xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_max'])))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CARB_MIN'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CARB_MAX'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'ABV_MIN'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'ABV_MAX'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_max']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // STYLE - -xmlwriter_start_element($xw, 'EQUIPMENT'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['eq_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NOTES'); -xmlwriter_text($xw, $row['eq_notes']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BATCH_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['eq_batch_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['eq_boil_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_TIME'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['eq_boil_time']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // EQUIPMENT - -xmlwriter_start_element($xw, 'HOPS'); -$arr = json_decode($row['json_hops'], true); -foreach($arr as $item) { //foreach element in $arr - - xmlwriter_start_element($xw, 'HOP'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['h_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ALPHA'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_alpha']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['h_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'USE'); - xmlwriter_text($xw, $hopuse[$item['h_useat']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TIME'); - xmlwriter_text($xw, $item['h_time']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $hoptype[$item['h_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'FORM'); - xmlwriter_text($xw, $hopform[$item['h_form']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'BETA'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_beta']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'HSI'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_hsi']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ORIGIN'); - xmlwriter_text($xw, $item['h_origin']); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // HOP -} -xmlwriter_end_element($xw); // HOPS - -xmlwriter_start_element($xw, 'FERMENTABLES'); -$arr = json_decode($row['json_fermentables'], true); -foreach($arr as $item) { //foreach element in $arr - xmlwriter_start_element($xw, 'FERMENTABLE'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['f_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $fermentabletype[$item['f_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'YIELD'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_yield']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'COLOR'); - xmlwriter_text($xw, sprintf("%.1f",ebc_to_srm(floatval($item['f_color'])))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ADD_AFTER_BOIL'); - ($item['f_add_after_boil']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ORIGIN'); - xmlwriter_text($xw, $item['f_origin']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SUPPLIER'); - xmlwriter_text($xw, $item['f_supplier']); - xmlwriter_end_element($xw); - - if (floatval($item['f_coarse_fine_diff'])) { - xmlwriter_start_element($xw, 'COARSE_FINE_DIFF'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_coarse_fine_diff']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_moisture'])) { - xmlwriter_start_element($xw, 'MOISTURE'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_moisture']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_diastatic_power'])) { - xmlwriter_start_element($xw, 'DIASTATIC_POWER'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_diastatic_power']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_protein'])) { - xmlwriter_start_element($xw, 'PROTEIN'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_protein']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_max_in_batch'])) { - xmlwriter_start_element($xw, 'MAX_IN_BATCH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_max_in_batch']))); - xmlwriter_end_element($xw); - } - - xmlwriter_start_element($xw, 'RECOMMEND_MASH'); - ($item['f_recommend_mash']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'GRAINTYPE'); - xmlwriter_text($xw, $graintype[$item['f_graintype']]); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // FERMENTABLE -} -xmlwriter_end_element($xw); // FERMENTABLES - -xmlwriter_start_element($xw, 'MISCS'); -$arr = json_decode($row['json_miscs'], true); -foreach($arr as $item) { - - xmlwriter_start_element($xw, 'MISC'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['m_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $misctype[$item['m_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.5f",floatval($item['m_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); - ($item['m_amount_is_weight']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'USE'); - xmlwriter_text($xw, $miscuse[$item['m_use_use']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TIME'); - xmlwriter_text($xw, sprintf("%.0f",floatval($item['m_time']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // MISC -} -xmlwriter_end_element($xw); // MISCS - -xmlwriter_start_element($xw, 'YEASTS'); -$arr = json_decode($row['json_yeasts'], true); -foreach($arr as $item) { //foreach element in $arr - - xmlwriter_start_element($xw, 'YEAST'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['y_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $yeasttype[$item['y_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'FORM'); - xmlwriter_text($xw, $yeastform[$item['y_form']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.5f",floatval($item['y_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); - ($item['y_form'] == 1) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'LABORATORY'); - xmlwriter_text($xw, $item['y_laboratory']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PRODUCT_ID'); - xmlwriter_text($xw, $item['y_product_id']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'MIN_TEMPERATURE'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_min_temperature']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'MAX_TEMPERATURE'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_max_temperature']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ATTENUATION'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_attenuation']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ADD_TO_SECONDARY'); - ($item['y_use'] == 0) ? xmlwriter_text($xw, 'FALSE') : xmlwriter_text($xw, 'TRUE'); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // YEAST -} -xmlwriter_end_element($xw); // YEASTS - -xmlwriter_start_element($xw, 'WATERS'); -xmlwriter_start_element($xw, 'WATER'); // Source 1 - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['w1_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'AMOUNT'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_amount']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CALCIUM'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_calcium']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BICARBONATE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']) * 1.22)); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SULFATE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sulfate']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CHLORIDE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_chloride']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SODIUM'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sodium']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'PH'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['w1_ph']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // WATER - -if (strlen($row['w2_name'])) { - xmlwriter_start_element($xw, 'WATER'); // Source 2 - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $row['w2_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'CALCIUM'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_calcium']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'BICARBONATE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']) * 1.22)); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SULFATE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sulfate']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'CHLORIDE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_chloride']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SODIUM'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sodium']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($row['w2_ph']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // WATER -} -xmlwriter_end_element($xw); // WATERS - -xmlwriter_start_element($xw, 'MASH'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['mash_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'GRAIN_TEMP'); -xmlwriter_text($xw, '10.0'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'PH'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_ph']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SPARGE_TEMP'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_temp']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'MASH_STEPS'); -$arr = json_decode($row['json_mashs'], true); -foreach($arr as $item) { //foreach element in $arr - xmlwriter_start_element($xw, 'MASH_STEP'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['step_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $mashsteptype[$item['step_type']]); - xmlwriter_end_element($xw); - - if ($item['step_type'] == 0) { - xmlwriter_start_element($xw, 'INFUSE_AMOUNT'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_infuse_amount']))); - xmlwriter_end_element($xw); - } - - xmlwriter_start_element($xw, 'STEP_TEMP'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_temp']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'STEP_TIME'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_time']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'RAMP_TIME'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['ramp_time']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'END_TEMP'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['end_temp']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($row['mash_ph']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // MASH_STEP -} -xmlwriter_end_element($xw); // MASH_STEPS -xmlwriter_end_element($xw); // MASH -xmlwriter_end_element($xw); // RECIPE -xmlwriter_end_element($xw); // RECIPES -xmlwriter_end_document($xw); - -$beerxml = xmlwriter_output_memory($xw); - -Header('Content-type: text/xml'); -header('Content-Disposition: attachment; filename="' . $row['code'] . ' ' . $row['name'] . '.xml"'); -header('Content-Transfer-Encoding: binary'); -header('Expires: 0'); -header('Pragma: no-cache'); -header('Content-Length: '.strlen($beerxml)); -exit($beerxml);
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/www/rec_beerxml.php Thu Feb 28 15:40:14 2019 +0100 @@ -0,0 +1,610 @@ +<?php +//require_once('config.php'); +//require_once('includes/formulas.php'); +require_once($_SERVER['DOCUMENT_ROOT'].'/config.php'); +require_once($_SERVER['DOCUMENT_ROOT'].'/includes/formulas.php'); + + +$link = mysqli_connect(DBASE_HOST,DBASE_USER,DBASE_PASS,DBASE_NAME); +if (! $link) { + die('Connect Error (' . mysqli_connect_errno() . ') ' . mysqli_connect_error()); +} +if (! mysqli_set_charset($link, "utf8" )) { + echo "error"; + return 1; +} + +//setlocale ( LC_ALL, 'nl_NL.UTF-8'); +if (isset($_GET["record"])) + $record = $_GET["record"]; +else + $record = 148; +$result = mysqli_query($link, "SELECT * FROM recipes WHERE record='".$record."'"); +$row = mysqli_fetch_array($result); + + +$recipetype = array( 'Extract', 'Partial Mash', 'All Grain' ); +$styletype = array( 'Lager', 'Ale', 'Mead', 'Wheat', 'Mixed', 'Cider' ); +$hoptype = array( 'Bittering', 'Aroma', 'Both' ); +$hopform = array( 'Pellet', 'Plug', 'Leaf' ); +$hopuse = array( 'Mash', 'First wort', 'Boil', 'Aroma', 'Whirlpool', 'Dry hop' ); +$fermentabletype = array( 'Grain', 'Sugar', 'Extract', 'Dry extract', 'Adjunct' ); +$graintype = array( 'Base', 'Roast', 'Crystal', 'Kilned', 'Sour malt', 'Special', 'No malt' ); +$yeasttype = array( 'Lager', 'Ale', 'Wheat', 'Wine', 'Champagne' ); +$yeastform = array( 'Liquid', 'Dry', 'Slant', 'Culture', 'Frozen', 'Bottle' ); +$yeastuse = array( 'Primary', 'Secondary', 'Tertiary', 'Bottle' ); +$misctype = array( 'Spice', 'Herb', 'Flavor', 'Fining', 'Water agent', 'Yeast nutrient', 'Other' ); +$miscuse = array( 'Starter', 'Mash', 'Boil', 'Primary', 'Secondary', 'Bottling' ); +$mashsteptype = array( 'Infusion', 'Temperature', 'Decoction' ); + + +/* + * Create beerxml output + */ +$xw = xmlwriter_open_memory(); +xmlwriter_set_indent($xw, 1); +$res = xmlwriter_set_indent_string($xw, ' '); + +xmlwriter_start_document($xw, '1.0', 'UTF-8'); + +xmlwriter_start_element($xw, 'RECIPES'); +xmlwriter_start_element($xw, 'RECIPE'); + +// Recipe basics +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NOTES'); +xmlwriter_text($xw, $row['notes']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TYPE'); +xmlwriter_text($xw, $recipetype[$row['type']]); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BREWER'); +xmlwriter_text($xw, 'Anonymous'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BATCH_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_TIME'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'EFFICIENCY'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['efficiency']))); +xmlwriter_end_element($xw); + + +// Style +xmlwriter_start_element($xw, 'STYLE'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['st_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CATEGORY'); +xmlwriter_text($xw, $row['st_category']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CATEGORY_NUMBER'); +xmlwriter_text($xw, $row['st_category_number']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'STYLE_LETTER'); +xmlwriter_text($xw, $row['st_letter']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'STYLE_GUIDE'); +xmlwriter_text($xw, $row['st_guide']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TYPE'); +xmlwriter_text($xw, $styletype[$row['st_type']]); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MIN'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MAX'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'FG_MIN'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'OG_MAX'); +xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_fg_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'IBU_MIN'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'IBU_MAX'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'COLOR_MIN'); +xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_min'])))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'COLOR_MAX'); +xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_max'])))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CARB_MIN'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CARB_MAX'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_max']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'ABV_MIN'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_min']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'ABV_MAX'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_max']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // STYLE + + +xmlwriter_start_element($xw, 'EQUIPMENT'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, 'Dummy brewery'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BATCH_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_SIZE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BOIL_TIME'); +xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // EQUIPMENT + + +xmlwriter_start_element($xw, 'HOPS'); +$arr = json_decode($row['json_hops'], true); +foreach($arr as $item) { //foreach element in $arr + + xmlwriter_start_element($xw, 'HOP'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['h_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ALPHA'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_alpha']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['h_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'USE'); + xmlwriter_text($xw, $hopuse[$item['h_useat']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TIME'); + xmlwriter_text($xw, $item['h_time']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $hoptype[$item['h_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'FORM'); + xmlwriter_text($xw, $hopform[$item['h_form']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'BETA'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_beta']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'HSI'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_hsi']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ORIGIN'); + xmlwriter_text($xw, $item['h_origin']); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // HOP +} +xmlwriter_end_element($xw); // HOPS + + +xmlwriter_start_element($xw, 'FERMENTABLES'); +$arr = json_decode($row['json_fermentables'], true); +foreach($arr as $item) { //foreach element in $arr + xmlwriter_start_element($xw, 'FERMENTABLE'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['f_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $fermentabletype[$item['f_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'YIELD'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_yield']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'COLOR'); + xmlwriter_text($xw, sprintf("%.1f",ebc_to_srm(floatval($item['f_color'])))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ADD_AFTER_BOIL'); + ($item['f_add_after_boil']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ORIGIN'); + xmlwriter_text($xw, $item['f_origin']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SUPPLIER'); + xmlwriter_text($xw, $item['f_supplier']); + xmlwriter_end_element($xw); + + if (floatval($item['f_coarse_fine_diff'])) { + xmlwriter_start_element($xw, 'COARSE_FINE_DIFF'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_coarse_fine_diff']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_moisture'])) { + xmlwriter_start_element($xw, 'MOISTURE'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_moisture']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_diastatic_power'])) { + xmlwriter_start_element($xw, 'DIASTATIC_POWER'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_diastatic_power']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_protein'])) { + xmlwriter_start_element($xw, 'PROTEIN'); + xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_protein']))); + xmlwriter_end_element($xw); + } + + if (floatval($item['f_max_in_batch'])) { + xmlwriter_start_element($xw, 'MAX_IN_BATCH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_max_in_batch']))); + xmlwriter_end_element($xw); + } + + xmlwriter_start_element($xw, 'RECOMMEND_MASH'); + ($item['f_recommend_mash']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'GRAINTYPE'); + xmlwriter_text($xw, $graintype[$item['f_graintype']]); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // FERMENTABLE +} +xmlwriter_end_element($xw); // FERMENTABLES + + +xmlwriter_start_element($xw, 'MISCS'); +$arr = json_decode($row['json_miscs'], true); +foreach($arr as $item) { + + xmlwriter_start_element($xw, 'MISC'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['m_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $misctype[$item['m_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.5f",floatval($item['m_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); + ($item['m_amount_is_weight']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'USE'); + xmlwriter_text($xw, $miscuse[$item['m_use_use']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TIME'); + xmlwriter_text($xw, sprintf("%.0f",floatval($item['m_time']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // MISC +} +xmlwriter_end_element($xw); // MISCS + + +xmlwriter_start_element($xw, 'YEASTS'); +$arr = json_decode($row['json_yeasts'], true); +foreach($arr as $item) { //foreach element in $arr + + xmlwriter_start_element($xw, 'YEAST'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['y_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $yeasttype[$item['y_type']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'FORM'); + xmlwriter_text($xw, $yeastform[$item['y_form']]); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.5f",floatval($item['y_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); + ($item['y_form'] == 1) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'LABORATORY'); + xmlwriter_text($xw, $item['y_laboratory']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PRODUCT_ID'); + xmlwriter_text($xw, $item['y_product_id']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'MIN_TEMPERATURE'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_min_temperature']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'MAX_TEMPERATURE'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_max_temperature']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ATTENUATION'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_attenuation']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'ADD_TO_SECONDARY'); + ($item['y_use'] == 0) ? xmlwriter_text($xw, 'FALSE') : xmlwriter_text($xw, 'TRUE'); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // YEAST +} +xmlwriter_end_element($xw); // YEASTS + + +xmlwriter_start_element($xw, 'WATERS'); +xmlwriter_start_element($xw, 'WATER'); // Source 1 + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['w1_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'AMOUNT'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_amount']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CALCIUM'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_calcium']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'BICARBONATE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']) * 1.22)); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SULFATE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sulfate']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'CHLORIDE'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_chloride']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SODIUM'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sodium']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'PH'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['w1_ph']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); +xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']))); +xmlwriter_end_element($xw); + +xmlwriter_end_element($xw); // WATER + +if (strlen($row['w2_name'])) { + xmlwriter_start_element($xw, 'WATER'); // Source 2 + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $row['w2_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'AMOUNT'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_amount']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'CALCIUM'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_calcium']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'BICARBONATE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']) * 1.22)); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SULFATE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sulfate']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'CHLORIDE'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_chloride']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'SODIUM'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sodium']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($row['w2_ph']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); + xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // WATER +} +xmlwriter_end_element($xw); // WATERS + + +xmlwriter_start_element($xw, 'MASH'); + +xmlwriter_start_element($xw, 'VERSION'); +xmlwriter_text($xw, '1'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'NAME'); +xmlwriter_text($xw, $row['mash_name']); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'GRAIN_TEMP'); +xmlwriter_text($xw, '10.0'); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'PH'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_ph']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'SPARGE_TEMP'); +xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_temp']))); +xmlwriter_end_element($xw); + +xmlwriter_start_element($xw, 'MASH_STEPS'); +$arr = json_decode($row['json_mashs'], true); +foreach($arr as $item) { //foreach element in $arr + xmlwriter_start_element($xw, 'MASH_STEP'); + + xmlwriter_start_element($xw, 'VERSION'); + xmlwriter_text($xw, '1'); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'NAME'); + xmlwriter_text($xw, $item['step_name']); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'TYPE'); + xmlwriter_text($xw, $mashsteptype[$item['step_type']]); + xmlwriter_end_element($xw); + + if ($item['step_type'] == 0) { + xmlwriter_start_element($xw, 'INFUSE_AMOUNT'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_infuse_amount']))); + xmlwriter_end_element($xw); + } + + xmlwriter_start_element($xw, 'STEP_TEMP'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_temp']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'STEP_TIME'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_time']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'RAMP_TIME'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['ramp_time']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'END_TEMP'); + xmlwriter_text($xw, sprintf("%.1f",floatval($item['end_temp']))); + xmlwriter_end_element($xw); + + xmlwriter_start_element($xw, 'PH'); + xmlwriter_text($xw, sprintf("%.1f",floatval($row['mash_ph']))); + xmlwriter_end_element($xw); + + xmlwriter_end_element($xw); // MASH_STEP +} +xmlwriter_end_element($xw); // MASH_STEPS +xmlwriter_end_element($xw); // MASH + +xmlwriter_end_element($xw); // RECIPE +xmlwriter_end_element($xw); // RECIPES +xmlwriter_end_document($xw); + +$beerxml = xmlwriter_output_memory($xw); + +Header('Content-type: text/xml'); +header('Content-Disposition: attachment; filename="' . $row['name'] . '.xml"'); +header('Content-Transfer-Encoding: binary'); +header('Expires: 0'); +header('Pragma: no-cache'); +header('Content-Length: '.strlen($beerxml)); +exit($beerxml);
--- a/www/rec_export.php Wed Feb 27 22:14:03 2019 +0100 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,610 +0,0 @@ -<?php -//require_once('config.php'); -//require_once('includes/formulas.php'); -require_once($_SERVER['DOCUMENT_ROOT'].'/config.php'); -require_once($_SERVER['DOCUMENT_ROOT'].'/includes/formulas.php'); - - -$link = mysqli_connect(DBASE_HOST,DBASE_USER,DBASE_PASS,DBASE_NAME); -if (! $link) { - die('Connect Error (' . mysqli_connect_errno() . ') ' . mysqli_connect_error()); -} -if (! mysqli_set_charset($link, "utf8" )) { - echo "error"; - return 1; -} - -//setlocale ( LC_ALL, 'nl_NL.UTF-8'); -if (isset($_GET["record"])) - $record = $_GET["record"]; -else - $record = 148; -$result = mysqli_query($link, "SELECT * FROM recipes WHERE record='".$record."'"); -$row = mysqli_fetch_array($result); - - -$recipetype = array( 'Extract', 'Partial Mash', 'All Grain' ); -$styletype = array( 'Lager', 'Ale', 'Mead', 'Wheat', 'Mixed', 'Cider' ); -$hoptype = array( 'Bittering', 'Aroma', 'Both' ); -$hopform = array( 'Pellet', 'Plug', 'Leaf' ); -$hopuse = array( 'Mash', 'First wort', 'Boil', 'Aroma', 'Whirlpool', 'Dry hop' ); -$fermentabletype = array( 'Grain', 'Sugar', 'Extract', 'Dry extract', 'Adjunct' ); -$graintype = array( 'Base', 'Roast', 'Crystal', 'Kilned', 'Sour malt', 'Special', 'No malt' ); -$yeasttype = array( 'Lager', 'Ale', 'Wheat', 'Wine', 'Champagne' ); -$yeastform = array( 'Liquid', 'Dry', 'Slant', 'Culture', 'Frozen', 'Bottle' ); -$yeastuse = array( 'Primary', 'Secondary', 'Tertiary', 'Bottle' ); -$misctype = array( 'Spice', 'Herb', 'Flavor', 'Fining', 'Water agent', 'Yeast nutrient', 'Other' ); -$miscuse = array( 'Starter', 'Mash', 'Boil', 'Primary', 'Secondary', 'Bottling' ); -$mashsteptype = array( 'Infusion', 'Temperature', 'Decoction' ); - - -/* - * Create beerxml output - */ -$xw = xmlwriter_open_memory(); -xmlwriter_set_indent($xw, 1); -$res = xmlwriter_set_indent_string($xw, ' '); - -xmlwriter_start_document($xw, '1.0', 'UTF-8'); - -xmlwriter_start_element($xw, 'RECIPES'); -xmlwriter_start_element($xw, 'RECIPE'); - -// Recipe basics -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NOTES'); -xmlwriter_text($xw, $row['notes']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TYPE'); -xmlwriter_text($xw, $recipetype[$row['type']]); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BREWER'); -xmlwriter_text($xw, 'Anonymous'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BATCH_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_TIME'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'EFFICIENCY'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['efficiency']))); -xmlwriter_end_element($xw); - - -// Style -xmlwriter_start_element($xw, 'STYLE'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['st_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CATEGORY'); -xmlwriter_text($xw, $row['st_category']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CATEGORY_NUMBER'); -xmlwriter_text($xw, $row['st_category_number']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'STYLE_LETTER'); -xmlwriter_text($xw, $row['st_letter']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'STYLE_GUIDE'); -xmlwriter_text($xw, $row['st_guide']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TYPE'); -xmlwriter_text($xw, $styletype[$row['st_type']]); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MIN'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MAX'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'FG_MIN'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_og_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'OG_MAX'); -xmlwriter_text($xw, sprintf("%.3f",floatval($row['st_fg_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'IBU_MIN'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'IBU_MAX'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['st_ibu_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'COLOR_MIN'); -xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_min'])))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'COLOR_MAX'); -xmlwriter_text($xw, sprintf("%.2f",ebc_to_srm(floatval($row['st_color_max'])))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CARB_MIN'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CARB_MAX'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_carb_max']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'ABV_MIN'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_min']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'ABV_MAX'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['st_abv_max']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // STYLE - - -xmlwriter_start_element($xw, 'EQUIPMENT'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, 'Dummy brewery'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BATCH_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['batch_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_SIZE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['boil_size']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BOIL_TIME'); -xmlwriter_text($xw, sprintf("%.0f",floatval($row['boil_time']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // EQUIPMENT - - -xmlwriter_start_element($xw, 'HOPS'); -$arr = json_decode($row['json_hops'], true); -foreach($arr as $item) { //foreach element in $arr - - xmlwriter_start_element($xw, 'HOP'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['h_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ALPHA'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_alpha']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['h_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'USE'); - xmlwriter_text($xw, $hopuse[$item['h_useat']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TIME'); - xmlwriter_text($xw, $item['h_time']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $hoptype[$item['h_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'FORM'); - xmlwriter_text($xw, $hopform[$item['h_form']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'BETA'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_beta']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'HSI'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['h_hsi']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ORIGIN'); - xmlwriter_text($xw, $item['h_origin']); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // HOP -} -xmlwriter_end_element($xw); // HOPS - - -xmlwriter_start_element($xw, 'FERMENTABLES'); -$arr = json_decode($row['json_fermentables'], true); -foreach($arr as $item) { //foreach element in $arr - xmlwriter_start_element($xw, 'FERMENTABLE'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['f_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $fermentabletype[$item['f_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'YIELD'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_yield']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'COLOR'); - xmlwriter_text($xw, sprintf("%.1f",ebc_to_srm(floatval($item['f_color'])))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ADD_AFTER_BOIL'); - ($item['f_add_after_boil']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ORIGIN'); - xmlwriter_text($xw, $item['f_origin']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SUPPLIER'); - xmlwriter_text($xw, $item['f_supplier']); - xmlwriter_end_element($xw); - - if (floatval($item['f_coarse_fine_diff'])) { - xmlwriter_start_element($xw, 'COARSE_FINE_DIFF'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_coarse_fine_diff']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_moisture'])) { - xmlwriter_start_element($xw, 'MOISTURE'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_moisture']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_diastatic_power'])) { - xmlwriter_start_element($xw, 'DIASTATIC_POWER'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_diastatic_power']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_protein'])) { - xmlwriter_start_element($xw, 'PROTEIN'); - xmlwriter_text($xw, sprintf("%.4f",floatval($item['f_protein']))); - xmlwriter_end_element($xw); - } - - if (floatval($item['f_max_in_batch'])) { - xmlwriter_start_element($xw, 'MAX_IN_BATCH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['f_max_in_batch']))); - xmlwriter_end_element($xw); - } - - xmlwriter_start_element($xw, 'RECOMMEND_MASH'); - ($item['f_recommend_mash']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'GRAINTYPE'); - xmlwriter_text($xw, $graintype[$item['f_graintype']]); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // FERMENTABLE -} -xmlwriter_end_element($xw); // FERMENTABLES - - -xmlwriter_start_element($xw, 'MISCS'); -$arr = json_decode($row['json_miscs'], true); -foreach($arr as $item) { - - xmlwriter_start_element($xw, 'MISC'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['m_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $misctype[$item['m_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.5f",floatval($item['m_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); - ($item['m_amount_is_weight']) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'USE'); - xmlwriter_text($xw, $miscuse[$item['m_use_use']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TIME'); - xmlwriter_text($xw, sprintf("%.0f",floatval($item['m_time']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // MISC -} -xmlwriter_end_element($xw); // MISCS - - -xmlwriter_start_element($xw, 'YEASTS'); -$arr = json_decode($row['json_yeasts'], true); -foreach($arr as $item) { //foreach element in $arr - - xmlwriter_start_element($xw, 'YEAST'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['y_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $yeasttype[$item['y_type']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'FORM'); - xmlwriter_text($xw, $yeastform[$item['y_form']]); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.5f",floatval($item['y_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT_IS_WEIGHT'); - ($item['y_form'] == 1) ? xmlwriter_text($xw, 'TRUE') : xmlwriter_text($xw, 'FALSE'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'LABORATORY'); - xmlwriter_text($xw, $item['y_laboratory']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PRODUCT_ID'); - xmlwriter_text($xw, $item['y_product_id']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'MIN_TEMPERATURE'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_min_temperature']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'MAX_TEMPERATURE'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_max_temperature']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ATTENUATION'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['y_attenuation']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'ADD_TO_SECONDARY'); - ($item['y_use'] == 0) ? xmlwriter_text($xw, 'FALSE') : xmlwriter_text($xw, 'TRUE'); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // YEAST -} -xmlwriter_end_element($xw); // YEASTS - - -xmlwriter_start_element($xw, 'WATERS'); -xmlwriter_start_element($xw, 'WATER'); // Source 1 - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['w1_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'AMOUNT'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_amount']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CALCIUM'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_calcium']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'BICARBONATE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']) * 1.22)); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SULFATE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sulfate']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'CHLORIDE'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_chloride']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SODIUM'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_sodium']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'PH'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['w1_ph']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); -xmlwriter_text($xw, sprintf("%.2f",floatval($row['w1_total_alkalinity']))); -xmlwriter_end_element($xw); - -xmlwriter_end_element($xw); // WATER - -if (strlen($row['w2_name'])) { - xmlwriter_start_element($xw, 'WATER'); // Source 2 - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $row['w2_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'AMOUNT'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_amount']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'CALCIUM'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_calcium']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'BICARBONATE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']) * 1.22)); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SULFATE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sulfate']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'CHLORIDE'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_chloride']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'SODIUM'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_sodium']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($row['w2_ph']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TOTAL_ALKALINITY'); - xmlwriter_text($xw, sprintf("%.2f",floatval($row['w2_total_alkalinity']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // WATER -} -xmlwriter_end_element($xw); // WATERS - - -xmlwriter_start_element($xw, 'MASH'); - -xmlwriter_start_element($xw, 'VERSION'); -xmlwriter_text($xw, '1'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'NAME'); -xmlwriter_text($xw, $row['mash_name']); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'GRAIN_TEMP'); -xmlwriter_text($xw, '10.0'); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'PH'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_ph']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'SPARGE_TEMP'); -xmlwriter_text($xw, sprintf("%.1f",floatval($row['sparge_temp']))); -xmlwriter_end_element($xw); - -xmlwriter_start_element($xw, 'MASH_STEPS'); -$arr = json_decode($row['json_mashs'], true); -foreach($arr as $item) { //foreach element in $arr - xmlwriter_start_element($xw, 'MASH_STEP'); - - xmlwriter_start_element($xw, 'VERSION'); - xmlwriter_text($xw, '1'); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'NAME'); - xmlwriter_text($xw, $item['step_name']); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'TYPE'); - xmlwriter_text($xw, $mashsteptype[$item['step_type']]); - xmlwriter_end_element($xw); - - if ($item['step_type'] == 0) { - xmlwriter_start_element($xw, 'INFUSE_AMOUNT'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_infuse_amount']))); - xmlwriter_end_element($xw); - } - - xmlwriter_start_element($xw, 'STEP_TEMP'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_temp']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'STEP_TIME'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['step_time']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'RAMP_TIME'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['ramp_time']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'END_TEMP'); - xmlwriter_text($xw, sprintf("%.1f",floatval($item['end_temp']))); - xmlwriter_end_element($xw); - - xmlwriter_start_element($xw, 'PH'); - xmlwriter_text($xw, sprintf("%.1f",floatval($row['mash_ph']))); - xmlwriter_end_element($xw); - - xmlwriter_end_element($xw); // MASH_STEP -} -xmlwriter_end_element($xw); // MASH_STEPS -xmlwriter_end_element($xw); // MASH - -xmlwriter_end_element($xw); // RECIPE -xmlwriter_end_element($xw); // RECIPES -xmlwriter_end_document($xw); - -$beerxml = xmlwriter_output_memory($xw); - -Header('Content-type: text/xml'); -header('Content-Disposition: attachment; filename="' . $row['name'] . '.xml"'); -header('Content-Transfer-Encoding: binary'); -header('Expires: 0'); -header('Pragma: no-cache'); -header('Content-Length: '.strlen($beerxml)); -exit($beerxml);