Python: атрибут дочернего класса не прилипает - PullRequest
0 голосов
/ 16 октября 2018

Я пытаюсь работать с классами, но все еще плохо знаком с ними.Я не понимаю, как наследовать атрибуты родительского класса, а также инициализировать новые атрибуты дочернего класса.Я считаю, что родительские атрибуты могут вызываться, но не дочерние атрибуты, которые я определяю.Пожалуйста, смотрите мой код ниже:

import random
import hashlib
import base64
import requests
import json
import urllib3
import getpass

# Disable warning re: server certificate checking turned off
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)

class vsa:
    def __init__(self):
        self.vsa_token = self.api_authentication()
        self.headers = {'Authorization': "Bearer " + self.vsa_token}
        self.url = "example.com"

    def api_authentication(self):
        while True: 
            username = input("Enter your username: ")
            password = getpass.getpass("Enter your password: ")

            vsa = "example.com/api/auth"
            random_integer = random.randint(5000, 50000)
            CoveredSHA256HashTemp_object = hashlib.sha256()
            CoveredSHA256HashTemp_object.update(('%s%s' % (password, username)).encode('utf-8'))
            CoveredSHA256HashTemp = CoveredSHA256HashTemp_object.hexdigest()
            CoveredSHA256Hash_object = hashlib.sha256()
            CoveredSHA256Hash_object.update(('%s%d' % (CoveredSHA256HashTemp, random_integer)).encode('utf-8'))
            CoveredSHA256Hash = CoveredSHA256Hash_object.hexdigest()
            CoveredSHA1HashTemp_object = hashlib.sha1()
            CoveredSHA1HashTemp_object.update(('%s%s' % (password, username)).encode('utf-8'))
            CoveredSHA1HashTemp = CoveredSHA1HashTemp_object.hexdigest()
            CoveredSHA1Hash_object = hashlib.sha1()
            CoveredSHA1Hash_object.update(('%s%d' % (CoveredSHA1HashTemp, random_integer)).encode('utf-8'))
            CoveredSHA1Hash = CoveredSHA1Hash_object.hexdigest()
            auth = "user=%s, pass2=%s, pass1=%s, rpass2=%s, rpass1=%s, rand2=%d, twofapass=:undefined" % (username, CoveredSHA256Hash, CoveredSHA1Hash, CoveredSHA1Hash, CoveredSHA256Hash, random_integer)
            encode = base64.urlsafe_b64encode(('%s' % auth).encode('UTF-8')).decode('ascii')
            headers = { 'Authorization' : 'Basic %s' %  encode }
            r = requests.get(vsa, headers=headers, verify=False)

            data = r.text

            parsed_data = json.loads(data)
            if parsed_data['ResponseCode'] == 0:
                print("\nVSA token successfully retrieved\n")
                vsa_token = parsed_data['Result']['Token']
                return vsa_token
            else:
                print("Unauthorized")


    def get_vsa_token(self):
        return self.vsa_token

class agents(vsa):

    def __init___(self):
        vsa.__init__(self)
        self.call = "/asetmgmt/agents"

    def get_agents(self):
        list_agents = []
        r = requests.get(self.url + self.call, headers=self.headers, verify=False)
        data = r.text
        parsed_data = json.loads(data)
        all_agents = parsed_data
        for agents in all_agents['Result']:
                    list_agents.append((agents['AgentName']))
        return list_agents

session = agents()
print(session.call)

Последняя команда - print(session.call) дает мне следующий вывод:

AttributeError: 'agents' object has no attribute 'call'

Тем не менее, я принял (что я считаю)Соответствующие фрагменты этого кода и запустить его через PythonTutor, и увидеть, что атрибут вызова инициализируется?

PythonTutor Ссылка на код

Я в растерянности для чегоЯ делаю не такЯ обнаружил, что могу инициализировать переменную вне блока agents.__init__(self), и это прекрасно работает:

class agents(vsa):

    call = "/assetmgmt/agents"

    def __init___(self):
        vsa.__init__(self)

, но теперь это что-то концептуальное, что беспокоит меня.Я глуп в том, как я это структурирую?Как бы вы лучше структурировали?

Спасибо за любые идеи, которые вы можете предоставить.

1 Ответ

0 голосов
/ 16 октября 2018

Спасибо @Blckknght, который предоставил мне решение, которое заключается в исправлении опечатки, которую я сделал ...

__init___! = __init__

Это всегда простые вещи, которыеупускаются из виду.Я рад, что разместил здесь вопрос, а не постоянно отлаживал и пробовал другие решения (что я делал, вероятно, в течение 30 предательских минут).

Спасибо!

...