mirror of
https://github.com/getpelican/pelican.git
synced 2025-10-15 20:28:56 +02:00
Adding ability to listen on addresses other than localhost.
This is helpful for mobile testing of Pelican sites by allowing broadcasting on the local network. Using port 80 requires running as root on most machines.
This commit is contained in:
parent
b72961f12d
commit
3d8ceb1c67
2 changed files with 35 additions and 25 deletions
|
|
@ -12,7 +12,8 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
import socketserver # NOQA
|
import socketserver # NOQA
|
||||||
|
|
||||||
PORT = len(sys.argv) == 2 and int(sys.argv[1]) or 8000
|
PORT = len(sys.argv) in (2, 3) and int(sys.argv[1]) or 8000
|
||||||
|
SERVER = len(sys.argv) == 3 and sys.argv[2] or ""
|
||||||
SUFFIXES = ['', '.html', '/index.html']
|
SUFFIXES = ['', '.html', '/index.html']
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -38,13 +39,13 @@ Handler = ComplexHTTPRequestHandler
|
||||||
|
|
||||||
socketserver.TCPServer.allow_reuse_address = True
|
socketserver.TCPServer.allow_reuse_address = True
|
||||||
try:
|
try:
|
||||||
httpd = socketserver.TCPServer(("", PORT), Handler)
|
httpd = socketserver.TCPServer((SERVER, PORT), Handler)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
logging.error("Could not listen on port %s", PORT)
|
logging.error("Could not listen on port %s, server %s", PORT, SERVER)
|
||||||
sys.exit(getattr(e, 'exitcode', 1))
|
sys.exit(getattr(e, 'exitcode', 1))
|
||||||
|
|
||||||
|
|
||||||
logging.info("Serving at port %s", PORT)
|
logging.info("Serving at port %s, server %s", PORT, SERVER)
|
||||||
try:
|
try:
|
||||||
httpd.serve_forever()
|
httpd.serve_forever()
|
||||||
except KeyboardInterrupt as e:
|
except KeyboardInterrupt as e:
|
||||||
|
|
|
||||||
|
|
@ -40,6 +40,7 @@ help:
|
||||||
@echo ' make regenerate regenerate files upon modification '
|
@echo ' make regenerate regenerate files upon modification '
|
||||||
@echo ' make publish generate using production settings '
|
@echo ' make publish generate using production settings '
|
||||||
@echo ' make serve [PORT=8000] serve site at http://localhost:8000'
|
@echo ' make serve [PORT=8000] serve site at http://localhost:8000'
|
||||||
|
@echo ' make serve-global [SERVER=0.0.0.0] serve (as root) to $(SERVER):80 '
|
||||||
@echo ' make devserver [PORT=8000] start/restart develop_server.sh '
|
@echo ' make devserver [PORT=8000] start/restart develop_server.sh '
|
||||||
@echo ' make stopserver stop local server '
|
@echo ' make stopserver stop local server '
|
||||||
@echo ' make ssh_upload upload the web site via SSH '
|
@echo ' make ssh_upload upload the web site via SSH '
|
||||||
|
|
@ -50,7 +51,7 @@ help:
|
||||||
@echo ' make cf_upload upload the web site via Cloud Files'
|
@echo ' make cf_upload upload the web site via Cloud Files'
|
||||||
@echo ' make github upload the web site via gh-pages '
|
@echo ' make github upload the web site via gh-pages '
|
||||||
@echo ' '
|
@echo ' '
|
||||||
@echo 'Set the DEBUG variable to 1 to enable debugging, e.g. make DEBUG=1 html'
|
@echo 'Set the DEBUG variable to 1 to enable debugging, e.g. make DEBUG=1 html '
|
||||||
@echo ' '
|
@echo ' '
|
||||||
|
|
||||||
html:
|
html:
|
||||||
|
|
@ -69,6 +70,14 @@ else
|
||||||
cd $$(OUTPUTDIR) && $(PY) -m pelican.server
|
cd $$(OUTPUTDIR) && $(PY) -m pelican.server
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
serve-global:
|
||||||
|
ifdef SERVER
|
||||||
|
cd $$(OUTPUTDIR) && $(PY) -m pelican.server 80 $$(SERVER)
|
||||||
|
else
|
||||||
|
cd $$(OUTPUTDIR) && $(PY) -m pelican.server 80 0.0.0.0
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
devserver:
|
devserver:
|
||||||
ifdef PORT
|
ifdef PORT
|
||||||
$$(BASEDIR)/develop_server.sh restart $$(PORT)
|
$$(BASEDIR)/develop_server.sh restart $$(PORT)
|
||||||
|
|
@ -106,4 +115,4 @@ github: publish
|
||||||
ghp-import -m "Generate Pelican site" -b $(GITHUB_PAGES_BRANCH) $$(OUTPUTDIR)
|
ghp-import -m "Generate Pelican site" -b $(GITHUB_PAGES_BRANCH) $$(OUTPUTDIR)
|
||||||
git push origin $(GITHUB_PAGES_BRANCH)
|
git push origin $(GITHUB_PAGES_BRANCH)
|
||||||
|
|
||||||
.PHONY: html help clean regenerate serve devserver publish ssh_upload rsync_upload dropbox_upload ftp_upload s3_upload cf_upload github
|
.PHONY: html help clean regenerate serve serve-global devserver publish ssh_upload rsync_upload dropbox_upload ftp_upload s3_upload cf_upload github
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue