ajout d'une interface pour la gestion des machines

darcs-hash:20061110134614-f46e9-a636e37c33caab306cfd87e565f2fad28c78596f.gz
This commit is contained in:
gdetrez 2006-11-10 14:46:14 +01:00
parent f4d5e3c798
commit 4e7c67e33b
14 changed files with 1124 additions and 406 deletions

View file

@ -71,7 +71,7 @@ from plugins.verifdroitsfilter import VerifDroitsFilter
class Intranet:
__ldap = None
def __init__(self):
from pages import monCompte, impression, factures, digicode
from pages import monCompte, impression, factures, digicode, mesmachines
self.__ldap = cherrypy.config.configMap["global"]["crans_ldap"]
# liste des modules disponibles
@ -81,8 +81,8 @@ class Intranet:
self.digicode = digicode.root()
# liste des modules en developpement
#if (cherrypy.config.configMap["global"]["server.environment"] == "development"):
if (cherrypy.config.configMap["global"]["server.environment"] == "development"):
self.mesMachines = mesmachines.root()
@ -92,13 +92,15 @@ class Intranet:
return {
'template':'accueil',
'values':{},
'stylesheets':['accueil.css'],
}
index.exposed= True
def info(self):
return {
'template':'info-diverses',
'values':{}
'values':{},
'stylesheets':['accueil.css'],
}
info.exposed = True

View file

@ -21,4 +21,4 @@ paypal.businessAdress = "gdetrez-buisness@crans.org"
paypal.useSandbox = True
[/static]
staticFilter.dir = "/usr/scripts/intranet/static/"
staticFilter.dir = "/home/gdetrez/crans.usr.scripts/intranet/static/"

237
intranet/pages/mesmachines.py Executable file
View file

