summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLudovic Pouzenc <ludovic@pouzenc.fr>2016-03-12 15:40:43 +0100
committerLudovic Pouzenc <ludovic@pouzenc.fr>2016-03-12 15:40:43 +0100
commit82c54972d7cbfd48d325dacc005471b2a8137134 (patch)
tree7a58575b7211e99bfddf398bc2f6807b7546d5c5
parentb2c7b3f2d325d8ad52eaa35c558c00088618381b (diff)
downloadchd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.zip
chd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.tar.gz
chd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.tar.bz2
Initial import for API part.
-rw-r--r--.gitignore3
-rw-r--r--api/data.json.php87
-rw-r--r--api/gen_conf.php72
-rw-r--r--api/gen_firm.php62
-rw-r--r--api/inc/config.default.php8
-rw-r--r--api/mig_wan6ll.php53
6 files changed, 285 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..c10f5ca
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,3 @@
+api/d3
+api/test.php
+api/inc/config.php
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 @@
+<?php
+/**
+ * Copyright 2016 Ludovic Pouzenc <ludovic@pouzenc.fr>
+ * Copyright 2016 Nicolas Goaziou <mail@nicolasgoaziou.fr>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+**/
+
+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 "<pre>\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 @@
+<?php
+/**
+ * Copyright 2016 Ludovic Pouzenc <ludovic@pouzenc.fr>
+ * Copyright 2016 Nicolas Goaziou <mail@nicolasgoaziou.fr>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+**/
+
+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 "<pre>\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 @@
+<?php
+/**
+ * Copyright 2016 Ludovic Pouzenc <ludovic@pouzenc.fr>
+ * Copyright 2016 Nicolas Goaziou <mail@nicolasgoaziou.fr>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+**/
+
+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 @@
+<?php
+
+$db_config=array(
+ 'host' => '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 @@
+<?php
+/**
+ * Copyright 2016 Ludovic Pouzenc <ludovic@pouzenc.fr>
+ * Copyright 2016 Nicolas Goaziou <mail@nicolasgoaziou.fr>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+**/
+
+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);
+