remove install wizzrd

pull/26/head
ibuler 2015-12-17 10:08:38 +08:00
parent 5740dec7b4
commit 9fb71ade71
3 changed files with 0 additions and 435 deletions

View File

@ -13,8 +13,6 @@ urlpatterns = patterns('jumpserver.views',
url(r'^file/download/$', 'download', name='file_download'),
url(r'^setting', 'setting', name='setting'),
url(r'^terminal/$', 'web_terminal', name='terminal'),
url(r'^install/$', 'install', name='install'),
url(r'^install/test/(\w+)/$', 'install_test', name='install_test'),
url(r'^juser/', include('juser.urls')),
url(r'^jasset/', include('jasset.urls')),
url(r'^jlog/', include('jlog.urls')),

View File

@ -356,77 +356,3 @@ def web_terminal(request):
return render_to_response('jlog/web_terminal.html', locals())
def install(request):
if request.method == 'POST':
username = request.GET.get('username')
password = request.GET.get('password')
email = request.GET.get('email')
db_host = request.GET.get('db_host')
db_port = int(request.GET.get('db_port')) if request.GET.get('db_port') else 1
db_user = request.GET.get('db_user')
db_pass = request.GET.get('db_pass')
db = request.GET.get('db')
smtp_host = request.GET.get('smtp_host') if request.GET.get('smtp_host') else 'jumpserver'
smtp_port = int(request.GET.get('smtp_port')) if request.GET.get('smtp_port') else 25
mail_addr = request.GET.get('mail_addr')
mail_pass = request.GET.get('mail_pass')
config = ConfigParser.ConfigParser()
config.read(os.path.join(BASE_DIR, 'jumpserver.conf'))
config.set('db', 'host', db_host)
config.set('db', 'port', db_port)
config.set('db', 'user', db_user)
config.set('db', 'password', db_pass)
config.set('db', 'database', db)
config.set('mail', 'email_host', smtp_host)
config.set('mail', 'email_port', smtp_port)
config.set('mail', 'email_host_user', mail_addr)
config.set('mail', 'email_host_passoword', mail_pass)
f = open(os.path.join(BASE_DIR, 'jumpserver.conf'), 'w')
config.write(f)
return render_to_response('install.html', locals())
def install_test(request, offset):
if request.method == 'GET':
if offset == 'db':
import MySQLdb
db_host = request.GET.get('db_host')
db_port = int(request.GET.get('db_port')) if request.GET.get('db_port') else 1
db_user = request.GET.get('db_user')
db_pass = request.GET.get('db_pass')
db = request.GET.get('db')
try:
conn = MySQLdb.connect(host=db_host, port=db_port, user=db_user, passwd=db_pass, db=db)
except Exception, e:
logger.debug(u'测试连接数据库失败: %s %s % s %s' % (db_host, db_port, db_user, db_pass))
return HttpResponse(u'链接失败 %s' % e, status=500)
else:
return HttpResponse('连接成功')
elif offset == 'mail':
from smtplib import SMTP
smtp_host = request.GET.get('smtp_host') if request.GET.get('smtp_host') else 'jumpserver'
smtp_port = int(request.GET.get('smtp_port')) if request.GET.get('smtp_port') else 25
mail_addr = request.GET.get('mail_addr')
mail_pass = request.GET.get('mail_pass')
try:
smtp = SMTP(smtp_host, port=smtp_port, timeout=2)
smtp.login(mail_addr, mail_pass)
smtp.sendmail(mail_addr, (mail_addr),
'''From:%s\r\nTo:%s\r\nSubject:Jumpserver Mail Test!\r\n\r\n Mail test passed!\r\n''' %
(mail_addr, mail_addr))
smtp.quit()
except Exception, e:
logger.debug(u'邮件测试失败: %s' % e)
return HttpResponse('测试失败 %s' % e)
else:
return HttpResponse(u'登陆 %s邮箱查看邮件' % mail_addr)
else:
return HttpResponse('请求方法错误')

View File

@ -1,359 +0,0 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Jumpserver Install</title>
<!-- <link href="css/bootstrap.min.css" rel="stylesheet"> -->
<link href="/static/css/bootstrap.min.css" rel="stylesheet">
<!-- <link href="font-awesome/css/font-awesome.css" rel="stylesheet"> -->
<!-- <link href="css/plugins/iCheck/custom.css" rel="stylesheet"> -->
<link href="/static/css/plugins/steps/jquery.steps.css" rel="stylesheet">
<!-- <link href="css/animate.css" rel="stylesheet"> -->
<!-- <link href="css/style.css" rel="stylesheet"> -->
<link href="/static/css/style.css" rel="stylesheet">
<style>
.wizard-big.wizard > .content {
min-height: 320px;
}
</style>
</head>
<body>
<div id="wrapper">
<div class="row" >
<div class="col-sm-12" >
<div class="ibox">
<div class="ibox-title">
<h5>向导</h5>
<div class="ibox-tools">
<a class="collapse-link">
<i class="fa fa-chevron-up"></i>
</a>
<a class="dropdown-toggle" data-toggle="dropdown" href="#">
<i class="fa fa-wrench"></i>
</a>
<a class="close-link">
<i class="fa fa-times"></i>
</a>
</div>
</div>
<div class="ibox-content" style="height: 900px;">
<h2>
安装向导
</h2>
<p>
请输入相关信息完成安装
</p>
<form id="form" action="{% url 'install' %}" method="post" class="wizard-big" >
<h1>管理员账户</h1>
<fieldset>
<h2>管理员账号是首次登陆的账号</h2>
<div class="row">
<div class="col-sm-6">
<div class="form-group">
<label>用户名 *</label>
<input id="username" name="username" type="text" class="form-control required" minlength="5" >
</div>
<div class="form-group">
<label>密码 *</label>
<input id="password" name="password" type="password" class="form-control required password" minlength="8">
</div>
</div>
<div class="col-sm-6">
<div class="form-group">
<label>邮件 *</label>
<input id="email" name="email" type="email" class="form-control required">
</div>
<div class="form-group">
<label>确认密码 *</label>
<input id="pass_confirm" name="pass_confirm" type="password" equalto="#password" class="form-control required">
</div>
</div>
<div class="col-sm-4">
<div class="text-center">
<div style="margin-top: 20px">
<i class="fa fa-sign-in" style="font-size: 180px;color: #e5e5e5 "></i>
</div>
</div>
</div>
</div>
</fieldset>
<h1>数据库</h1>
<fieldset>
<h2>数据库连接信息</h2>
<div class="row">
<div class="col-sm-6">
<div class="form-group">
<label>地址 *</label>
<input id="db_host" name="db_host" type="text" value="127.0.0.1" class="form-control required">
</div>
<div class="form-group">
<label>端口 *</label>
<input id="db_port" name="db_port" type="text" value="3306" class="form-control required number">
</div>
<div class="form-group">
<label>数据库 *</label>
<input id="db" name="db" type="text" value="jumpserver" class="form-control required">
</div>
</div>
<div class="col-sm-6">
<div class="form-group">
<label>用户名 *</label>
<input id="db_user" name="db_user" type="text" value="jumpserver" class="form-control required">
</div>
<div class="form-group">
<label>密码 *</label>
<input id="db_pass" name="db_pass" type="password" class="form-control required">
</div>
<div class="form-group">
<div></div>
<a id="db_btn" value="{% url 'install_test' 'db' %}" class="btn btn-sm btn-warning" style="float: right" onclick="db_test(this)"> 测试连接 </a>
</div>
</div>
</div>
</fieldset>
<h1>邮件设置</h1>
<fieldset>
<h2>邮件设置</h2>
<div class="row">
<div class="col-sm-6">
<div class="form-group">
<label>SMTP *</label>
<input id="smtp_host" name="smtp_host" placeholder="smtp.qq.com" type="text" class="form-control required">
</div>
<div class="form-group">
<label>端口 *</label>
<input id="smtp_port" name="smtp_port" value="25" type="text" class="form-control required">
</div>
</div>
<div class="col-sm-6">
<div class="form-group">
<label>邮件地址 *</label>
<input id="mail_addr" name="mail_addr" placeholder="xxxx@qq.com" type="text" class="form-control required">
</div>
<div class="form-group">
<label>密码 *</label>
<input id="mail_pass" name="mail_pass" type="password" class="form-control required">
</div>
<div class="form-group">
<div></div>
<a id="mail_btn" value="{% url 'install_test' 'mail' %}" class="btn btn-sm btn-warning" style="float: right" onclick="smtp_test(this)"> 测试邮件 </a>
</div>
</div>
</div>
</fieldset>
<h1>完成</h1>
<fieldset>
<h2>确认信息</h2>
<p id="confirm"></p>
</fieldset>
</form>
</div>
</div>
</div>
</div>
</div>
</div>
<!-- Mainly scripts -->
<!-- // <script src="js/jquery-2.1.1.js"></script> -->
<script src="/static/js/jquery-2.1.1.js"></script>
<script src="/static/js/bootstrap.min.js"></script>
<!-- // <script src="js/plugins/metisMenu/jquery.metisMenu.js"></script> -->
<script src="/static/js/plugins/metisMenu/jquery.metisMenu.js"></script>
<!-- // <script src="js/plugins/slimscroll/jquery.slimscroll.min.js"></script> -->
<!-- Custom and plugin javascript -->
<!-- // <script src="js/inspinia.js"></script> -->
<!-- // <script src="js/plugins/pace/pace.min.js"></script> -->
<!-- Steps -->
<script src="/static/js/plugins/steps/jquery.steps.min.js"></script>
<!-- Jquery Validate -->
<script src="/static/js/plugins/validate/jquery.validate.min.js"></script>
<script>
var db_test_valid = false;
var smtp_test_valid = false;
function db_test(t, alert_){
var valid = $(t).closest('form').valid();
if (valid == false){
console.log('Not valid');
return
}
var db_host = $('#db_host').val();
var db_port = $('#db_port').val();
var db_user = $('#db_user').val();
var db_pass = $('#db_pass').val();
var db = $('#db').val();
$.ajax({
url: $(t).attr('value'),
data: {'db_host': db_host,
'db_port': db_port,
'db_user': db_user,
'db_pass': db_pass,
'db': db },
success: function(data, status){
db_test_valid = true;
$('#db_btn').removeClass('btn-danger');
$('#db_btn').addClass('btn-primary');
alert(data)
},
error: function(data){
$('#db_btn').addClass('btn-danger');
alert(data.responseText)
}
});
return false;
}
function smtp_test(t){
var valid = $(t).closest('form').valid();
if (valid == false){
console.log('Not valid');
return
}
var smtp_host = $('#smtp_host').val();
var smtp_port = $('#smtp_port').val();
var mail_addr = $('#mail_addr').val();
var mail_pass = $('#mail_pass').val();
$.ajax({
url: $(t).attr('value'),
data: {
'smtp_host': smtp_host,
'smtp_port': smtp_port,
'mail_addr': mail_addr,
'mail_pass': mail_pass
},
success: function(data, status){
smtp_test_valid = false;
$('#smtp_btn').removeClass('btn-danger');
$('#smtp_btn').addClass('btn-primary');
alert(data)
},
error: function(data) {
$('#smtp_btn').addClass('btn-danger');
alert(data.responseText)
}
});
return false;
}
$(document).ready(function(){
// $("#wizard").steps();
$("#form").steps({
bodyTag: "fieldset",
onStepChanging: function (event, currentIndex, newIndex)
{
// Always allow going backward even if the current step contains invalid fields!
if (currentIndex > newIndex)
{
return true;
}
// Forbid suppressing "Warning" step if the user is to young
if (newIndex === 2){
if (db_test_valid == false) {
$('#db_btn').removeClass('btn-warning');
$('#db_btn').addClass('btn-danger');
return false;
}
}
if (newIndex === 3){
//if (smtp_test_valid == false){
// $('#smtp_btn').removeClass('btn-warning');
// $('#smtp_btn').addClass('btn-danger');
// return false;
//}
console.log('pass')
}
var form = $(this);
// Clean up if user went backward before
if (currentIndex < newIndex)
{
// To remove error styles
$(".body:eq(" + newIndex + ") label.error", form).remove();
$(".body:eq(" + newIndex + ") .error", form).removeClass("error");
}
// Disable validation on fields that are disabled or hidden.
form.validate().settings.ignore = ":disabled,:hidden";
// Start validation; Prevent going forward if false
return form.valid();
},
onStepChanged: function (event, currentIndex, priorIndex)
{
// Suppress (skip) "Warning" step if the user is old enough.
if (currentIndex === 2 && Number($("#age").val()) >= 18)
{
$(this).steps("next");
}
// Suppress (skip) "Warning" step if the user is old enough and wants to the previous step.
if (currentIndex === 2 && priorIndex === 3)
{
$(this).steps("previous");
}
console.log(currentIndex + ';' + priorIndex);
if (currentIndex === 3 && priorIndex === 2)
{
$('#confirm').html(
'<span>' + '管理账号: ' + $('#username').val() + '<br/ >' +
'<span>' + '管理邮箱: ' + $('#email').val() + '<br/ >' +
'<span>' + '数据库地址: ' + $('#db_host').val() + '<br/ >' +
'<span>' + '数据库端口: ' + $('#db_port').val() + '<br/ >' +
'<span>' + '数据库账号: ' + $('#db_user').val() + '<br/ >' +
'<span>' + 'SMTP地址: ' + $('#smtp_host').val() + '<br/ >' +
'<span>' + 'SMTP端口: ' + $('#smtp_port').val() + '<br/ >' +
'<span>' + '邮件账号: ' + $('#mail_addr').val() + '<br/ >'
)
}
},
onFinishing: function (event, currentIndex)
{
var form = $(this);
// Disable validation on fields that are disabled.
// At this point it's recommended to do an overall check (mean ignoring only disabled fields)
form.validate().settings.ignore = ":disabled";
// Start validation; Prevent form submission if false
return form.valid();
},
onFinished: function (event, currentIndex)
{
var form = $(this);
// Submit form input
form.submit();
}
}).validate({
errorPlacement: function (error, element)
{
element.before(error);
},
rules: {
confirm: {
equalTo: "#password"
}
}
});
});
</script>
</body>
</html>