@ -0,0 +1,237 @@
#! /usr/bin/env python
# -*- coding: iso-8859-15 -*-
import cherrypy, sys, os, datetime
from time import strftime, localtime, time
# libraries crans
sys.path.append('/usr/scripts/gestion/')
from config_mail import MailConfig
if (cherrypy.config.configMap["global"]["server.environment"] == "development"):
from ldap_crans_test import *
# print("monCompte : unsing test ldap : env=" + cherrypy.config.configMap["global"]["server.environment"])
else:
from ldap_crans import *
# print("monCompte : unsing prod ldap : env=" + cherrypy.config.configMap["global"]["server.environment"])
class root:
__ldap = None
def __init__(self):
self.__ldap = cherrypy.config.configMap["global"]["crans_ldap"]
def AJAXListeMachines(self):
adh = self.__ldap.search('uid=' + cherrypy.session['uid'])['adherent'][0]
machines = []
for une_machine in adh.machines():
machineInfos = {}
# nom, mac, mid, ip
machineInfos['nom'] = une_machine.nom()
machineInfos['nomCourt'] = une_machine.nom().split('.',1)[0]
machineInfos['mid'] = une_machine.id()
# type
if une_machine.objectClass == 'machineFixe':
machineInfos['type'] = 'fixe'
#machineInfos['type'] = 'Machine fixe'
else:
machineInfos['type'] = 'wifi'
#machineInfos['type'] = 'Machine wifi'
# clef ipsec
machines.append(machineInfos)
return {"machines":machines}
AJAXListeMachines.exposed = True
def AJAXMachineInfo(self, mid):
try:
machine = self.__ldap.search('mid=' + mid)['machine'][0]
if machine.proprietaire().mail() != cherrypy.session['uid']:
raise Exception
# zamok -> pour tester l'affichage des ports, des alias
#machine = self.__ldap.search('mid=896')['machine'][0]
machineInfos = {}
# nom, mac, mid, ip
machineInfos['nom'] = machine.nom()
machineInfos['nomCourt'] = machine.nom().split('.',1)[0]
machineInfos['mac'] = machine.mac()
machineInfos['mid'] = machine.id()
machineInfos['ip'] = machine.ip()
# type
if machine.objectClass == 'machineFixe':
machineInfos['type'] = 'fixe'
else:
machineInfos['type'] = 'wifi'
# clef ipsec
try:
machineInfos['ipsec'] = machine.ipsec()
except:
machineInfos['ipsec'] = ''
# alias
machineInfos['alias'] = machine.alias()
# blacklists
machineInfos['blacklist'] = []
for blacklist_type in machine.blacklist_all()[0].keys():
for (begin, end) in machine.blacklist_all()[0][blacklist_type]:
blacklist = {}
blacklist['begin'] = strftime('%d/%m/%Y %H:%M', localtime(int(begin)))
blacklist['end'] = strftime('%d/%m/%Y %H:%M', localtime(int(end)))
blacklist['type'] = blacklist_type
blacklist['actif'] = 1
machineInfos['blacklist'].append(blacklist)
for blacklist_type in machine.blacklist_all()[1].keys():
for (begin, end) in machine.blacklist_all()[1][blacklist_type]:
blacklist = {}
blacklist['begin'] = strftime('%d/%m/%Y %H:%M', localtime(int(begin)))
blacklist['end'] = strftime('%d/%m/%Y %H:%M', localtime(int(end)))
blacklist['type'] = blacklist_type
blacklist['actif'] = 0
machineInfos['blacklist'].append(blacklist)
# ports
machineInfos['ports'] = []
if machine.portTCPin() != []:
machineInfos['ports'].append(
{
'titre':'Ports TCP ouvert ext->machine',
'ports':machine.portTCPin()
}
)
if machine.portTCPout() != []:
machineInfos['ports'].append(
{
'titre':'Ports TCP ouvert machine->ext',
'ports':machine.portTCPout()
}
)
if machine.portUDPin() != []:
machineInfos['ports'].append(
{
'titre':'Ports UDP ouvert ext->machine',
'ports':machine.portUDPin()
}
)
if machine.portUDPout() != []:
machineInfos['ports'].append(
{
'titre':'Ports TCP ouvert machine->ext',
'ports':machine.portUDPout()
}
)
return machineInfos
except Exception, e:
return {"erreur":str(e)}
AJAXMachineInfo.exposed = True
##########################
# affichage
##########################
#
# methode qui affiche la template
#
def index(self):
return {
'template' :'machines',
'values' :{},
'stylesheets' :['machines.css'],
'scripts':['machines.js'],
}
index.exposed = True
###########################################################################
# methodes pour changer
# des valeurs
###########################################################################
#
##########################
# machine:nom
##########################
def AJAXChangerNom(self, mid, nouveauNom):
try:
adh = self.__ldap.search('uid=' + cherrypy.session['uid'])['adherent'][0]
mach = self.__ldap.search('mid=' + mid, 'w')['machine'][0]
# tester si c'est bien la machine de l'adherent
if mach.proprietaire().compte() != cherrypy.session['uid']:
del adh, mach
raise Exception(u"L'uid de l'adherent ne correspond mas au proprietaire de la machine.")
mach.nom(nouveauNom)
mach.save()
del mach
except ValueError, e:
raise e
#return {'error':str(e)}
cherrypy.log("Changer nom machine : %s" % nouveauNom, "MESMACHINES")
return {'message':u"Modification réussie", 'mid':mid}
AJAXChangerNom.exposed = True
##########################
# machine:mac
##########################
def AJAXchangerMAC(self, mid, nouvelleMAC):
try:
adh = self.__ldap.search('uid=' + cherrypy.session['uid'])['adherent'][0]
mach = self.__ldap.search('mid=' + mid, 'w')['machine'][0]
# tester si c'est bien la machine de l'adherent
if mach.proprietaire().compte() != cherrypy.session['uid']:
del adh, mach
raise Exception(u"L'uid de l'adherent ne correspond mas au proprietaire de la machine.")
mach.mac(nouvelleMAC)
mach.save()
del mach
except ValueError, e:
return {'error':e.args[0]}
cherrypy.log("Change mac machine", "MESMACHINES")
return {'message':u"Modification réussie", 'mid':mid}
AJAXchangerMAC.exposed = True
##########################
# machine:suppression
##########################
def AJAXSupprimerMachine(self, mid):
try:
adh = self.__ldap.search('uid=' + cherrypy.session['uid'])['adherent'][0]
mach = self.__ldap.search('mid=' + mid, 'w')['machine'][0]
# tester si c'est bien la machine de l'adherent
if mach.proprietaire().compte() != cherrypy.session['uid']:
del adh, mach
raise Exception(u"L'uid de l'adherent ne correspond mas au proprietaire de la machine.")
mach.delete()
except ValueError, e:
return {'error':e.args[0]}
cherrypy.log("Machine supprimee", "MACHINES")
return {'message':u"Machine supprimée"}
AJAXSupprimerMachine.exposed = True
##########################
# machine:creation
##########################
def AJAXCreerMachine(self, nomNouvelleMachine, MACNouvelleMachine, typeNouvelleMachine):
adh = self.__ldap.search('uid=' + cherrypy.session['uid'])['adherent'][0]
if typeNouvelleMachine=='wifi' and adh.droits() == [] and adh.machines_fixes() != []:
return {'error':'Vous avez deja une machine fixe. Vous ne pouvez ajouter que des machines WiFi.'}
try:
if typeNouvelleMachine=='wifi':
m = MachineWifi(adh)
elif typeNouvelleMachine=='fixe':
m = MachineFixe(adh)
else:
raise Exception, "type de machine inconnu : %s " % typeNouvelleMachine
m.nom(nomNouvelleMachine)
m.mac(MACNouvelleMachine)
m.ip("<automatique>")
message = m.save()
del m
except ValueError, e:
del m
return {'error':e.args[0].replace("\n","\\n")}
cherrypy.log("Nouvelle machine %s" % nomNouvelleMachine, "MACHINES")
return {'message':u"Machine enregistrée avec succès"}
AJAXCreerMachine.exposed = True

View file

@ -0,0 +1,74 @@
/*************************************************************
..
.... ............ ........
. ....... . .... ..
. ... .. .. .. .. ..... . ..
.. .. ....@@@. .. . ........ .
.. . .. ..@.@@..@@. .@@@@@@@ @@@@@@. ....
.@@@@. .@@@@. .@@@@..@@.@@..@@@..@@@..@@@@.... ....
@@@@... .@@@.. @@ @@ .@..@@..@@...@@@. .@@@@@. ..
.@@@.. . @@@. @@.@@..@@.@@..@@@ @@ .@@@@@@.. .....
...@@@.... @@@ .@@.......... ........ ..... ..
. ..@@@@.. . .@@@@. .. ....... . .............
. .. .... .. .. . ... ....
. . .... ............. .. ...
.. .. ... ........ ... ...
................................
==============================================================
mainInterface.css - Intranet Style
Mise en page de l'accueil
Copyright (c) 2006 by www.crans.org
**************************************************************/
div.framed_gray {
border:5px solid #e2e2e2; /* #acc0ff */
background-color:#f2f2f2;
padding:10px;
}
div.framed_gray fieldset {
border-width:2px;
border-style:solid none none none;
border-color:#a2a2a2;
padding:10px;
margin:10px 10px;
}
div.framed_gray fieldset legend {
color:#a2a2a2;
}
div.framed_gray fieldset ul {
list-style-type:none;
margin:0;
padding:0;
}
div.framed_gray fieldset ul li {
float:left;
height:70px;
width:100px;
margin:5px;
display:block;
text-align:center;
}
div.framed_gray fieldset ul li span {
margin-bottom:0;
display:block;
}
div.framed_gray fieldset ul a {
color:black;
text-decoration:none;
}
div.framed_gray fieldset ul li img {
margin:2px auto;
width:32px;
height:32px;
}

