Page Menu
Home
Software Heritage
Search
Configure Global Search
Log In
Files
F9125903
main.py
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
4 KB
Subscribers
None
main.py
View Options
# Copyright (C) 2015 The Software Heritage developers
# See the AUTHORS file at the top-level directory of this distribution
# License: GNU Affero General Public License version 3, or any later version
# See top-level LICENSE file for more information
import
logging
import
os
import
json
from
flask
import
Flask
from
swh.core
import
config
from
swh.web.ui.renderers
import
RENDERERS
,
urlize_api_links
from
swh.web.ui.renderers
import
safe_docstring_display
from
swh.web.ui.renderers
import
revision_id_from_url
from
swh.web.ui.renderers
import
SWHMultiResponse
from
swh.storage
import
get_storage
DEFAULT_CONFIG
=
{
'storage_args'
:
(
'list[str]'
,
[
'http://localhost:5000/'
]),
'storage_class'
:
(
'str'
,
'remote_storage'
),
'log_dir'
:
(
'string'
,
'/tmp/swh/log'
),
'debug'
:
(
'bool'
,
None
),
'host'
:
(
'string'
,
'127.0.0.1'
),
'port'
:
(
'int'
,
6543
),
'secret_key'
:
(
'string'
,
'development key'
),
'max_log_revs'
:
(
'int'
,
25
),
}
# api's definition
app
=
Flask
(
__name__
)
app
.
response_class
=
SWHMultiResponse
app
.
jinja_env
.
filters
[
'urlize_api_links'
]
=
urlize_api_links
app
.
jinja_env
.
filters
[
'safe_docstring_display'
]
=
safe_docstring_display
app
.
jinja_env
.
filters
[
'revision_id_from_url'
]
=
revision_id_from_url
def
read_config
(
config_file
):
"""Read the configuration file `config_file`, update the app with
parameters (secret_key, conf) and return the parsed configuration as a
dict"""
conf
=
config
.
read
(
config_file
,
DEFAULT_CONFIG
)
config
.
prepare_folders
(
conf
,
'log_dir'
)
conf
[
'storage'
]
=
get_storage
(
conf
[
'storage_class'
],
conf
[
'storage_args'
])
return
conf
def
load_controllers
():
"""Load the controllers for the application.
"""
from
swh.web.ui
import
views
,
apidoc
# flake8: noqa
def
rules
():
"""Returns rules from the application in dictionary form.
Beware, must be called after swh.web.ui.main.load_controllers funcall.
Returns:
Generator of application's rules.
"""
for
rule
in
app
.
url_map
.
_rules
:
yield
{
'rule'
:
rule
.
rule
,
'methods'
:
rule
.
methods
,
'endpoint'
:
rule
.
endpoint
}
def
storage
():
"""Return the current application's storage.
"""
return
app
.
config
[
'conf'
][
'storage'
]
def
run_from_webserver
(
environ
,
start_response
):
"""Run the WSGI app from the webserver, loading the configuration.
Note: This function is called on a per-request basis so beware the side
effects here!
"""
load_controllers
()
config_path
=
'/etc/softwareheritage/webapp/webapp.ini'
conf
=
read_config
(
config_path
)
app
.
secret_key
=
conf
[
'secret_key'
]
app
.
config
[
'conf'
]
=
conf
app
.
config
[
'DEFAULT_RENDERERS'
]
=
RENDERERS
logging
.
basicConfig
(
filename
=
os
.
path
.
join
(
conf
[
'log_dir'
],
'web-ui.log'
),
level
=
logging
.
INFO
)
return
app
(
environ
,
start_response
)
def
run_debug_from
(
config_path
,
verbose
=
False
):
"""Run the api's server in dev mode.
Note: This is called only once (contrast with the production mode
in run_from_webserver function)
Args:
conf is a dictionary of keywords:
- 'db_url' the db url's access (through psycopg2 format)
- 'content_storage_dir' revisions/directories/contents storage on disk
- 'host' to override the default 127.0.0.1 to open or not the server
to the world
- 'port' to override the default of 5000 (from the underlying layer:
flask)
- 'debug' activate the verbose logs
- 'secret_key' the flask secret key
Returns:
Never
"""
load_controllers
()
conf
=
read_config
(
config_path
)
app
.
secret_key
=
conf
[
'secret_key'
]
app
.
config
[
'conf'
]
=
conf
app
.
config
[
'DEFAULT_RENDERERS'
]
=
RENDERERS
host
=
conf
.
get
(
'host'
,
'127.0.0.1'
)
port
=
conf
.
get
(
'port'
)
debug
=
conf
.
get
(
'debug'
)
log_file
=
os
.
path
.
join
(
conf
[
'log_dir'
],
'web-ui.log'
)
logging
.
basicConfig
(
level
=
logging
.
DEBUG
if
verbose
else
logging
.
INFO
,
handlers
=
[
logging
.
FileHandler
(
log_file
),
logging
.
StreamHandler
()])
app
.
run
(
host
=
host
,
port
=
port
,
debug
=
debug
)
File Metadata
Details
Attached
Mime Type
text/x-python
Expires
Jun 21 2025, 9:28 PM (4 w, 2 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3402172
Attached To
rDWAPPS Web applications
Event Timeline
Log In to Comment