Beispiel #1
0
def rz_mainpage(rzdoc_name=None):
    """
    Main application load function.

    [!] Do not use as a flask endpoint as multiple functions redirect here
    """

    # fetch rz_username for welcome message
    email_address = session.get('username')
    rz_username = "******"
    role_set = []
    if None != email_address:  # session cookie passed & contains uid (email_address)
        try:
            _uid, u_account = current_app.user_db.lookup_user__by_email_address(
                email_address)
        except Exception as e:
            # may occur on user_db reset or malicious cookie != stale cookie,
            # for which the user would at least be known to the user_db
            # FIXME: remove the cookie
            pass
        else:
            role_set = u_account.role_set
            rz_username = escape(u_account.rz_username)

    rz_config = current_app.rz_config
    if None == rzdoc_name:
        s_rzdoc_name = rz_config.rzdoc__mainpage_name
    else:
        try:
            s_rzdoc_name = sanitize_input__rzdoc_name(rzdoc_name)
        except Exception as e:
            log.exception(e)
            return common_resp_handle__client_error(status=404)

    # establish rz_config template values
    host_addr, host_port = request.host_sock_addr[0], request.host_sock_addr[1]
    rz_config = {
        'rz_config__rzdoc_cur__name': s_rzdoc_name,
        'rz_config__rzdoc__mainpage_name': rz_config.rzdoc__mainpage_name,
        'rz_config__hostname': host_addr,
        'rz_config__port': host_port,
        'rz_config__optimized_main':
        'true' if rz_config.optimized_main else 'false',
        'rz_config__role_set': role_set,
        'fragment_d_path': rz_config.fragment_d_path,
    }
    return render_template('index.html', rz_username=rz_username, **rz_config)
Beispiel #2
0
def rz_mainpage(rzdoc_name=None):
    """
    Main application load function.

    [!] Do not use as a flask endpoint as multiple functions redirect here
    """

    # fetch rz_username for welcome message
    email_address = session.get('username')
    rz_username = "******"
    role_set = []
    if None != email_address:  # session cookie passed & contains uid (email_address)
        try:
            _uid, u_account = current_app.user_db.lookup_user__by_email_address(email_address)
        except Exception as e:
            # may occur on user_db reset or malicious cookie != stale cookie,
            # for which the user would at least be known to the user_db
            # FIXME: remove the cookie
            pass
        else:
            role_set = u_account.role_set
            rz_username = escape(u_account.rz_username)

    rz_config = current_app.rz_config
    if None == rzdoc_name:
        s_rzdoc_name = rz_config.rzdoc__mainpage_name
    else:
        try:
            s_rzdoc_name = sanitize_input__rzdoc_name(rzdoc_name)
        except Exception as e:
            log.exception(e)
            return common_resp_handle__client_error(status=404)

    # establish rz_config template values
    host_addr, host_port = request.host_sock_addr[0], request.host_sock_addr[1]
    rz_config = {'rz_config__rzdoc_cur__name': s_rzdoc_name,
                 'rz_config__rzdoc__mainpage_name': rz_config.rzdoc__mainpage_name,
                 'rz_config__hostname': host_addr,
                 'rz_config__port': host_port,
                 'rz_config__optimized_main': 'true' if rz_config.optimized_main else 'false',
                 'rz_config__role_set': role_set,
                 'fragment_d_path': rz_config.fragment_d_path,
                 }
    return render_template('index.html', rz_username=rz_username, **rz_config)
Beispiel #3
0
def diff_commit__topo():
    """
    REST API wrapper around diff_commit__topo():
       - extract topo_diff from request
       - handle success/error outcomes
    """
    def sanitize_input(req):
        rzdoc_name = request.get_json().get('rzdoc_name')
        topo_diff_dict = request.get_json()['topo_diff']
        topo_diff = Topo_Diff.from_json_dict(topo_diff_dict)

        sanitize_input__topo_diff(topo_diff)
        return rzdoc_name, topo_diff

    rzdoc_name, topo_diff = sanitize_input(request)
    if topo_diff.is_empty():
        return common_resp_handle__client_error()

    ctx = __context__common(rzdoc_name)
    kernel = flask.current_app.kernel
    _, commit_ret = kernel.diff_commit__topo(topo_diff, ctx)
    return common_resp_handle__success(data=commit_ret)
Beispiel #4
0
def diff_commit__topo():
    """
    REST API wrapper around diff_commit__topo():
       - extract topo_diff from request
       - handle success/error outcomes
    """
    def sanitize_input(req):
        rzdoc_name = request.get_json().get('rzdoc_name')
        topo_diff_dict = request.get_json()['topo_diff']
        topo_diff = Topo_Diff.from_json_dict(topo_diff_dict)

        sanitize_input__topo_diff(topo_diff)
        return rzdoc_name, topo_diff

    rzdoc_name, topo_diff = sanitize_input(request)
    if topo_diff.is_empty():
        return common_resp_handle__client_error()

    ctx = __context__common(rzdoc_name)
    kernel = flask.current_app.kernel
    _, commit_ret = kernel.diff_commit__topo(topo_diff, ctx)
    return common_resp_handle__success(data=commit_ret)