diff options
author | Ludovic Pouzenc <ludovic@pouzenc.fr> | 2016-03-12 15:40:43 +0100 |
---|---|---|
committer | Ludovic Pouzenc <ludovic@pouzenc.fr> | 2016-03-12 15:40:43 +0100 |
commit | 82c54972d7cbfd48d325dacc005471b2a8137134 (patch) | |
tree | 7a58575b7211e99bfddf398bc2f6807b7546d5c5 /api | |
parent | b2c7b3f2d325d8ad52eaa35c558c00088618381b (diff) | |
download | chd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.zip chd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.tar.gz chd_gestion-82c54972d7cbfd48d325dacc005471b2a8137134.tar.bz2 |
Initial import for API part.
Diffstat (limited to 'api')
-rw-r--r-- | api/data.json.php | 87 | ||||
-rw-r--r-- | api/gen_conf.php | 72 | ||||
-rw-r--r-- | api/gen_firm.php | 62 | ||||
-rw-r--r-- | api/inc/config.default.php | 8 | ||||
-rw-r--r-- | api/mig_wan6ll.php | 53 |
5 files changed, 282 insertions, 0 deletions
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); + |