Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
pyfs
Overview
Overview
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
OpenEdx
pyfs
Commits
4c9f9711
Commit
4c9f9711
authored
Dec 05, 2010
by
willmcgugan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Some missing files from last push
parent
ca0b820c
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
484 additions
and
0 deletions
+484
-0
fs/expose/http.py
+155
-0
fs/opener.py
+329
-0
No files found.
fs/expose/http.py
0 → 100644
View file @
4c9f9711
import
SimpleHTTPServer
import
SocketServer
from
fs.path
import
pathjoin
,
dirname
from
fs.errors
import
FSError
from
time
import
mktime
from
cStringIO
import
StringIO
import
cgi
import
urllib
import
posixpath
import
time
import
threading
def
_datetime_to_epoch
(
d
):
return
mktime
(
d
.
timetuple
())
class
FSHTTPRequestHandler
(
SimpleHTTPServer
.
SimpleHTTPRequestHandler
):
"""A hacked together version of SimpleHTTPRequestHandler"""
def
__init__
(
self
,
fs
,
request
,
client_address
,
server
):
self
.
_fs
=
fs
SimpleHTTPServer
.
SimpleHTTPRequestHandler
.
__init__
(
self
,
request
,
client_address
,
server
)
def
do_GET
(
self
):
"""Serve a GET request."""
f
=
None
try
:
f
=
self
.
send_head
()
if
f
:
self
.
copyfile
(
f
,
self
.
wfile
)
finally
:
if
f
is
not
None
:
f
.
close
()
def
send_head
(
self
):
"""Common code for GET and HEAD commands.
This sends the response code and MIME headers.
Return value is either a file object (which has to be copied
to the outputfile by the caller unless the command was HEAD,
and must be closed by the caller under all circumstances), or
None, in which case the caller has nothing further to do.
"""
path
=
self
.
translate_path
(
self
.
path
)
#path = self.translate_path(self.path)
#print path
f
=
None
if
self
.
_fs
.
isdir
(
path
):
if
not
self
.
path
.
endswith
(
'/'
):
# redirect browser - doing basically what apache does
self
.
send_response
(
301
)
self
.
send_header
(
"Location"
,
self
.
path
+
"/"
)
self
.
end_headers
()
return
None
for
index
in
"index.html"
,
"index.htm"
:
index
=
pathjoin
(
path
,
index
)
if
self
.
_fs
.
exists
(
index
):
path
=
index
break
else
:
return
self
.
list_directory
(
path
)
ctype
=
self
.
guess_type
(
path
)
try
:
info
=
self
.
_fs
.
getinfo
(
path
)
f
=
self
.
_fs
.
open
(
path
,
'r'
)
except
FSError
:
self
.
send_error
(
404
,
"File not found"
)
return
None
self
.
send_response
(
200
)
self
.
send_header
(
"Content-type"
,
ctype
)
self
.
send_header
(
"Content-Length"
,
str
(
info
[
'size'
]))
if
'modified_time'
in
info
:
self
.
send_header
(
"Last-Modified"
,
self
.
date_time_string
(
_datetime_to_epoch
(
info
[
'modified_time'
])))
self
.
end_headers
()
return
f
def
list_directory
(
self
,
path
):
"""Helper to produce a directory listing (absent index.html).
Return value is either a file object, or None (indicating an
error). In either case, the headers are sent, making the
interface the same as for send_head().
"""
try
:
dir_paths
=
self
.
_fs
.
listdir
(
path
,
dirs_only
=
True
)
file_paths
=
self
.
_fs
.
listdir
(
path
,
files_only
=
True
)
except
FSError
:
self
.
send_error
(
404
,
"No permission to list directory"
)
return
None
paths
=
[
p
+
'/'
for
p
in
sorted
(
dir_paths
,
key
=
lambda
p
:
p
.
lower
())]
+
sorted
(
file_paths
,
key
=
lambda
p
:
p
.
lower
())
#list.sort(key=lambda a: a.lower())
f
=
StringIO
()
displaypath
=
cgi
.
escape
(
urllib
.
unquote
(
self
.
path
))
f
.
write
(
'<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">'
)
f
.
write
(
"<html>
\n
<title>Directory listing for
%
s</title>
\n
"
%
displaypath
)
f
.
write
(
"<body>
\n
<h2>Directory listing for
%
s</h2>
\n
"
%
displaypath
)
f
.
write
(
"<hr>
\n
<ul>
\n
"
)
parent
=
dirname
(
path
)
if
path
!=
parent
:
f
.
write
(
'<li><a href="
%
s">../</a></li>'
%
urllib
.
quote
(
parent
.
rstrip
(
'/'
)
+
'/'
))
for
path
in
paths
:
f
.
write
(
'<li><a href="
%
s">
%
s</a>
\n
'
%
(
urllib
.
quote
(
path
),
cgi
.
escape
(
path
)))
f
.
write
(
"</ul>
\n
<hr>
\n
</body>
\n
</html>
\n
"
)
length
=
f
.
tell
()
f
.
seek
(
0
)
self
.
send_response
(
200
)
self
.
send_header
(
"Content-type"
,
"text/html"
)
self
.
send_header
(
"Content-Length"
,
str
(
length
))
self
.
end_headers
()
return
f
def
translate_path
(
self
,
path
):
# abandon query parameters
path
=
path
.
split
(
'?'
,
1
)[
0
]
path
=
path
.
split
(
'#'
,
1
)[
0
]
path
=
posixpath
.
normpath
(
urllib
.
unquote
(
path
))
return
path
def
serve_fs
(
fs
,
address
=
''
,
port
=
8000
):
def
Handler
(
request
,
client_address
,
server
):
return
FSHTTPRequestHandler
(
fs
,
request
,
client_address
,
server
)
#class ThreadedTCPServer(SocketServer.ThreadingMixIn, SocketServer.TCPServer):
# pass
httpd
=
SocketServer
.
TCPServer
((
address
,
port
),
Handler
,
bind_and_activate
=
False
)
#httpd = ThreadedTCPServer((address, port), Handler, bind_and_activate=False)
httpd
.
allow_reuse_address
=
True
httpd
.
server_bind
()
httpd
.
server_activate
()
server_thread
=
threading
.
Thread
(
target
=
httpd
.
serve_forever
)
server_thread
.
setDaemon
(
True
)
server_thread
.
start
()
try
:
while
True
:
time
.
sleep
(
0.1
)
except
(
KeyboardInterrupt
,
SystemExit
):
httpd
.
shutdown
()
if
__name__
==
"__main__"
:
from
fs.osfs
import
OSFS
serve_fs
(
OSFS
(
'~/'
))
\ No newline at end of file
fs/opener.py
0 → 100644
View file @
4c9f9711
This diff is collapsed.
Click to expand it.
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