Python Blockchain - klasa transakcji

W tym rozdziale stwórzmy plik Transactionclass, aby klient mógł wysłać komuś pieniądze. Pamiętaj, że klient może być zarówno nadawcą, jak i odbiorcą pieniędzy. Gdy chcesz otrzymać pieniądze, inny nadawca utworzy transakcję i określi Twójpublicadres w nim. Definiujemy inicjalizację klasy transakcji w następujący sposób -

def __init__(self, sender, recipient, value):
   self.sender = sender
   self.recipient = recipient
   self.value = value
   self.time = datetime.datetime.now()

Plik init metoda przyjmuje trzy parametry - nadawcy public klucz odbiorcy publicklucz i kwotę do wysłania. Są one przechowywane w zmiennych instancji do wykorzystania przez inne metody. Dodatkowo tworzymy jeszcze jedną zmienną do przechowywania czasu transakcji.

Następnie piszemy metodę narzędzia o nazwie to_dictktóra łączy wszystkie cztery wyżej wymienione zmienne instancji w obiekcie słownika. Ma to na celu umieszczenie całej informacji o transakcji dostępnej za pośrednictwem jednej zmiennej.

Jak wiesz z wcześniejszego samouczka, pierwszy blok w łańcuchu bloków to plik Genesisblok. Blok Genesis zawiera pierwszą transakcję zainicjowaną przez twórcę łańcucha bloków. Tożsamość tej osoby może być utrzymywana w tajemnicy, jak w przypadku Bitcoinów. Więc kiedy ta pierwsza transakcja zostanie utworzona, twórca może po prostu wysłać swoją tożsamość jakoGenesis. Dlatego podczas tworzenia słownika sprawdzamy, czy jest to nadawcaGenesisa jeśli tak, po prostu przypisujemy wartość ciągu do zmiennej tożsamości; w przeciwnym razie przypisujemy tożsamość nadawcy do plikuidentity zmienna.

if self.sender == "Genesis":
   identity = "Genesis"
else:
   identity = self.sender.identity

Słownik konstruujemy za pomocą następującego wiersza kodu

return collections.OrderedDict({
   'sender': identity,
   'recipient': self.recipient,
   'value': self.value,
   'time' : self.time})

Cały kod dla to_dict metoda jest pokazana poniżej -

def to_dict(self):
   if self.sender == "Genesis":
      identity = "Genesis"
   else:
      identity = self.sender.identity

   return collections.OrderedDict({
      'sender': identity,
      'recipient': self.recipient,
      'value': self.value,
      'time' : self.time})

Na koniec podpiszemy ten obiekt słownika kluczem prywatnym nadawcy. Tak jak poprzednio używamy wbudowanego PKI z algorytmem SHA. Wygenerowany podpis jest dekodowany, aby uzyskać reprezentację ASCII do wydrukowania i przechowywania w naszym łańcuchu bloków. Pliksign_transaction kod metody jest pokazany tutaj -

def sign_transaction(self):
   private_key = self.sender._private_key
   signer = PKCS1_v1_5.new(private_key)
   h = SHA.new(str(self.to_dict()).encode('utf8'))
   return binascii.hexlify(signer.sign(h)).decode('ascii')

Teraz to przetestujemy Transaction klasa.

Testowanie klasy transakcji

W tym celu utworzymy dwóch użytkowników tzw Dinesh i Ramesh. Dinesh wyśle ​​5 TPCoinów do Ramesha. W tym celu najpierw tworzymy klientów o nazwie Dinesh and Ramesh.

Dinesh = Client()
Ramesh = Client()

Pamiętaj, że podczas tworzenia wystąpienia pliku Client klasa, plik public andzostaną utworzone klucze prywatne unikalne dla klienta. Ponieważ Dinesh wysyła płatność do Ramesha, będzie potrzebował klucza publicznego Ramesha, który jest uzyskiwany przy użyciu właściwości tożsamości klienta.

W ten sposób utworzymy instancję transakcji za pomocą następującego kodu -

t = Transaction(
   Dinesh,
   Ramesh.identity,
   5.0
)

Zwróć uwagę, że pierwszym parametrem jest nadawca, drugim jest klucz publiczny odbiorcy, a trzecim parametrem jest kwota do przesłania. Pliksign_transaction metoda pobiera klucz prywatny nadawcy z pierwszego parametru do podpisywania transakcji.

Po utworzeniu obiektu transakcji podpiszesz go, wywołując jego sign_transactionmetoda. Ta metoda zwraca wygenerowany podpis w formacie do druku. Generujemy i drukujemy podpis za pomocą następujących dwóch wierszy kodu -

signature = t.sign_transaction()
print (signature)

Po uruchomieniu powyższego kodu zobaczysz dane wyjściowe podobne do tego -

7c7e3c97629b218e9ec6e86b01f9abd8e361fd69e7d373c38420790b655b9abe3b575e343c7
13703ca1aee781acd7157a0624db3d57d7c2f1172730ee3f45af943338157f899965856f6b0
0e34db240b62673ad5a08c8e490f880b568efbc36035cae2e748f1d802d5e8e66298be826f5
c6363dc511222fb2416036ac04eb972

Teraz, gdy nasza podstawowa infrastruktura tworzenia klienta i transakcji jest gotowa, będziemy mieć wielu klientów wykonujących wiele transakcji, tak jak w prawdziwej sytuacji.