Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.buildout
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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
slapos.buildout
Commits
c8adddda
Commit
c8adddda
authored
Jun 09, 2017
by
Julien Muchembled
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
networkcache: Python 3 compatibility, small code cleanup
parent
06628c2d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
40 deletions
+32
-40
src/zc/buildout/networkcache.py
src/zc/buildout/networkcache.py
+32
-40
No files found.
src/zc/buildout/networkcache.py
View file @
c8adddda
...
@@ -14,22 +14,21 @@
...
@@ -14,22 +14,21 @@
#XXX factor with slapos/grid/networkcache.py and use libnetworkcache helpers
#XXX factor with slapos/grid/networkcache.py and use libnetworkcache helpers
from
__future__
import
absolute_import
,
print_function
,
division
import
hashlib
import
hashlib
import
posixpath
import
posixpath
import
re
import
re
import
sys
import
traceback
import
traceback
try
:
try
:
# Python 3
# Python 3
from
urllib.error
import
HTTPError
from
urllib.error
import
HTTPError
from
urllib.parse
import
urlparse
from
urllib.parse
import
urlparse
strify
=
bytes
.
decode
except
ImportError
:
except
ImportError
:
# Python 2
# Python 2
from
urllib2
import
HTTPError
from
urllib2
import
HTTPError
from
urlparse
import
urlparse
from
urlparse
import
urlparse
strify
=
str
print_
=
lambda
*
a
:
sys
.
stdout
.
write
(
' '
.
join
(
map
(
str
,
a
))
+
'
\
\
n'
)
try
:
try
:
try
:
try
:
...
@@ -43,10 +42,10 @@ try:
...
@@ -43,10 +42,10 @@ try:
else
:
else
:
LIBNETWORKCACHE_ENABLED
=
True
LIBNETWORKCACHE_ENABLED
=
True
except
:
except
:
print
_
(
'There was problem while trying to import slapos.libnetworkcache:'
\
print
(
'There was problem while trying to import slapos.libnetworkcache:
\
n
'
'
\
n
%s'
%
traceback
.
format_exc
())
+
traceback
.
format_exc
())
LIBNETWORKCACHE_ENABLED
=
False
LIBNETWORKCACHE_ENABLED
=
False
print
_
(
'Networkcache forced to be disabled.'
)
print
(
'Networkcache forced to be disabled.'
)
_md5_re
=
re
.
compile
(
r'md5=([a-f0-9]+)'
)
_md5_re
=
re
.
compile
(
r'md5=([a-f0-9]+)'
)
...
@@ -55,7 +54,6 @@ def _get_md5_from_url(url):
...
@@ -55,7 +54,6 @@ def _get_md5_from_url(url):
match
=
_md5_re
.
search
(
url
)
match
=
_md5_re
.
search
(
url
)
if
match
:
if
match
:
return
match
.
group
(
1
)
return
match
.
group
(
1
)
return
None
def
fallback_call
(
function
):
def
fallback_call
(
function
):
"""Decorator which disallow to have any problem while calling method"""
"""Decorator which disallow to have any problem while calling method"""
...
@@ -66,7 +64,7 @@ def fallback_call(function):
...
@@ -66,7 +64,7 @@ def fallback_call(function):
try
:
try
:
return
function
(
self
,
*
args
,
**
kwd
)
return
function
(
self
,
*
args
,
**
kwd
)
except
:
# indeed, *any* exception is swallowed
except
:
# indeed, *any* exception is swallowed
print
_
(
'There was problem while calling method %r:
\
n
%s'
%
(
print
(
'There was problem while calling method %r:
\
n
%s'
%
(
function
.
__name__
,
traceback
.
format_exc
()))
function
.
__name__
,
traceback
.
format_exc
()))
return
False
return
False
wrapper
.
__doc__
=
function
.
__doc__
wrapper
.
__doc__
=
function
.
__doc__
...
@@ -82,7 +80,7 @@ def get_directory_key(url):
...
@@ -82,7 +80,7 @@ def get_directory_key(url):
- if not, the directory key will be slapos-buildout-urlmd5
- if not, the directory key will be slapos-buildout-urlmd5
# XXX why is that?
# XXX why is that?
"""
"""
urlmd5
=
hashlib
.
md5
(
url
).
hexdigest
()
urlmd5
=
hashlib
.
md5
(
url
.
encode
()
).
hexdigest
()
if
'pypi'
in
url
:
if
'pypi'
in
url
:
return
'pypi-buildout-%s'
%
urlmd5
return
'pypi-buildout-%s'
%
urlmd5
return
'slapos-buildout-%s'
%
urlmd5
return
'slapos-buildout-%s'
%
urlmd5
...
@@ -91,7 +89,8 @@ def get_directory_key(url):
...
@@ -91,7 +89,8 @@ def get_directory_key(url):
def
get_index_directory_key
(
url
,
requirement
):
def
get_index_directory_key
(
url
,
requirement
):
"""Returns directory hash based on egg requirement.
"""Returns directory hash based on egg requirement.
"""
"""
return
'pypi-index-%s-%s'
%
(
hashlib
.
md5
(
url
).
hexdigest
(),
requirement
)
urlmd5
=
hashlib
.
md5
(
url
.
encode
()).
hexdigest
()
return
'pypi-index-%s-%s'
%
(
urlmd5
,
requirement
)
@
fallback_call
@
fallback_call
...
@@ -112,7 +111,7 @@ def download_network_cached(dir_url, cache_url, path, url, logger,
...
@@ -112,7 +111,7 @@ def download_network_cached(dir_url, cache_url, path, url, logger,
directory_key
=
get_directory_key
(
url
)
directory_key
=
get_directory_key
(
url
)
logger
.
debug
(
'Trying to download %s from network cache...'
%
url
)
logger
.
debug
(
'Trying to download %s from network cache...'
,
url
)
if
helper_download_network_cached_to_file
(
if
helper_download_network_cached_to_file
(
dir_url
=
dir_url
,
dir_url
=
dir_url
,
...
@@ -120,13 +119,13 @@ def download_network_cached(dir_url, cache_url, path, url, logger,
...
@@ -120,13 +119,13 @@ def download_network_cached(dir_url, cache_url, path, url, logger,
signature_certificate_list
=
signature_certificate_list
,
signature_certificate_list
=
signature_certificate_list
,
directory_key
=
directory_key
,
directory_key
=
directory_key
,
path
=
path
):
path
=
path
):
logger
.
info
(
'Downloaded %s from network cache.'
%
url
)
logger
.
info
(
'Downloaded %s from network cache.'
,
url
)
if
not
check_md5sum
(
path
,
md5sum
):
if
check_md5sum
(
path
,
md5sum
):
logger
.
info
(
'MD5 checksum mismatch downloading %s'
%
url
)
return
True
return
False
logger
.
info
(
'MD5 checksum mismatch downloading %s'
,
url
)
return
True
else
:
logger
.
info
(
'Cannot download %s from network cache.'
%
url
)
logger
.
info
(
'Cannot download %s from network cache.'
,
url
)
return
False
return
False
@
fallback_call
@
fallback_call
...
@@ -147,8 +146,8 @@ def download_index_network_cached(dir_url, cache_url, url, requirement, logger,
...
@@ -147,8 +146,8 @@ def download_index_network_cached(dir_url, cache_url, url, requirement, logger,
directory_key
=
get_index_directory_key
(
url
,
requirement
)
directory_key
=
get_index_directory_key
(
url
,
requirement
)
wanted_metadata_dict
=
{
wanted_metadata_dict
=
{
'urlmd5'
:
hashlib
.
md5
(
url
).
hexdigest
(),
'urlmd5'
:
hashlib
.
md5
(
url
.
encode
()
).
hexdigest
(),
'requirement'
:
requirement
'requirement'
:
requirement
,
}
}
required_key_list
=
[
'base'
]
required_key_list
=
[
'base'
]
...
@@ -158,15 +157,15 @@ def download_index_network_cached(dir_url, cache_url, url, requirement, logger,
...
@@ -158,15 +157,15 @@ def download_index_network_cached(dir_url, cache_url, url, requirement, logger,
if
result
:
if
result
:
file_descriptor
,
metadata
=
result
file_descriptor
,
metadata
=
result
try
:
try
:
content
=
file_descriptor
.
read
(
)
content
=
strify
(
file_descriptor
.
read
()
)
logger
.
info
(
'Downloaded %s from network cache.'
%
url
)
logger
.
info
(
'Downloaded %s from network cache.'
,
url
)
return
content
,
metadata
[
'base'
]
return
content
,
metadata
[
'base'
]
except
(
IOError
,
DirectoryNotFound
)
as
e
:
except
(
IOError
,
DirectoryNotFound
)
as
e
:
if
isinstance
(
e
,
HTTPError
)
and
e
.
code
==
404
:
if
isinstance
(
e
,
HTTPError
)
and
e
.
code
==
404
:
logger
.
debug
(
'%s does not exist in network cache.'
%
url
)
logger
.
debug
(
'%s does not exist in network cache.'
,
url
)
else
:
else
:
logger
.
debug
(
'Failed to download from network cache %s: %s'
%
\
logger
.
debug
(
'Failed to download from network cache %s: %s'
,
(
url
,
str
(
e
))
)
url
,
e
)
return
False
return
False
@
fallback_call
@
fallback_call
...
@@ -181,15 +180,14 @@ def upload_network_cached(dir_url, cache_url, external_url, path, logger,
...
@@ -181,15 +180,14 @@ def upload_network_cached(dir_url, cache_url, external_url, path, logger,
if
not
(
dir_url
and
cache_url
):
if
not
(
dir_url
and
cache_url
):
return
False
return
False
logger
.
info
(
'Uploading %s into network cache.'
%
external_url
)
logger
.
info
(
'Uploading %s into network cache.'
,
external_url
)
file_name
=
get_filename_from_url
(
external_url
)
file_name
=
get_filename_from_url
(
external_url
)
directory_key
=
get_directory_key
(
external_url
)
directory_key
=
get_directory_key
(
external_url
)
kw
=
dict
(
file_name
=
file_name
,
kw
=
dict
(
file_name
=
file_name
,
urlmd5
=
hashlib
.
md5
(
external_url
).
hexdigest
())
urlmd5
=
hashlib
.
md5
(
external_url
.
encode
()
).
hexdigest
())
f
=
open
(
path
,
'r'
)
# convert '' into None in order to call nc nicely
# convert '' into None in order to call nc nicely
if
not
signature_private_key_file
:
if
not
signature_private_key_file
:
signature_private_key_file
=
None
signature_private_key_file
=
None
...
@@ -219,17 +217,12 @@ def upload_network_cached(dir_url, cache_url, external_url, path, logger,
...
@@ -219,17 +217,12 @@ def upload_network_cached(dir_url, cache_url, external_url, path, logger,
return
False
return
False
try
:
try
:
return
nc
.
upload
(
f
,
directory_key
,
**
kw
)
with
open
(
path
,
'rb'
)
as
f
:
return
nc
.
upload
(
f
,
directory_key
,
**
kw
)
except
(
IOError
,
UploadError
)
as
e
:
except
(
IOError
,
UploadError
)
as
e
:
logger
.
info
(
'Fail to upload file. %s'
%
\
logger
.
info
(
'Fail to upload file. %s'
,
e
)
(
str
(
e
)))
return
False
return
False
finally
:
f
.
close
()
return
True
@
fallback_call
@
fallback_call
def
upload_index_network_cached
(
dir_url
,
cache_url
,
external_url
,
base
,
requirement
,
content
,
logger
,
def
upload_index_network_cached
(
dir_url
,
cache_url
,
external_url
,
base
,
requirement
,
content
,
logger
,
signature_private_key_file
,
shacache_ca_file
,
shacache_cert_file
,
signature_private_key_file
,
shacache_ca_file
,
shacache_cert_file
,
...
@@ -242,7 +235,7 @@ def upload_index_network_cached(dir_url, cache_url, external_url, base, requirem
...
@@ -242,7 +235,7 @@ def upload_index_network_cached(dir_url, cache_url, external_url, base, requirem
if
not
(
dir_url
and
cache_url
):
if
not
(
dir_url
and
cache_url
):
return
False
return
False
logger
.
info
(
'Uploading %s content into network cache.'
%
external_url
)
logger
.
info
(
'Uploading %s content into network cache.'
,
external_url
)
directory_key
=
get_index_directory_key
(
external_url
,
requirement
)
directory_key
=
get_index_directory_key
(
external_url
,
requirement
)
kw
=
dict
(
file
=
"file"
,
kw
=
dict
(
file
=
"file"
,
...
@@ -285,8 +278,7 @@ def upload_index_network_cached(dir_url, cache_url, external_url, base, requirem
...
@@ -285,8 +278,7 @@ def upload_index_network_cached(dir_url, cache_url, external_url, base, requirem
try
:
try
:
return
nc
.
upload_generic
(
f
,
directory_key
,
**
kw
)
return
nc
.
upload_generic
(
f
,
directory_key
,
**
kw
)
except
(
IOError
,
UploadError
)
as
e
:
except
(
IOError
,
UploadError
)
as
e
:
logger
.
info
(
'Fail to upload file. %s'
%
\
logger
.
info
(
'Fail to upload file. %s'
,
e
)
(
str
(
e
)))
return
False
return
False
finally
:
finally
:
...
@@ -313,4 +305,4 @@ def get_filename_from_url(url):
...
@@ -313,4 +305,4 @@ def get_filename_from_url(url):
return
name
return
name
from
zc.buildout
.download
import
check_md5sum
from
.download
import
check_md5sum
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