View file

@ -0,0 +1,160 @@
/*************************************************************
..
.... ............ ........
. ....... . .... ..
. ... .. .. .. .. ..... . ..
.. .. ....@@@. .. . ........ .
.. . .. ..@.@@..@@. .@@@@@@@ @@@@@@. ....
.@@@@. .@@@@. .@@@@..@@.@@..@@@..@@@..@@@@.... ....
@@@@... .@@@.. @@ @@ .@..@@..@@...@@@. .@@@@@. ..
.@@@.. . @@@. @@.@@..@@.@@..@@@ @@ .@@@@@@.. .....
...@@@.... @@@ .@@.......... ........ ..... ..
. ..@@@@.. . .@@@@. .. ....... . .............
. .. .... .. .. . ... ....
. . .... ............. .. ...
.. .. ... ........ ... ...
................................
==============================================================
macines.css - Intranet Style
Copyright (c) 2006 by www.crans.org
**************************************************************/
#globalDiv {
padding-left : 25%;
margin:0;
position:relative;
}
h2 {
margin: 0 5px .5em 5px;padding:5px;
}
div.alias {
color:gray;
margin:0;
padding:0 0 0 60px;
display:block;
font-weight:normal;
font-size:0.6em;
}
table.blacklist_table,
table.ports_table {
border-top: thin black solid;
border-left: thin black solid;
}
table.blacklist_table td,
table.blacklist_table th,
table.ports_table td,
table.ports_table th {
border-right: thin black solid;
border-bottom: thin black solid;
padding: 3px;
}
.actif {
color:red;
}
.inactif {
}
#gestion_machines_main_frame {
padding:5px;
}
dl.basicInfos dt {
float:left;
font-weight:bold;
clear:left;
}
dl.basicInfos dd {
float:left;
margin:0 1em;
}
ul#listeMachines {
list-style-type:none;
margin:0;
padding:0;
}
ul#listeMachines li {
float:left;
height:70px;
width:100px;
margin:5px;
display:block;
text-align:center;
}
ul#listeMachines li span {
margin-bottom:0;
display:block;
}
ul#listeMachines li a {
display:block;
color:black;
text-decoration:none;
}
ul#listeMachines li a:hover {
background:#bbbbff;
}
ul#listeMachines li a:active {
background:#8888ff;
}
ul#listeMachines li img {
margin:2px auto;
width:32px;
height:32px;
}
#menu_actions {
background:#eeeeff;
padding:.3em;
max-width:20%;
float:left;
position:absolute;
top:1em;
left:0;
border: thin black solid;
}
#menu_actions ul {
list-style-type:none;
padding:0;
margin:.5em;
}
#menu_actions ul li a {
text-decoration:none;
}
#menu_actions ul li a:hover {
text-decoration:underline;
}
#menu_actions h1 {
font-size:1em;
margin:0;
text-align:center;
border-bottom: thin black solid;
}
// on change la couleur des messages
.message {
background-color:#000080;
color:white;
}
label {
width:175px;
display:block;
float:left;
}

View file

