From 82c54972d7cbfd48d325dacc005471b2a8137134 Mon Sep 17 00:00:00 2001 From: Ludovic Pouzenc Date: Sat, 12 Mar 2016 15:40:43 +0100 Subject: Initial import for API part. --- api/data.json.php | 87 ++++++++++++++++++++++++++++++++++++++++++++++ api/gen_conf.php | 72 ++++++++++++++++++++++++++++++++++++++ api/gen_firm.php | 62 +++++++++++++++++++++++++++++++++ api/inc/config.default.php | 8 +++++ api/mig_wan6ll.php | 53 ++++++++++++++++++++++++++++ 5 files changed, 282 insertions(+) create mode 100644 api/data.json.php create mode 100644 api/gen_conf.php create mode 100644 api/gen_firm.php create mode 100644 api/inc/config.default.php create mode 100644 api/mig_wan6ll.php (limited to 'api') diff --git a/api/data.json.php b/api/data.json.php new file mode 100644 index 0000000..d94ffb2 --- /dev/null +++ b/api/data.json.php @@ -0,0 +1,87 @@ + + * Copyright 2016 Nicolas Goaziou + * + * This file is part of CHD Gestion. + * + * CHD Gestion is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * CHD Gestion is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with CHD Gestion. If not, see . +**/ + +include_once('inc/config.php'); +$mysqli = new mysqli($db_config['host'], $db_config['username'], $db_config['password'], $db_config['database']); +unset($db_config); +$mysqli->query("SET NAMES 'utf8'"); + +$res = $mysqli->query("SELECT id, CONCAT('e', id) as 'name', uplink_id FROM equipements"); + +$roots = array(); +$childrens = array(); +while ( $row = $res->fetch_assoc() ) { + if ( ! array_key_exists($row['id'], $childrens) ) { + $childrens[$row['id']] = array(); + } + $row['children'] = &$childrens[$row['id']]; + $uplink_id = $row['uplink_id']; + unset($row['uplink_id']); + if ( $uplink_id !== NULL ) { + $childrens[$uplink_id][] = $row; + } else { + $roots[] = $row; + } +} +foreach ( $childrens as &$arr ) { + foreach ( $arr as &$node ) { + if ( array_key_exists('children', $node) && count($node['children']) === 0 ) { + unset($node['children']); + $node['size'] = 2000; + } + } +} +$orphans = array(); +foreach ( $roots as $k => &$node ) { + if ( array_key_exists('children', $node) && count($node['children']) === 0 ) { + unset($node['children']); + $node['size'] = 1000; + $orphans[$k] = &$node; + } +} + +// Remove orphans from $roots then rekey +foreach ( array_keys($orphans) as $k ) { + unset($roots[$k]); +} +$roots = array_values($roots); +$orphans = array_values($orphans); + +$world = array( + 'name' => 'world', + 'children' => array ( + array ( + 'name' => 'roots', + 'children' => &$roots + ), + array ( + 'name' => 'orphans', + 'children' => &$orphans + ), + ), +); +/* +echo "
\n";
+print_r($world);
+ */
+header('Content-type: application/json');
+echo json_encode($world, JSON_NUMERIC_CHECK | JSON_PRETTY_PRINT | JSON_PARTIAL_OUTPUT_ON_ERROR);
+
diff --git a/api/gen_conf.php b/api/gen_conf.php
new file mode 100644
index 0000000..ac910ce
--- /dev/null
+++ b/api/gen_conf.php
@@ -0,0 +1,72 @@
+
+ * Copyright 2016 Nicolas Goaziou 
+ * 
+ * This file is part of CHD Gestion.
+ * 
+ * CHD Gestion is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ * 
+ * CHD Gestion is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ * 
+ * You should have received a copy of the GNU General Public License
+ * along with CHD Gestion.  If not, see .
+**/
+
+include_once('inc/config.php');
+$mysqli = new mysqli($db_config['host'], $db_config['username'], $db_config['password'], $db_config['database']);
+unset($db_config);
+$mysqli->query("SET NAMES 'utf8'");
+
+
+$descriptorspec = array(
+	0 => array("pipe", "r"),  // stdin is a pipe that the child will read from
+	1 => array("pipe", "w"),  // stdout is a pipe that the child will write to
+	2 => array("pipe", "w")
+);
+$pipes=array();
+$proc = proc_open('ssh -p2222 genconf@chd-stg1 sudo genconf_prod', $descriptorspec, $pipes, '/tmp');
+if (!is_resource($proc)) die("Pb ouverture ssh");
+$fd=$pipes[0];
+
+fwrite($fd, "# This is auto-generated from database (see v_api_gen_conf VIEW)\n");
+
+$res = $mysqli->query("SELECT * FROM v_api_gen_conf;");
+
+$meta = $res->fetch_fields();
+if ( $meta !== FALSE ) {
+	fwrite($fd, '# ');
+	foreach ( $meta as $v) {
+		fwrite($fd, $v->name."\t");
+	}
+	fwrite($fd, "\n");
+}
+
+while ( $row = $res->fetch_assoc() ) {
+	foreach ( $row as $v ) {
+		fwrite($fd, ($v==NULL?"-":$v)."\t" );
+	}
+	fwrite($fd, "\n");
+}
+
+fclose($fd);
+
+$out_data = stream_get_contents($pipes[1]);
+fclose($pipes[1]);
+$err_data = stream_get_contents($pipes[2]);
+fclose($pipes[2]);
+$return_value = proc_close($proc);
+
+echo "
\n";
+if ( $return_value !== 0 || strlen($err_data) !== 0 ) {
+	echo $err_data;
+} else {
+	echo $out_data;
+}
+
diff --git a/api/gen_firm.php b/api/gen_firm.php
new file mode 100644
index 0000000..8c08030
--- /dev/null
+++ b/api/gen_firm.php
@@ -0,0 +1,62 @@
+
+ * Copyright 2016 Nicolas Goaziou 
+ * 
+ * This file is part of CHD Gestion.
+ * 
+ * CHD Gestion is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ * 
+ * CHD Gestion is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ * 
+ * You should have received a copy of the GNU General Public License
+ * along with CHD Gestion.  If not, see .
+**/
+
+include_once('inc/config.php');
+$mysqli = new mysqli($db_config['host'], $db_config['username'], $db_config['password'], $db_config['database']);
+unset($db_config);
+$mysqli->query("SET NAMES 'utf8'");
+
+$arg_ip4pub=(array_key_exists('ip4pub', $_GET) && preg_match('/^[0-9.]+$/', $_GET['ip4pub']))?$_GET['ip4pub']:NULL;
+
+if (!$arg_ip4pub) {
+	die("Wrong args");
+}
+$arg = $mysqli->real_escape_string($arg_ip4pub);
+$res = $mysqli->query("SELECT * FROM v_api_gen_firm WHERE ippublique_id='$arg'");
+//var_dump($query);
+
+if ( $res === FALSE ) {
+	die("Wrong query");
+}
+
+$row = $res->fetch_assoc();
+if ( ! is_array($row) ) {
+	die("No result");
+}
+$row2 = $res->fetch_assoc();
+if ( is_array($row2) ) {
+	die("Non unique result");
+}
+
+$fullname = (strlen($row['raison'])==0)?($row['prenom'] .  " " . $row['nom']):$row['raison'];
+
+$matches=array();
+$res = preg_match_all('/\b\p{L}/u', $fullname, $matches);
+if ( $res < 1 ) {
+	die("Pb re");
+}
+
+$row['initiales'] = implode($matches[0]);
+unset($row['prenom']);
+unset($row['nom']);
+unset($row['raison']);
+
+echo json_encode($row);
diff --git a/api/inc/config.default.php b/api/inc/config.default.php
new file mode 100644
index 0000000..84c42ed
--- /dev/null
+++ b/api/inc/config.default.php
@@ -0,0 +1,8 @@
+ 'localhost',
+            'username' => 'DATABASE_USER',
+            'password' => 'DATABASE_PASSWORD',
+			'database' => 'DATABASE_NAME',
+		);
diff --git a/api/mig_wan6ll.php b/api/mig_wan6ll.php
new file mode 100644
index 0000000..173f7fe
--- /dev/null
+++ b/api/mig_wan6ll.php
@@ -0,0 +1,53 @@
+
+ * Copyright 2016 Nicolas Goaziou 
+ * 
+ * This file is part of CHD Gestion.
+ * 
+ * CHD Gestion is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ * 
+ * CHD Gestion is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ * 
+ * You should have received a copy of the GNU General Public License
+ * along with CHD Gestion.  If not, see .
+**/
+
+include_once('inc/config.php');
+$mysqli = new mysqli($db_config['host'], $db_config['username'], $db_config['password'], $db_config['database']);
+unset($db_config);
+$mysqli->query("SET NAMES 'utf8'");
+
+$arg_ip6wanll=(array_key_exists('ip6wanll', $_GET) && preg_match('/^[a-f0-9:]+$/', $_GET['ip6wanll']))?$_GET['ip6wanll']:NULL;
+
+if (!$arg_ip6wanll) {
+	die("Wrong args");
+}
+$arg = $mysqli->real_escape_string($arg_ip6wanll);
+$res = $mysqli->query("SELECT * FROM ipmgmt WHERE ip6='$arg'");
+//var_dump($query);
+
+if ( $res === FALSE ) {
+	die("Wrong query");
+}
+
+$row = $res->fetch_assoc();
+if ( ! is_array($row) ) {
+	die("No result");
+}
+$row2 = $res->fetch_assoc();
+if ( is_array($row2) ) {
+	die("Non unique result");
+}
+
+$res = $mysqli->query("UPDATE ipmgmt SET ip6=NULL WHERE ip6='$arg' LIMIT 1");
+$row["updated"] = $mysqli->affected_rows;
+
+echo json_encode($row);
+
-- 
cgit v1.1