Exemplo n.º 1
0
def login(user, password, ip_addr, isHttps):
    if isHttps == "1":
        conn = httplib.HTTPSConnection(ip_addr)
    else:
        conn = httplib.HTTPConnection(ip_addr)

    auth = user + ":" + password
    auth_encoded = base64.b64encode(auth.encode())

    credential = {"Authorization": "Basic " + auth_encoded.decode(),
                  "User-Agent": "Rest-Conf"}

#    print ("being sent", credential)

    conn.request("POST", LOGIN_RESTCONF, "", credential)

    resp = conn.getresponse()
#    print resp.status
#    print resp.reason
#    page = resp.read()
#    print page
    auth = resp.getheader('authorization')

    if auth is None:
        errors = pyfos_util.set_response_parse(resp)
        if 'errors' in errors:
            return {"login-error": errors['errors']['error']['error-message']}
        elif 'server-error-message' in errors:
            return {"login-error": errors['server-error-message']}
        else:
            return {"login-error": "unknown login error"}
    else:
        return {"Authorization": auth}
Exemplo n.º 2
0
def login(user, password, ip_addr, isHttps):
    if isHttps == "self":
        conn = httplib.HTTPSConnection(
            ip_addr, context=ssl._create_unverified_context())
    elif isHttps == "CA":
        conn = httplib.HTTPSConnection(ip_addr)
    else:
        conn = httplib.HTTPConnection(ip_addr)

    auth = user + ":" + password
    auth_encoded = base64.b64encode(auth.encode())

    credential = {
        "Authorization": "Basic " + auth_encoded.decode(),
        "User-Agent": "Rest-Conf"
    }

    #    print ("being sent", credential)

    conn.request("POST", LOGIN_RESTCONF, "", credential)

    resp = conn.getresponse()
    #    print resp.reason
    #    page = resp.read()
    #    print page
    auth = resp.getheader('authorization')
    content = resp.getheader('content-type')
    contentlist = content.split(";")
    if auth is None:
        if resp.status == 404 and content in 'text/html; charset=iso-8859-1':
            return {"login-error": "Rest unsupported FOS version"}, dict()
        else:
            errors = pyfos_util.set_response_parse(resp)

        if 'client-error-message' in errors:
            return {
                "login-error":
                errors['client-errors']['errors']['error']['error-message']
            }, dict()
        elif 'server-error-message' in errors:
            return {"login-error": errors['server-error-message']}, dict()
        else:
            return {"login-error": "unknown login error"}, dict()
    else:
        if len(contentlist) == 2:
            content_type = contentlist[0]
            content_ver = contentlist[1]
        else:
            content_type = content
            content_ver = None
        return {
            "Authorization": auth
        }, {
            "content-type": content_type,
            "content-version": content_ver
        }
Exemplo n.º 3
0
def logout(credential, ip_addr, isHttps):
    if isHttps == "1":
        conn = httplib.HTTPSConnection(ip_addr)
    else:
        conn = httplib.HTTPConnection(ip_addr)

#    print credential

    conn.request("POST", LOGOUT_RESTCONF, "", credential)

    resp = conn.getresponse()
#    print resp.status
#    print resp.reason
#    page = resp.read()
#    print resp.getheaders()

    return pyfos_util.set_response_parse(resp)
Exemplo n.º 4
0
def logout(credential, ip_addr, isHttps):
    if isHttps == "self":
        conn = httplib.HTTPSConnection(
            ip_addr, context=ssl._create_unverified_context())
    elif isHttps == "CA":
        conn = httplib.HTTPSConnection(ip_addr)
    else:
        conn = httplib.HTTPConnection(ip_addr)

#    print credential

    conn.request("POST", LOGOUT_RESTCONF, "", credential)

    resp = conn.getresponse()
    #    print resp.status
    #    print resp.reason
    #    page = resp.read()
    #    print resp.getheaders()

    content = resp.getheader('content-type')
    if resp.status == 404 and content in 'text/html; charset=iso-8859-1':
        return {"login-error": "Rest unsupported FOS version"}
    return pyfos_util.set_response_parse(resp)
Exemplo n.º 5
0
def login(user,
          password,
          ip_addr,
          isHttps,
          delay,
          authtoken=None,
          sessionless=False):
    request_uri = None
    request_auth = None

    if sessionless is True:
        request_auth = "Basic "
    else:
        if authtoken is not None:
            request_uri = LOGIN_RESTCONF
            request_auth = "Custom_Auth "
        else:
            request_uri = LOGIN_RESTCONF
            request_auth = "Custom_Basic "

        if isHttps == "self":
            conn = httplib.HTTPSConnection(
                ip_addr, 443, context=ssl._create_unverified_context())
        elif isHttps == "CA":
            conn = httplib.HTTPSConnection(ip_addr, 443)
        else:
            conn = httplib.HTTPConnection(ip_addr, 80)

    if authtoken is not None:
        auth = user + ":" + authtoken.auth_token
    else:
        auth = user + ":" + password

    auth_encoded = base64.b64encode(auth.encode())

    credential = {
        "Authorization": request_auth + auth_encoded.decode(),
        "User-Agent": "Rest-Conf"
    }
    # print(credential)

    # print ("being sent", credential)
    if sessionless is True:
        # Check the content dict returned here is default
        return credential, {
            "content-type": "application/yang-data+xml",
            "content-version": None
        }
    resp = pyfos_util.bsn_request(conn, "POST", request_uri, "", credential,
                                  delay)

    #    print resp.reason
    #    page = resp.read()
    #    print page
    auth = resp.getheader('authorization')
    content = resp.getheader('content-type')
    contentlist = content.split(";")
    if auth is None:
        if resp.status == 404 and content in 'text/html; charset=iso-8859-1':
            return {"login-error": "Rest unsupported FOS version"}, dict()
        else:
            errors = pyfos_util.set_response_parse(resp)

        if 'client-error-message' in errors:
            return {
                "login-error":
                errors['client-errors']['errors']['error']['error-message']
            }, dict()
        elif 'server-error-message' in errors:
            return {"login-error": errors['server-error-message']}, dict()
        else:
            return {"login-error": "unknown login error"}, dict()
    else:
        if len(contentlist) == 2:
            content_type = contentlist[0]
            content_ver = contentlist[1]
        else:
            content_type = content
            content_ver = None
        return {
            "Authorization": auth
        }, {
            "content-type": content_type,
            "content-version": content_ver
        }