@ -28,8 +28,8 @@ Copyright (c) 2006 by www.crans.org
/* STYLE GLOBAL
- body
- liens
- titres
- images
- messages
- aides
- ...
*/
@ -60,8 +60,6 @@ div#pageContent {
}
/**************************************************************************/
/* LE HAUT DES PAGES
- le logo a gauche
- petit menu a droite
@ -126,6 +124,55 @@ ul#main_topContentMenu hr, div#topMenu h1 {
margin:5px;
}
/**************************************************************************
* Messages
* (les messages affichés sur les pages pour indiquer le bon déroulement
* ou non d'une action)
**************************************************************************/
#_crans_main_message_place_holder {
height:0;
overflow:visible;
position:absolute;
top:100px;
width:100%;
}
.messageText {
padding:2px 10px;
display:block;
}
.message {
padding: 0;
background: #fad163;
width: 300px;
text-align: center;
margin : 1px auto 10px auto;
}
.errorMessage {
display:block;
background:white;
border:2px #cc0000 solid;
padding:5px;
text-align:center;
min-width:230px;
max-width:430px;
font-weight:bold;
margin : 1px auto 10px auto;
}
#_crans_main_message_chargement {
background:#cc0000;
position:fixed;
top:1px;
right:1px;
z-index:1000;
display:none;
padding:2px 3px;
color:white;
}
/**************************************************************************
* DIVERS
**************************************************************************/
@ -142,56 +189,8 @@ ul#main_topContentMenu hr, div#topMenu h1 {
display:none;
}
div.visualClear {clear:both;}
div.framed_gray {
border:5px solid #e2e2e2; /* #acc0ff */
background-color:#f2f2f2;
padding:10px;
}
div.framed_gray fieldset {
border-width:2px;
border-style:solid none none none;
border-color:#a2a2a2;
padding:10px;
margin:10px 10px;
}
div.framed_gray fieldset legend {
color:#a2a2a2;
}
div.framed_gray fieldset ul {
list-style-type:none;
margin:0;
padding:0;
}
div.framed_gray fieldset ul li {
float:left;
height:70px;
width:100px;
margin:5px;
display:block;
text-align:center;
}
div.framed_gray fieldset ul li span {
margin-bottom:0;
display:block;
}
div.framed_gray fieldset ul a {
color:black;
text-decoration:none;
}
div.framed_gray fieldset ul li img {
margin:2px auto;
width:32px;
height:32px;
}
.aide {
font-size:0.8em;

View file

@ -1,192 +1,80 @@
function askForName(oldName) {
var c = '';
while ( c == '')
c = prompt("Votre nom :",oldName);
if (c == null)
return false;
else
window.location.href= 'changeNomAdherent?nouveauNom=' + c;
}
/* ************************************************************
* Crans
************************************************************
* Crans.messages : afficher des messages sur les pages
* Crans.loading : afficher l'indicateur de chargement
*/
Crans = {};
/*****************************
Crans.Messages
*****************************/
Crans.messages = {}
Crans.messages.initialized = false;
function askForSurname(oldSurname) {
var c = '';
while ( c == '')
c = prompt("Votre prénom :",oldSurname);
if (c == null)
return false;
else
window.location.href= 'changePrenomAdherent?nouveauPrenom=' + c;
}
function askForTel(oldTel) {
var c = '';
while ( c == '')
c = prompt("Votre numéro de téléphone :",oldTel);
if (c == null)
return false;
else
window.location.href= 'changeTelAdherent?nouveauTel=' + c;
}
function askForMachineMac(oldMac, mid) {
var c = '';
while ( c == '')
c = prompt("Adresse MAC de la machine :",oldMac);
if (c == null)
return false;
var e = loadJSONDoc('changeMACMachine?nouvelleMAC=' + c + '&mid=' + mid);
e.addCallback(machineModifHandler);
e.addErrback(ajaxErrorHandler);
loading(true);
return false;
}
function askForMachineName(oldName, mid) {
var c = '';
while ( c == '')
c = prompt("Nom de la machine :",oldName);
if (c == null)
return false;
var e = loadJSONDoc("changeNomMachine?nouveauNom=" + c + "&mid=" + mid);
e.addCallback(machineModifHandler);
e.addErrback(ajaxErrorHandler);
loading(true);
return false;
}
function askForDeleteMachine(mid, nom) {
if (confirm("Supprimer la machine ?")) {
var e = loadJSONDoc('supprimeMachine?mid=' + mid);
e.addCallback(machineModifHandler);
e.addErrback(ajaxErrorHandler);
loading(true);
return false;
}
return false;
}
function newAlias() {
var c = '';
while ( c == '')
c = prompt("Nouvel alias :");
if (c == null)
return false;
else
window.location.href= 'newAlias?alias=' + c + "#mailTab";
}
function newMachineNode(name, shortName, mac, ip, mid, type, ipsec) {
machineName = H3({},shortName);
var propertiesList = createDOM("DL",{'class':'machineInfos'});
valuesList = [
{'label':'Type : ', 'value':type},
{'label':'Mac : ', 'value':mac},
{'label':'IP : ', 'value':ip},
{'label':'ipsec : ', 'value':ipsec},
] ;
for (var i=0; i<valuesList.length; i++) {
var item = valuesList[i];
if (item.value) {
propertiesList.appendChild(createDOM("DT",item.label));
propertiesList.appendChild(createDOM("DD",item.value));
Crans.messages.init = function()
{
if (!Crans.messages.initialized)
{
updateNodeAttributes(document.body, {'onclick':'Crans.messages.setMessage();'});
appendChildNodes(document.body, DIV({'id':'_crans_main_message_place_holder'}));
Crans.messages.initialized = true;
}
}
var actions = SPAN({'class':'actions'},[
A({'href':'#','onclick':"return askForMachineName('"+shortName+"','"+mid+"');"},'Renommer'),
A({'href':'#','onclick':"return askForMachineMac('"+mac+"','"+mid+"');"},'Changer de MAC'),
A({'href':'#','onclick':"return askForDeleteMachine('"+mid+"');"},'Supprimer'),
]);
return LI({},[
machineName,
propertiesList,
DIV({'class':'clear'},''),
actions,
DIV({'class':'clear'},''),
]);
}
function newMachineLiNodeFromDict(adict) {
return LI({},newMachineNode(adict.nom, adict.nomCourt, adict.mac, adict.ip, adict.mid, adict.type, adict.ipsec));
}
function renderMachineList(result) {
replaceChildNodes('machineList',map(newMachineLiNodeFromDict,result.machines));
}
function loadMachineList() {
var e = loadJSONDoc('listeMachines');
e.addCallback(renderMachineList);
e.addErrback(ajaxErrorHandler);
}
function ajaxErrorHandler(d) {
loading(false);
alert(d)
logError("AJAX Error");
logerror(d);
window.location.href= "";
}
function machineModifHandler(result) {
loading(false);
if (result.message){
setMessage(result.message);
addMachineForm.clear();
logDebug("AJAX Succed");
}
if (result.error){
alert(result.error);
logError("AJAX error");
}
loadMachineList();
}
addMachineForm = {}
addMachineForm.setFieldValue = function(fieldName, newValue) {
document.addMachineForm[fieldName] = newValue;
}
addMachineForm.clear = function() {
document.addMachineForm.reset();
logDebug("addMachineForm cleared");
}
function creerMachine(nom, mac, estMachineWifi) {
var e = loadJSONDoc("creerMachine?nomNouvelleMachine=" + nom + "&MACNouvelleMachine=" + mac + "&estMachineWifi="+estMachineWifi);
e.addCallback(machineModifHandler);
e.addErrback(ajaxErrorHandler);
loading(true);
return false;
}
function setMessage(m, messageClass) {
Crans.messages.setMessage = function(m, messageClass)
{
if (!Crans.messages.initialized)
Crans.messages.init();
if (m == null) {
var messagePlace = document.getElementById("messagePlaceHolder");
replaceChildNodes(messagePlace,'');
return
}
var messageBox = '';
} else {
if (messageClass==null)
messageClass='message'
messageClass='message';
var textHolder = SPAN({'class':'messageText'},m);
var messageBox = DIV({'class':messageClass},textHolder);
var messagePlace = document.getElementById("messagePlaceHolder");
var messagePlace = document.getElementById("_crans_main_message_place_holder");
}
try
{
var messagePlace = document.getElementById("_crans_main_message_place_holder");
replaceChildNodes(messagePlace,messageBox);
roundElement(messageBox);
try {roundElement(messageBox);} catch (error) {}
}
catch (error)
{
logError("élement _crans_main_message_place_holder introuvable")
return
}
}
function loading(bool) {
var loadingEl = document.getElementById("loadings");
/*****************************
Crans.loading
*****************************/
Crans.loading = {}
Crans.loading.initialized = false;
Crans.loading.init = function(){
try {
if (!Crans.loading.initialized) {
appendChildNodes(document.body, DIV({'id':'_crans_main_message_chargement'}, "Chargement..."));
Crans.loading.initialized = true;
}
} catch (error) {
logError(error.description);
}
}
Crans.loading.display = function(bool) {
if (!Crans.loading.initialized)
Crans.loading.init();
var loadingEl = document.getElementById("_crans_main_message_chargement");
if (loadingEl) {
if (bool) {
loadingEl.style.display='block';
appear(loadingEl);
} else {
loadingEl.style.display='none';
fade(loadingEl);
}
}
return false;

View file

@ -14,7 +14,7 @@ Digicode = {};
Digicode.init = function()
{
// afficher le tableau codelist
appendChildNodes("globalDiv", Digicode.codelist.create())
appendChildNodes("globalDiv", Digicode.codelist.create());
// recuperer la liste des codes
this.codelist.load();
// afficher le formulaire de creation de code
@ -29,11 +29,13 @@ Digicode.makeCode = {}
Digicode.makeCode.displayForm = function()
{
var myForm = FORM({'id':'createCodeForm', 'name':'createCodeForm','onsubmit':"Digicode.makeCode.createCode(document.createCodeForm.newCode.value); return false;", 'style':'display: none;'},
BUTTON({"type":"button","onclick":"Digicode.makeCode.createCode(document.createCodeForm.newCode.value)", "style":"float:right;"},"Créer code"),
INPUT({"name":"newCode", "size":"6", "maxlength":"6", "style":"float:right;"}),
BUTTON({"type":"button","onclick":"Digicode.makeCode.createCode()", "style":"float:right;clear:both;"},"Code aléatoire")
LABEL({'for':'newCodeLogin', "style":"clear:left;"}, "Login adhérent :"),
INPUT({"name":"newCodeLogin", "size":"10", "maxlength":"20", "style":"float:rightk;clear:both;"}),
LABEL({'for':'newCode', "style":"clear:left;"}, "Code :"),
INPUT({"name":"newCode", "size":"6", "maxlength":"6", "style":"float:rightk;clear:both;"}),
BUTTON({"type":"button","onclick":"Digicode.makeCode.createCode(document.createCodeForm.newCodeLogin.value, document.createCodeForm.newCode.value)", "style":"float:right;"},"Créer code"),
BUTTON({"type":"button","onclick":"Digicode.makeCode.createCode(document.createCodeForm.newCodeLogin.value)", "style":"float:right;"},"Code aléatoire")
);
replaceChildNodes("addCodeBox", H1({},"Nouveau code"), myForm );
appear(myForm);
@ -51,16 +53,16 @@ Digicode.makeCode.restoreForm = function()
}
Digicode.makeCode.createCode = function(code)
Digicode.makeCode.createCode = function(login, code)
{
var image = createDOM("IMG",{'style':'margin-right:2px;float:right;','src':'/static/images/indicator.gif'});
appendChildNodes("addCodeBox", DIV({'id':"loading",'style':'display:none;max-height:1em;float:left;'},image,"Loading"))
appendChildNodes("addCodeBox", DIV({'id':"loading",'style':'display:none;max-height:1em;float:left;'},image,"Loading"));
removeElement("createCodeForm");
appear("loading");
if (code)
Digicode.AJAX.call("createCode?code="+code, this.handleNewCode);
Digicode.AJAX.call("createCode?code="+code + "&adherent=" + login, this.handleNewCode);
else
Digicode.AJAX.call("createCode", this.handleNewCode);
Digicode.AJAX.call("createCode?adherent=" + login, this.handleNewCode);
}
Digicode.makeCode.handleNewCode = function(res)
@ -127,7 +129,7 @@ Digicode.codelist.newCodeTrNodeFromDict = function (aDict, style)
Digicode.codelist.addCode = function (aDict)
{
var newLine = this.newCodeTrNodeFromDict(aDict)
var newLine = this.newCodeTrNodeFromDict(aDict);
appendChildNodes("codeList", newLine);
pulsate(newLine);
}
@ -139,7 +141,7 @@ Digicode.codelist.addCode = function (aDict)
Digicode.AJAX = {}
Digicode.AJAX.call = function(page, callBack) {
logDebug("calling AJAX : " + page)
logDebug("calling AJAX : " + page);
var e = loadJSONDoc(page);
e.addCallback(callBack);
e.addErrback(this.errorHandler);
@ -150,12 +152,4 @@ Digicode.AJAX.errorHandler = function(d) {
logError("AJAX Error: " + d);
}
setInterval(Digicode.codelist.load, 30000);

View file

@ -0,0 +1,348 @@
/* ************************************************************
* Machines
************************************************************
* Machines.init : initialisation de la page
* Machines.listeMachines : liste des machines
* Machines.infoPane : information sur une machine
* Machines.actions : modifications, ajout...
* Machines.AJAX : ajax
*/
Machines = {};
/*****************************
Machines.init
*****************************/
Machines.init = function()
{
// afficher le tableau codelist
appendChildNodes("globalDiv", Machines.createFrames());
appendChildNodes("globalDiv", Machines.actions.makeMenu());
// recuperer la liste des codes
this.listeMachines.load();
}
Machines.createFrames = function()
{
var main = DIV({"id":"gestion_machines_main_frame"});
var inside = DIV({"id":"__insideDivId", "style":"background:white;margin:5px;padding:5px;"},main);
var outside = DIV({"id":"__outsideDivId","style":"background:#000080;z-index:500;padding:0;"}, inside );
roundElement(outside);
roundElement(inside);
log("Creation du cadre");
return outside
}
/*****************************
Machines.listeMachines
*****************************/
Machines.listeMachines = {};
Machines.listeMachines.load = function()
{
Machines.AJAX.call("AJAXListeMachines", Machines.listeMachines.display);
log("Chargement liste...");
Machines.currentMachine = '';
}
Machines.listeMachines.display = function(result)
{
Crans.loading.display(false);
log("display liste");
replaceChildNodes( "gestion_machines_main_frame",
H2({}, "Mes machines"),
UL({"id":"listeMachines"}),
DIV( {"style":"clear:both;"} )
);
if (result.machines) {
replaceChildNodes('listeMachines',map(Machines.listeMachines.newMachineNodeFromDict ,result.machines));
Machines.actions.updateMenu(Machines.actions.actionForMachineList);
aMachines.currentMid = '';
}
else if (result.erreur)
logError("Erreur distante : " + result.erreur);
else
logError("Probleme bizarre...");
}
Machines.listeMachines.newMachineNodeFromDict = function (aDict, style)
{
var nom = aDict.nomCourt;
var mid = aDict.mid;
var image = "machines_icon_" + aDict.type + ".png";
//log("create an item : " + nom);
if (style) {
var anIcon = LI({'id':'machine_' + mid,"style":style});
} else
var anIcon = LI( {'id':'machine_' + mid} );
appendChildNodes(anIcon, A({"href":"#", "onclick":"Machines.infoPane.loadInfo('"+mid+"');return false;"}, IMG({"src":"/static/images/" + image}), SPAN({},nom) ) );
return anIcon;
}
/*****************************
Machines.infoPane
*****************************/
Machines.infoPane = {};
Machines.infoPane.loadInfo = function(mid)
{
if (!mid)
if (!Machines.currentMachine) {
logError("Machines.infoPane.loadInfo : pas de mid, pas de machine courrante...");
return
} else
mid = Machines.currentMachine.mid;
log("load info : " + mid);
Machines.AJAX.call("AJAXMachineInfo?mid=" + mid, Machines.infoPane.display);
try {
pulsate('machine_' + mid);
} catch (error) {}
}
Machines.infoPane.display = function(result)
{
Crans.loading.display(false);
if (result.nom) {
log("displaying info : " + result.mid);
// building pane
var machinePane = DIV({"id":"machine_pane"});
// lien pour retourner a la liste des machines
var back_link = A({"href":"#", "onclick":"Machines.listeMachines.load(); return false;"},"Retour");
appendChildNodes( machinePane, back_link );
// titre (nom de machine + alias)
var title = H2({}, IMG({"src":"/static/images/machines_icon_" + result.type + ".png"}), " ", result.nom);
var alias = DIV({"class":"alias"},
map(function(a_name) { return SPAN({}, a_name + " ")}, result.alias));
appendChildNodes( title, alias );
appendChildNodes( machinePane, title );
// infos de base (type, mac, ip, ipsec...)
var basicInfos = createDOM("DL", {"class":"basicInfos"});
appendChildNodes(basicInfos, createDOM("DT", "type:" ), createDOM("DD",{},"Machine " + result.type ) );
appendChildNodes(basicInfos, createDOM("DT", "mac: " ), createDOM("DD",{},result.mac ) );
appendChildNodes(basicInfos, createDOM("DT", "ip: " ), createDOM("DD",{},result.ip ) );
if (result.ipsec)
appendChildNodes(basicInfos, createDOM("DT", "Clef ipSec:" ), createDOM("DD",{},result.ipsec ) );
appendChildNodes( machinePane, basicInfos );
appendChildNodes( machinePane, DIV( {"style":"clear:both;"} ) );
// blacklist
if (result.blacklist)
if (result.blacklist.length) {
var subtitle = H3({}, "Blacklist");
appendChildNodes( machinePane, subtitle );
var blacklist_table = TABLE({"class":"blacklist_table", "cellspacing":"0"},
THEAD({},
TH({}, "Cause"),
TH({}, "Debut"),
TH({}, "Fin")
)
);
map(function(a_blacklist_dict) {
var style = "inactif";
if (a_blacklist_dict.actif)
style = "actif";
var line = TR({"class":style},
TD({}, a_blacklist_dict.type),
TD({}, a_blacklist_dict.begin),
TD({}, a_blacklist_dict.end)
);
appendChildNodes(blacklist_table, line);
}, result.blacklist );
appendChildNodes( machinePane, blacklist_table );
}
// liste des ports ouverts
if (result.ports)
if (result.ports.length) {
var subtitle = H3({}, "Ports ouverts");
appendChildNodes( machinePane, subtitle );
var port_table = TABLE({"class":"ports_table", "cellspacing":"0"});
map(function(a_port_dict) {
var line = TR({},
TH({}, a_port_dict.titre),
map(function(a_port) {return TD({}, a_port);}, a_port_dict.ports)
);
appendChildNodes(port_table, line);
}, result.ports );
appendChildNodes( machinePane, port_table );
}
// attaching pane to document
replaceChildNodes( "gestion_machines_main_frame", machinePane);
// updationg actions
Machines.currentMachine = result;
Machines.actions.updateMenu(Machines.actions.actionsForInfoPane);
} else if (result.erreur) {
logError("Erreur distante : " + result.erreur);
} else
logError("Probleme bizarr...");
}
/*****************************
Machines.actions
*****************************/
Machines.actions = {}
Machines.actions.disponibles =
{
'Ajouter machine fixe':'Machines.actions.formulaire.nouvelleMachine(\'fixe\');',
'Ajouter machine wifi':'Machines.actions.formulaire.nouvelleMachine(\'wifi\');',
'Modifier Mac':'Machines.actions.formulaire.modifierMac(Machines.currentMid);',
'Renommer':'Machines.actions.formulaire.renommer(Machines.currentMid);',
'Supprimer':'Machines.actions.formulaire.supprimer(Machines.currentMid);',
'Demander l\'ouverture d\'un port':'Machines.actions.formulaire.ouverturePort(Machines.currentMid);'
}
Machines.actions.actionForMachineList = ['Ajouter machine fixe', 'Ajouter machine wifi'];
Machines.actions.actionsForInfoPane = ['Modifier Mac', 'Renommer', 'Supprimer', 'Demander l\'ouverture d\'un port'];
Machines.actions.makeMenu = function(actionListe)
{
log("building action menu");
var liste = UL({"id":"liste_actions"});
//this.updateMenu(actionListe, liste)
return DIV( {"id":"menu_actions"},
H1( {}, "ACTIONS"),
liste
);
}
Machines.actions.updateMenu = function(actionListe, liste_actionsNode)
{
if (!liste_actionsNode)
liste_actionsNode = "liste_actions";
replaceChildNodes(liste_actionsNode);
map(
function(actionName) {
appendChildNodes(liste_actionsNode, LI({}, Machines.actions.makeActionLink(actionName)));
}
, actionListe);
}
Machines.actions.makeActionLink = function(actionName)
{
if (this.disponibles[actionName])
{
return A({"href":"#", "onclick":this.disponibles[actionName] + "return false;"}, actionName);
} else
logError("action inconnue " + actionName);
return A({}, "???");
}
Machines.actions.callback = function(result) {
Crans.loading.display(false);
if (result.message){
log(result.message);
Crans.messages.setMessage(result.message);
if (result.mid)
Machines.infoPane.loadInfo(result.mid);
else
Machines.listeMachines.load();
}
if (result.error){
alert(result.error);
logError("AJAX error");
}
}
// actions : affichage des formulaires
Machines.actions.formulaire = {}
Machines.actions.formulaire.modifierMac = function()
{
if (!Machines.currentMachine)
logError("pas de machine courrante");
else {
var c = '';
while ( c == '')
c = prompt("Adresse MAC de la machine :",Machines.currentMachine.mac);
if (c == null)
return false;
// AJAX stuff
Machines.AJAX.call('AJAXchangerMAC?nouvelleMAC=' + c + '&mid=' + Machines.currentMachine.mid,
Machines.actions.callback);
}
return false;
}
Machines.actions.formulaire.renommer = function() {
if (!Machines.currentMachine)
logError("pas de machine courrante");
else {
var c = '';
while ( c == '')
c = prompt("Nom de la machine :",Machines.currentMachine.nomCourt);
if (c == null)
return false;
// AJAX stuff
Machines.AJAX.call('AJAXChangerNom?nouveauNom=' + c + '&mid=' + Machines.currentMachine.mid,
Machines.actions.callback);
}
return false;
}
Machines.actions.formulaire.supprimer = function() {
if (!Machines.currentMachine)
logError("pas de machine courrante");
else {
if (confirm("Supprimer la machine " + Machines.currentMachine.nomCourt +" ?")) {
// AJAX stuff
Machines.AJAX.call('AJAXSupprimerMachine?mid=' + Machines.currentMachine.mid,
Machines.actions.callback);
}
}
return false;
}
Machines.actions.formulaire.nouvelleMachine = function(type) {
replaceChildNodes( "gestion_machines_main_frame",
A({"href":"#", "onclick":"Machines.listeMachines.load(); return false;"},"Retour"),
H2({}, "Nouvelle machine"),
FORM({"style":"clear:both;", 'onsubmit':'Machines.actions.creerMachine(this.typeField.value, this.nom.value, this.mac.value);return false;'},
createDOM('label', {'for':'add_machine_nom'}, "Nom de la machine : "),
INPUT({"name":"nom"}),
BR(),
createDOM('label', {'for':'add_machine_mac'}, "Adresse MAC : "),
INPUT({"name":"mac"}),
BR(),
createDOM('label', {'for':'add_machine_type'}, "Type de machine : "),
SPAN({'id':'add_machine_type'}, type),
INPUT({"name":"typeField", 'type':'hidden', 'value':type}),
BR(),
BUTTON({"class":"liens", 'type':'submit'}, 'Ajouter')
)
);
return false;
}
Machines.actions.creerMachine = function(type, nom, mac) {
Machines.AJAX.call('AJAXCreerMachine?nomNouvelleMachine=' + nom
+ '&MACNouvelleMachine=' + mac
+ '&typeNouvelleMachine=' + type,
Machines.actions.callback);
}
/*****************************
Machines.AJAX
*****************************/
Machines.AJAX = {}
Machines.AJAX.call = function(page, callBack) {
logDebug("calling AJAX : " + page);
var e = loadJSONDoc(page);
e.addCallback(callBack);
e.addErrback(this.errorHandler);
Crans.loading.display(true);
}
Machines.AJAX.errorHandler = function(d) {
//Machines.AJAX..modifPrix("Erreur", false);
logError("AJAX Error: " + d);
Crans.loading.display(false);
}

View file

@ -0,0 +1,41 @@
function askForName(oldName) {
var c = '';
while ( c == '')
c = prompt("Votre nom :",oldName);
if (c == null)
return false;
else
window.location.href= 'changeNomAdherent?nouveauNom=' + c;
}
function askForSurname(oldSurname) {
var c = '';
while ( c == '')
c = prompt("Votre prénom :",oldSurname);
if (c == null)
return false;
else
window.location.href= 'changePrenomAdherent?nouveauPrenom=' + c;
}
function askForTel(oldTel) {
var c = '';
while ( c == '')
c = prompt("Votre numéro de téléphone :",oldTel);
if (c == null)
return false;
else
window.location.href= 'changeTelAdherent?nouveauTel=' + c;
}
function newAlias() {
var c = '';
while ( c == '')
c = prompt("Nouvel alias :");
if (c == null)
return false;
else
window.location.href= 'newAlias?alias=' + c + "#mailTab";
}

View file

@ -2,7 +2,8 @@ Popup = {};
Popup.popupNode = null;
Popup.visible = false;
Popup.display = function() {
Popup.display = function()
{
if (this.popupNode == null) {
logError("Popup not created, cannot be displayed");
return false;

View file

@ -9,6 +9,10 @@ $sys.path.append(cherrypy.config.get('rootDir'))
<img src="/static/images/icon_monCompte.png" alt="icon" />
<span>Mon Compte</span>
</a></li>
<li><a href="/mesMachines">
<img src="/static/images/machines_icon_fixe.png" alt="icon" />
<span>Mes Machines</span>
</a></li>
<li><a href="/impression">
<img src="/static/images/icon_impression.png" alt="icon" />
<span>Impression</span>

View file

@ -0,0 +1,13 @@
<div id="messagePlaceHolder"></div>
<h1>Gestion de mes machines</h1>
<div id="globalDiv">
</div>
<script type="text/javascript">
<!--
Machines.init();
//-->
</script>
<noscript>
Cette page utilise javascript. Elle n'est pas support&eacute;e par votre navigateur.
</noscript>

View file

@ -1,24 +1,24 @@
<div id="messagePlaceHolder"></div>
#if $message != ''
<script type="text/javascript">setMessage('$message.replace("\'","\\\'")')</script>
<script type="text/javascript">
<!--
Crans.messages.setMessage('$message.replace("\'","\\\'")')
//-->
</script>
#end if
#if $error != ''
<script type="text/javascript">setMessage('$error.replace("\'","\\\'")', 'errorMessage')</script>
<script type="text/javascript">
<!--
Crans.messages.setMessage('$error.replace("\'","\\\'")', 'errorMessage')
//-->
</script>
#end if
<div id="loadings">
Chargement en cours...
</div>
<div id="globalDiv" onclick="setMessage();">
<div id="globalDiv">
<div id="paramCompte" class="domtab">
<h1>Param&egrave;tres de mon compte</h1>
<ul class="domtabs">
<li><a href="#mainTab">G&eacute;n&eacute;ral</a></li>
<li><a href="#machinesTab">Machines</a></li>
<li><a href="#mailTab">Mails</a></li>
</ul>
<!-- +++++++++++++++++++ Infos Utilisateur +++++++++++++++++++ -->
@ -106,49 +106,6 @@
</div>
<!-- +++++++++++++++++++ Infos Machines +++++++++++++++++++ -->
<div>
<h2 class="mark"><a name="machinesTab" id="machinesTab"></a></h2>
<ul class="tabbed_page" id="machineList">
#for $machine in $machines
<li>
<h3>$machine.nomCourt</h3>
<dl class="machineInfos">
<dt>Type : </dt><dd>$machine.type</dd>
<dt>MAC : </dt><dd>$machine.mac</dd>
<dt>IP : </dt><dd>$machine.ip</dd>
#if $machine.ipsec
<dt>Clef ipsec : </dt><dd>$machine.ipsec</dd>
#end if
</dl>
<div class="clear"></div>
<span class="actions">
<a href="#" onclick="return askForMachineName('$machine.nomCourt', '$machine.mid')">renommer</a>
<a href="#" onclick="return askForMachineMac('$machine.mac', '$machine.mid')">Changer de MAC</a>
<a href="#" onclick="return askForDeleteMachine('$machine.mid');">Supprimer</a>
</span>
<div class="clear"></div>
</li>
#end for
</ul>
<ul class="tabbed_page">
<li class="last">
<h3>Ajouter une machine</h3>
<form action="creerMachine" method="post" onsubmit="return creerMachine(this.nomNouvelleMachine.value, this.MACNouvelleMachine.value, this.estMachineWifi.checked)" name="addMachineForm">
<label class="textInputLabel" for="nomNouvelleMachine">Nom de la machine :</label>
<input type="text" id="nomNouvelleMachine" name="nomNouvelleMachine"/><br />
<label class="textInputLabel" for="MACNouvelleMachine">Adresse MAC :</label>
<input type="text" id="MACNouvelleMachine" name="MACNouvelleMachine"/><br />
<a class="textInputNote" href="http://wiki/VieCrans/Param%c3%a8tresConnexion/AdresseMac" target="_blanc">Comment trouver l'adresse mac ?</a><br />
<label class="checkBoxLabel" for="isWifi"><input type="checkbox" id="estMachineWifi" name="estMachineWifi" value="1" />machine wifi</label><br />
<input type="submit" value="Ajouter" />
</form>
<p class="note"><b>Note :</b>Pour les non membres actifs, le nombre de machines fixes est limit&eacute; &agrave; 1</p>
</li>
</ul>
</div>
<!-- +++++++++++++++++++ Infos Mails +++++++++++++++++++ -->
<div>
<h2 class="mark"><a name="mailTab" id="mailTab"></a></h2>