Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.package
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Łukasz Nowak
slapos.package
Commits
d43a8995
Commit
d43a8995
authored
May 29, 2013
by
Jondy Zhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
netreport.py unittest over
parent
73606b84
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
26 deletions
+38
-26
windows/netreport/src/netreport.py
windows/netreport/src/netreport.py
+38
-26
No files found.
windows/netreport/src/netreport.py
View file @
d43a8995
...
@@ -28,11 +28,11 @@
...
@@ -28,11 +28,11 @@
##############################################################################
##############################################################################
import
argparse
import
argparse
from
datetime
import
datetime
,
date
from
datetime
import
datetime
,
date
import
logger
from
lxml
import
etree
from
lxml
import
etree
import
netuse
import
netuse
import
os.path
import
os.path
import
slapos.slap.slap
import
slapos.slap.slap
import
sqlite3
import
sys
import
sys
from
time
import
sleep
from
time
import
sleep
...
@@ -75,12 +75,12 @@ class NetDriveUsageReporter(object):
...
@@ -75,12 +75,12 @@ class NetDriveUsageReporter(object):
def
__init__
(
self
,
option_dict
):
def
__init__
(
self
,
option_dict
):
for
option
,
value
in
option_dict
.
items
():
for
option
,
value
in
option_dict
.
items
():
setattr
(
self
,
option
,
value
)
setattr
(
self
,
option
,
value
)
self
.
slap_computer
=
None
self
.
_
slap_computer
=
None
self
.
_domain_name
=
None
self
.
_domain_name
=
None
self
.
_domain_account
=
None
self
.
_domain_account
=
None
self
.
_config_id
=
None
self
.
_config_id
=
None
self
.
_report_date
=
None
self
.
_report_date
=
None
self
.
_db
=
initializeDatabase
(
self
.
data_file
)
self
.
initializeDatabase
(
self
.
data_file
)
def
initializeConnection
(
self
):
def
initializeConnection
(
self
):
connection_dict
=
{}
connection_dict
=
{}
...
@@ -89,14 +89,14 @@ class NetDriveUsageReporter(object):
...
@@ -89,14 +89,14 @@ class NetDriveUsageReporter(object):
slap
=
slapos
.
slap
.
slap
()
slap
=
slapos
.
slap
.
slap
()
slap
.
initializeConnection
(
self
.
master_url
,
slap
.
initializeConnection
(
self
.
master_url
,
**
connection_dict
)
**
connection_dict
)
self
.
slap_computer
=
slap
.
registerComputer
(
self
.
computer_id
)
self
.
_
slap_computer
=
slap
.
registerComputer
(
self
.
computer_id
)
def
initializeConfigData
(
self
):
def
initializeConfigData
(
self
):
user_info
=
netuse
r
.
userInfo
()
user_info
=
netuse
.
userInfo
()
self
.
_domain_account
=
"%s
\
\
%s"
%
user_info
[
0
:
2
]
self
.
_domain_account
=
"%s
\
\
%s"
%
user_info
[
1
:
3
]
q
=
self
.
_db
.
execute
q
=
self
.
_db
.
execute
s
=
"SELECT _rowid, report_date FROM config "
\
s
=
"SELECT _rowid
_
, report_date FROM config "
\
"WHERE domain_account=? and computer_id=?"
"WHERE domain_account=? and computer_id=?"
for
r
in
q
(
s
,
(
self
.
_domain_account
,
self
.
computer_id
)):
for
r
in
q
(
s
,
(
self
.
_domain_account
,
self
.
computer_id
)):
self
.
_config_id
,
self
.
_report_date
=
r
self
.
_config_id
,
self
.
_report_date
=
r
...
@@ -125,6 +125,8 @@ class NetDriveUsageReporter(object):
...
@@ -125,6 +125,8 @@ class NetDriveUsageReporter(object):
last_timestamp
=
current_timestamp
last_timestamp
=
current_timestamp
except
KeyboardInterrupt
:
except
KeyboardInterrupt
:
pass
pass
finally
:
self
.
_db
.
close
()
def
insertUsageReport
(
self
,
start
,
duration
):
def
insertUsageReport
(
self
,
start
,
duration
):
q
=
self
.
_db
.
execute
q
=
self
.
_db
.
execute
...
@@ -139,7 +141,7 @@ class NetDriveUsageReporter(object):
...
@@ -139,7 +141,7 @@ class NetDriveUsageReporter(object):
"""Called at startup of this application, send all report
"""Called at startup of this application, send all report
in the config table."""
in the config table."""
q
=
self
.
_db
.
execute
q
=
self
.
_db
.
execute
for
r
in
q
(
"SELECT _rowid, domain_account, computer_id, report_date "
for
r
in
q
(
"SELECT _rowid
_
, domain_account, computer_id, report_date "
"FROM config "
"FROM config "
"WHERE report_date < date('now')"
):
"WHERE report_date < date('now')"
):
self
.
_postData
(
self
.
generateDailyReport
(
*
r
))
self
.
_postData
(
self
.
generateDailyReport
(
*
r
))
...
@@ -158,7 +160,7 @@ class NetDriveUsageReporter(object):
...
@@ -158,7 +160,7 @@ class NetDriveUsageReporter(object):
self
.
computer_id
,
self
.
computer_id
,
self
.
_domain_account
,
self
.
_domain_account
,
self
.
_report_date
))
self
.
_report_date
))
self
.
_db
.
execute
(
"UPDATE config SET report_date=? where _rowid=?"
,
self
.
_db
.
execute
(
"UPDATE config SET report_date=? where _rowid
_
=?"
,
(
today
,
self
.
_config_id
))
(
today
,
self
.
_config_id
))
def
_postData
(
self
,
xml_data
):
def
_postData
(
self
,
xml_data
):
...
@@ -166,7 +168,7 @@ class NetDriveUsageReporter(object):
...
@@ -166,7 +168,7 @@ class NetDriveUsageReporter(object):
serialized via_getDict.
serialized via_getDict.
"""
"""
if
xml_data
is
not
None
:
if
xml_data
is
not
None
:
self
.
slap_computer
.
reportNetDriveUsage
(
xml_data
)
self
.
_
slap_computer
.
reportNetDriveUsage
(
xml_data
)
def
initializeDatabase
(
self
,
db_path
):
def
initializeDatabase
(
self
,
db_path
):
self
.
_db
=
sqlite3
.
connect
(
db_path
,
isolation_level
=
None
)
self
.
_db
=
sqlite3
.
connect
(
db_path
,
isolation_level
=
None
)
...
@@ -177,7 +179,7 @@ class NetDriveUsageReporter(object):
...
@@ -177,7 +179,7 @@ class NetDriveUsageReporter(object):
report_date TEXT NOT NULL,
report_date TEXT NOT NULL,
remark TEXT)"""
)
remark TEXT)"""
)
q
(
"""CREATE TABLE IF NOT EXISTS net_drive_usage (
q
(
"""CREATE TABLE IF NOT EXISTS net_drive_usage (
config_id INTEGER REFERENCES config ( _rowid ),
config_id INTEGER REFERENCES config ( _rowid
_
),
drive_letter TEXT NOT NULL,
drive_letter TEXT NOT NULL,
remote_folder TEXT NOT NULL,
remote_folder TEXT NOT NULL,
start TEXT DEFAULT CURRENT_TIMESTAMP,
start TEXT DEFAULT CURRENT_TIMESTAMP,
...
@@ -185,7 +187,7 @@ class NetDriveUsageReporter(object):
...
@@ -185,7 +187,7 @@ class NetDriveUsageReporter(object):
usage_bytes INTEGER,
usage_bytes INTEGER,
remark TEXT)"""
)
remark TEXT)"""
)
q
(
"""CREATE TABLE IF NOT EXISTS net_drive_usage_history (
q
(
"""CREATE TABLE IF NOT EXISTS net_drive_usage_history (
config_id INTEGER REFERENCES config ( _rowid ),
config_id INTEGER REFERENCES config ( _rowid
_
),
drive_letter TEXT NOT NULL,
drive_letter TEXT NOT NULL,
remote_folder TEXT NOT NULL,
remote_folder TEXT NOT NULL,
start TEXT NOT NULL,
start TEXT NOT NULL,
...
@@ -197,31 +199,41 @@ class NetDriveUsageReporter(object):
...
@@ -197,31 +199,41 @@ class NetDriveUsageReporter(object):
report_date
,
remove
=
True
):
report_date
,
remove
=
True
):
q
=
self
.
_db
.
execute
q
=
self
.
_db
.
execute
root
=
etree
.
Element
(
"report"
)
root
=
etree
.
Element
(
"report"
)
computer
=
etree
.
Element
(
"computer"
)
element
=
etree
.
Element
(
"computer"
)
computer
.
text
=
computer_id
element
.
text
=
computer_id
account
=
etree
.
Element
(
"account"
)
root
.
append
(
element
)
account
.
text
=
domain_account
report_date
=
etree
.
Element
(
"date"
)
element
=
etree
.
Element
(
"account"
)
report_date
.
text
=
report_date
element
.
text
=
domain_account
usage
=
etree
.
Element
(
"usage"
)
root
.
append
(
element
)
details
=
etree
.
Element
(
"details"
)
root
.
append
(
computer
,
account
,
report_date
,
usage
,
details
)
element
=
etree
.
Element
(
"date"
)
element
.
text
=
report_date
root
.
append
(
element
)
element
=
etree
.
Element
(
"usage"
)
root
.
append
(
element
)
usage
=
element
element
=
etree
.
Element
(
"details"
)
root
.
append
(
element
)
total
=
0
total
=
0
for
r
in
q
(
"SELECT duration, usage_bytes FROM net_drive_usage "
for
r
in
q
(
"SELECT duration, usage_bytes FROM net_drive_usage "
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
(
_
config_id
,
report_date
)):
(
config_id
,
report_date
)):
total
+=
r
[
0
]
*
r
[
1
]
total
+=
r
[
0
]
*
r
[
1
]
usage
.
text
=
str
(
total
)
usage
.
text
=
str
(
total
)
if
remove
:
if
remove
:
q
(
"INSERT INTO net_drive_usage_history "
q
(
"INSERT INTO net_drive_usage_history "
"SELECT * FROM net_drive_usage "
"SELECT * FROM net_drive_usage "
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
(
_
config_id
,
report_date
))
(
config_id
,
report_date
))
q
(
"DELETE FROM net_drive_usage "
q
(
"DELETE FROM net_drive_usage "
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
"WHERE config_id=? AND strftime('%Y-%m-%d', start)=?"
,
(
_
config_id
,
report_date
))
(
config_id
,
report_date
))
if
total
:
if
total
:
return
etree
.
tostring
(
root
,
xml_declaration
=
True
)
return
etree
.
tostring
(
root
,
encoding
=
'utf-8'
,
xml_declaration
=
True
)
def
main
():
def
main
():
reporter
=
NetDriveUsageReporter
(
parseArgumentTuple
())
reporter
=
NetDriveUsageReporter
(
parseArgumentTuple
())
...
...
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