Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
J
jumpserver
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ops
jumpserver
Commits
b348f7f1
Commit
b348f7f1
authored
Dec 14, 2016
by
yumaojun03
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
添加了部分cron的list页面
parent
a0c9e3d1
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
37 deletions
+60
-37
list.html
apps/ops/templates/cron/list.html
+23
-30
list.html
apps/ops/templates/sudo/list.html
+2
-4
views.py
apps/ops/views.py
+3
-3
jumpserver.js
apps/static/js/jumpserver.js
+32
-0
No files found.
apps/ops/templates/cron/list.html
View file @
b348f7f1
...
@@ -3,9 +3,9 @@
...
@@ -3,9 +3,9 @@
{% block table_search %}
{% block table_search %}
{% endblock %}
{% endblock %}
{% block table_container %}
{% block table_container %}
<div
class=
"uc pull-left m-l-5 m-r-5"
><a
href=
"{% url "
users:user-create
"
%}"
class=
"btn btn-sm btn-primary"
>
{% trans "Create
sudo
" %}
</a></div>
<div
class=
"uc pull-left m-l-5 m-r-5"
><a
href=
"{% url "
users:user-create
"
%}"
class=
"btn btn-sm btn-primary"
>
{% trans "Create
cron
" %}
</a></div>
<div
class=
"uc pull-left"
><a
href=
"javascript:void(0);"
class=
"btn btn-sm btn-primary"
data-toggle=
"modal"
data-target=
"#user_import_modal"
>
{% trans "Import user" %}
</a></div>
{#
<div
class=
"uc pull-left"
><a
href=
"javascript:void(0);"
class=
"btn btn-sm btn-primary"
data-toggle=
"modal"
data-target=
"#user_import_modal"
>
{% trans "Import user" %}
</a></div>
#}
<table
class=
"table table-striped table-bordered table-hover "
id=
"
user_list_table"
>
<table
class=
"table table-striped table-bordered table-hover "
id=
"
cron_list_table"
>
<thead>
<thead>
<tr>
<tr>
<th
class=
"text-center"
>
<th
class=
"text-center"
>
...
@@ -13,10 +13,9 @@
...
@@ -13,10 +13,9 @@
<input
id=
""
type=
"checkbox"
class=
"ipt_check_all"
>
<input
id=
""
type=
"checkbox"
class=
"ipt_check_all"
>
</th>
</th>
<th
class=
"text-center"
>
{% trans 'Name' %}
</th>
<th
class=
"text-center"
>
{% trans 'Name' %}
</th>
<th
class=
"text-center"
>
{% trans 'Username' %}
</th>
<th
class=
"text-center"
>
{% trans 'Time' %}
</th>
<th
class=
"text-center"
>
{% trans 'Role' %}
</th>
<th
class=
"text-center"
>
{% trans 'Job' %}
</th>
<th
class=
"text-center"
>
{% trans 'User group' %}
</th>
<th
class=
"text-center"
>
{% trans 'User' %}
</th>
<th
class=
"text-center"
>
{% trans 'Active' %}
</th>
<th
class=
"text-center"
>
{% trans 'Action' %}
</th>
<th
class=
"text-center"
>
{% trans 'Action' %}
</th>
</tr>
</tr>
</thead>
</thead>
...
@@ -38,7 +37,7 @@
...
@@ -38,7 +37,7 @@
</div>
</div>
</div>
</div>
{% include "users/_user_bulk_update_modal.html" %}
{% include "users/_user_bulk_update_modal.html" %}
{
% include "users/_user_import_modal.html" %
}
{
#{% include "users/_user_import_modal.html" %}#
}
{% endblock %}
{% endblock %}
{% block content_bottom_left %}{% endblock %}
{% block content_bottom_left %}{% endblock %}
{% block custom_foot_js %}
{% block custom_foot_js %}
...
@@ -46,24 +45,19 @@
...
@@ -46,24 +45,19 @@
<script>
<script>
$
(
document
).
ready
(
function
(){
$
(
document
).
ready
(
function
(){
var
options
=
{
var
options
=
{
ele
:
$
(
'#
user
_list_table'
),
ele
:
$
(
'#
cron
_list_table'
),
columnDefs
:
[
columnDefs
:
[
{
targets
:
1
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
{
targets
:
1
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
var
detail_btn
=
'<a href="{% url "
users:user
-detail" pk=99991937 %}">'
+
cellData
+
'</a>'
;
var
detail_btn
=
'<a href="{% url "
ops:page-cron
-detail" pk=99991937 %}">'
+
cellData
+
'</a>'
;
$
(
td
).
html
(
detail_btn
.
replace
(
'99991937'
,
rowData
.
id
));
$
(
td
).
html
(
detail_btn
.
replace
(
'99991937'
,
rowData
.
id
));
}},
}},
{
targets
:
4
,
createdCell
:
function
(
td
,
cellData
)
{
{
targets
:
2
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
var
innerHtml
=
cellData
.
length
>
20
?
cellData
.
substring
(
0
,
20
)
+
'...'
:
cellData
;
var
cron_time_tmp
=
"{0} {1} {2} {3} {4} (分 时 日 月 周)"
;
$
(
td
).
html
(
'<span href="javascript:void(0);" data-toggle="tooltip" title="'
+
cellData
+
'">'
+
innerHtml
+
'</span>'
);
var
cron_time
=
cron_time_tmp
.
format
(
rowData
.
minute
,
rowData
.
hour
,
rowData
.
day
,
rowData
.
month
,
rowData
.
weekday
);
var
innerHtml
=
'<span>'
+
cron_time
+
'</span>'
;
$
(
td
).
html
(
innerHtml
.
replace
(
'99991937'
,
rowData
.
id
));
}},
}},
{
targets
:
5
,
createdCell
:
function
(
td
,
cellData
)
{
{
targets
:
4
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
if
(
!
cellData
)
{
$
(
td
).
html
(
'<i class="fa fa-times text-danger"></i>'
)
}
else
{
$
(
td
).
html
(
'<i class="fa fa-check text-navy"></i>'
)
}
}},
{
targets
:
6
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
var
update_btn
=
'<a href="{% url "users:user-update" pk=99991937 %}" class="btn btn-xs btn-info">{% trans "Update" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
update_btn
=
'<a href="{% url "users:user-update" pk=99991937 %}" class="btn btn-xs btn-info">{% trans "Update" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
del_btn
=
'<a class="btn btn-xs btn-danger m-l-xs btn_user_delete" data-uid="99991937">{% trans "Delete" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
del_btn
=
'<a class="btn btn-xs btn-danger m-l-xs btn_user_delete" data-uid="99991937">{% trans "Delete" %}</a>'
.
replace
(
'99991937'
,
cellData
);
if
(
rowData
.
id
===
1
||
rowData
.
username
==
"admin"
)
{
if
(
rowData
.
id
===
1
||
rowData
.
username
==
"admin"
)
{
...
@@ -72,9 +66,8 @@ $(document).ready(function(){
...
@@ -72,9 +66,8 @@ $(document).ready(function(){
$
(
td
).
html
(
update_btn
+
del_btn
)
$
(
td
).
html
(
update_btn
+
del_btn
)
}
}
}}],
}}],
ajax_url
:
'{% url "api-users:user-list" %}'
,
ajax_url
:
'{% url "api-ops:crontable-list" %}'
,
columns
:
[{
data
:
"id"
},
{
data
:
"username"
},
{
data
:
"name"
},
{
data
:
"get_role_display"
},
columns
:
[{
data
:
"id"
},
{
data
:
"name"
},
{
data
:
"month"
},
{
data
:
"job"
},
{
data
:
"user"
},
{
data
:
"id"
}],
{
data
:
"groups_display"
},
{
data
:
"is_valid"
},
{
data
:
"id"
}],
op_html
:
$
(
'#actions'
).
html
()
op_html
:
$
(
'#actions'
).
html
()
};
};
var
table
=
jumpserver
.
initDataTable
(
options
);
var
table
=
jumpserver
.
initDataTable
(
options
);
...
@@ -89,7 +82,7 @@ $(document).ready(function(){
...
@@ -89,7 +82,7 @@ $(document).ready(function(){
}).
on
(
'click'
,
'#btn_bulk_update'
,
function
(){
}).
on
(
'click'
,
'#btn_bulk_update'
,
function
(){
var
action
=
$
(
'#slct_bulk_update'
).
val
();
var
action
=
$
(
'#slct_bulk_update'
).
val
();
var
$data_table
=
$
(
'#
user
_list_table'
).
DataTable
();
var
$data_table
=
$
(
'#
cron
_list_table'
).
DataTable
();
var
id_list
=
[];
var
id_list
=
[];
var
plain_id_list
=
[];
var
plain_id_list
=
[];
$data_table
.
rows
({
selected
:
true
}).
every
(
function
(){
$data_table
.
rows
({
selected
:
true
}).
every
(
function
(){
...
@@ -121,7 +114,7 @@ $(document).ready(function(){
...
@@ -121,7 +114,7 @@ $(document).ready(function(){
var
success
=
function
()
{
var
success
=
function
()
{
var
msg
=
"{% trans 'User Deleted.' %}"
;
var
msg
=
"{% trans 'User Deleted.' %}"
;
swal
(
"{% trans 'User Delete' %}"
,
msg
,
"success"
);
swal
(
"{% trans 'User Delete' %}"
,
msg
,
"success"
);
$
(
'#
user
_list_table'
).
DataTable
().
ajax
.
reload
();
$
(
'#
cron
_list_table'
).
DataTable
().
ajax
.
reload
();
};
};
var
fail
=
function
()
{
var
fail
=
function
()
{
var
msg
=
"{% trans 'User Deleting failed.' %}"
;
var
msg
=
"{% trans 'User Deleting failed.' %}"
;
...
@@ -157,7 +150,7 @@ $(document).ready(function(){
...
@@ -157,7 +150,7 @@ $(document).ready(function(){
var
success
=
function
()
{
var
success
=
function
()
{
var
msg
=
"{% trans 'User Deleted.' %}"
;
var
msg
=
"{% trans 'User Deleted.' %}"
;
swal
(
"{% trans 'User Delete' %}"
,
msg
,
"success"
);
swal
(
"{% trans 'User Delete' %}"
,
msg
,
"success"
);
$
(
'#
user
_list_table'
).
DataTable
().
ajax
.
reload
();
$
(
'#
cron
_list_table'
).
DataTable
().
ajax
.
reload
();
};
};
var
fail
=
function
()
{
var
fail
=
function
()
{
var
msg
=
"{% trans 'User Deleting failed.' %}"
;
var
msg
=
"{% trans 'User Deleting failed.' %}"
;
...
@@ -198,7 +191,7 @@ $(document).ready(function(){
...
@@ -198,7 +191,7 @@ $(document).ready(function(){
new_groups
=
body
.
groups
.
map
(
Number
);
new_groups
=
body
.
groups
.
map
(
Number
);
body
.
groups
=
new_groups
;
body
.
groups
=
new_groups
;
}
}
var
$data_table
=
$
(
'#
user
_list_table'
).
DataTable
()
var
$data_table
=
$
(
'#
cron
_list_table'
).
DataTable
()
var
post_list
=
[];
var
post_list
=
[];
$data_table
.
rows
({
selected
:
true
}).
every
(
function
(){
$data_table
.
rows
({
selected
:
true
}).
every
(
function
(){
var
content
=
Object
.
assign
({
id
:
this
.
data
().
id
},
body
);
var
content
=
Object
.
assign
({
id
:
this
.
data
().
id
},
body
);
...
@@ -211,7 +204,7 @@ $(document).ready(function(){
...
@@ -211,7 +204,7 @@ $(document).ready(function(){
var
success
=
function
()
{
var
success
=
function
()
{
var
msg
=
"{% trans 'The selected users has been updated successfully.' %}"
;
var
msg
=
"{% trans 'The selected users has been updated successfully.' %}"
;
swal
(
"{% trans 'User Updated' %}"
,
msg
,
"success"
);
swal
(
"{% trans 'User Updated' %}"
,
msg
,
"success"
);
$
(
'#
user
_list_table'
).
DataTable
().
ajax
.
reload
();
$
(
'#
cron
_list_table'
).
DataTable
().
ajax
.
reload
();
jumpserver
.
checked
=
false
;
jumpserver
.
checked
=
false
;
};
};
APIUpdateAttr
({
url
:
the_url
,
method
:
'PATCH'
,
body
:
JSON
.
stringify
(
post_list
),
success
:
success
});
APIUpdateAttr
({
url
:
the_url
,
method
:
'PATCH'
,
body
:
JSON
.
stringify
(
post_list
),
success
:
success
});
...
@@ -225,7 +218,7 @@ $(document).ready(function(){
...
@@ -225,7 +218,7 @@ $(document).ready(function(){
$
(
'<span />'
,
{
class
:
'help-block text-danger'
}).
html
(
data
.
msg
).
insertAfter
(
$
(
'#id_excel'
));
$
(
'<span />'
,
{
class
:
'help-block text-danger'
}).
html
(
data
.
msg
).
insertAfter
(
$
(
'#id_excel'
));
}
else
{
}
else
{
$
(
'#user_import_modal'
).
modal
(
'hide'
);
$
(
'#user_import_modal'
).
modal
(
'hide'
);
var
$data_table
=
$
(
'#
user
_list_table'
).
DataTable
();
var
$data_table
=
$
(
'#
cron
_list_table'
).
DataTable
();
toastr
.
success
(
"{% trans 'Import User Success.' %}"
);
toastr
.
success
(
"{% trans 'Import User Success.' %}"
);
$data_table
.
ajax
.
reload
();
$data_table
.
ajax
.
reload
();
}
}
...
...
apps/ops/templates/sudo/list.html
View file @
b348f7f1
...
@@ -14,7 +14,6 @@
...
@@ -14,7 +14,6 @@
<th
class=
"text-center"
>
{% trans 'Name' %}
</th>
<th
class=
"text-center"
>
{% trans 'Name' %}
</th>
<th
class=
"text-center"
>
{% trans 'Privileges' %}
</th>
<th
class=
"text-center"
>
{% trans 'Privileges' %}
</th>
<th
class=
"text-center"
>
{% trans 'Extra Lines' %}
</th>
<th
class=
"text-center"
>
{% trans 'Extra Lines' %}
</th>
<th
class=
"text-center"
>
{% trans 'Created' %}
</th>
<th
class=
"text-center"
>
{% trans 'Action' %}
</th>
<th
class=
"text-center"
>
{% trans 'Action' %}
</th>
</tr>
</tr>
...
@@ -51,7 +50,7 @@ $(document).ready(function(){
...
@@ -51,7 +50,7 @@ $(document).ready(function(){
var
detail_btn
=
'<a href="{% url "ops:page-sudo-detail" pk=99991937 %}">'
+
cellData
+
'</a>'
;
var
detail_btn
=
'<a href="{% url "ops:page-sudo-detail" pk=99991937 %}">'
+
cellData
+
'</a>'
;
$
(
td
).
html
(
detail_btn
.
replace
(
'99991937'
,
rowData
.
id
));
$
(
td
).
html
(
detail_btn
.
replace
(
'99991937'
,
rowData
.
id
));
}},
}},
{
targets
:
5
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
{
targets
:
4
,
createdCell
:
function
(
td
,
cellData
,
rowData
)
{
var
update_btn
=
'<a href="{% url "users:user-update" pk=99991937 %}" class="btn btn-xs btn-info">{% trans "Update" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
update_btn
=
'<a href="{% url "users:user-update" pk=99991937 %}" class="btn btn-xs btn-info">{% trans "Update" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
del_btn
=
'<a class="btn btn-xs btn-danger m-l-xs btn_user_delete" data-uid="99991937">{% trans "Delete" %}</a>'
.
replace
(
'99991937'
,
cellData
);
var
del_btn
=
'<a class="btn btn-xs btn-danger m-l-xs btn_user_delete" data-uid="99991937">{% trans "Delete" %}</a>'
.
replace
(
'99991937'
,
cellData
);
if
(
rowData
.
id
===
1
||
rowData
.
username
==
"admin"
)
{
if
(
rowData
.
id
===
1
||
rowData
.
username
==
"admin"
)
{
...
@@ -61,8 +60,7 @@ $(document).ready(function(){
...
@@ -61,8 +60,7 @@ $(document).ready(function(){
}
}
}}],
}}],
ajax_url
:
'{% url "api-ops:sudo-list" %}'
,
ajax_url
:
'{% url "api-ops:sudo-list" %}'
,
columns
:
[{
data
:
"id"
},
{
data
:
"name"
},
{
data
:
"privilege_items"
},
{
data
:
"extra_lines"
},
columns
:
[{
data
:
"id"
},
{
data
:
"name"
},
{
data
:
"privilege_items"
},
{
data
:
"extra_lines"
},
{
data
:
"id"
}],
{
data
:
"created_time"
},
{
data
:
"id"
}],
op_html
:
$
(
'#actions'
).
html
()
op_html
:
$
(
'#actions'
).
html
()
};
};
var
table
=
jumpserver
.
initDataTable
(
options
);
var
table
=
jumpserver
.
initDataTable
(
options
);
...
...
apps/ops/views.py
View file @
b348f7f1
...
@@ -34,14 +34,14 @@ class SudoDetailView(DetailView):
...
@@ -34,14 +34,14 @@ class SudoDetailView(DetailView):
template_name
=
'sudo/detail.html'
template_name
=
'sudo/detail.html'
class
CronListView
(
AdminUserRequiredMixin
,
List
SudoPrivilegesMixin
,
List
View
):
class
CronListView
(
AdminUserRequiredMixin
,
ListView
):
paginate_by
=
settings
.
CONFIG
.
DISPLAY_PER_PAGE
paginate_by
=
settings
.
CONFIG
.
DISPLAY_PER_PAGE
model
=
CronTable
model
=
CronTable
context_object_name
=
'crons'
context_object_name
=
'crons'
template_name
=
'
sudo
/list.html'
template_name
=
'
cron
/list.html'
class
CronCreateView
(
AdminUserRequiredMixin
,
Create
SudoPrivilegesMixin
,
Create
View
):
class
CronCreateView
(
AdminUserRequiredMixin
,
CreateView
):
model
=
CronTable
model
=
CronTable
template_name
=
'cron/create.html'
template_name
=
'cron/create.html'
...
...
apps/static/js/jumpserver.js
View file @
b348f7f1
...
@@ -333,3 +333,35 @@ jumpserver.initDataTable = function (options) {
...
@@ -333,3 +333,35 @@ jumpserver.initDataTable = function (options) {
return
table
;
return
table
;
};
};
/**
* 替换所有匹配exp的字符串为指定字符串
* @param exp 被替换部分的正则
* @param newStr 替换成的字符串
*/
String
.
prototype
.
replaceAll
=
function
(
exp
,
newStr
)
{
return
this
.
replace
(
new
RegExp
(
exp
,
"gm"
),
newStr
);
};
/**
* 原型:字符串格式化
* @param args 格式化参数值
*/
String
.
prototype
.
format
=
function
(
args
)
{
var
result
=
this
;
if
(
arguments
.
length
<
1
)
{
return
result
;
}
var
data
=
arguments
;
if
(
arguments
.
length
==
1
&&
typeof
(
args
)
==
"object"
)
{
data
=
args
;
}
for
(
var
key
in
data
)
{
var
value
=
data
[
key
];
if
(
undefined
!=
value
)
{
result
=
result
.
replaceAll
(
"
\\
{"
+
key
+
"
\\
}"
,
value
);
}
}
return
result
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment