La classe Message

La classe Message viene utilizzata per definire i messaggi per una trasmissione efficiente nella rete o nello spazio di processo. I messaggi vengono definiti utilizzando le classi di campi.

Message è fornito dal modulo protorpc.messages.

Introduzione

I messaggi sono più limitati rispetto alle classi normali, in quanto possono contenere solo attributi di campo e altre definizioni di messaggi ed enum. Queste limitazioni sono in vigore perché la struttura della classe Message stessa è pensata per essere trasmessa attraverso la rete o lo spazio di processo e utilizzata direttamente dai client o anche da altri server. Pertanto, i metodi e gli attributi non di campo non possono essere trasmessi con le informazioni strutturali, il che causa discrepanze tra le diverse lingue e implementazioni.

Inizializzazione e convalida

Un oggetto Message viene considerato inizializzato se contiene tutti i campi obbligatori e anche tutti i messaggi nidificati sono inizializzati.

La chiamata a "check_initialized" genererà un ValidationError se non è inizializzato; "is_initialized" restituisce un valore booleano che indica se è valido.

Google Protocol RPC convalida automaticamente gli oggetti Message quando vengono creati e compilati. La tua applicazione può verificare se un determinato valore è compatibile con un campo a cui è assegnato utilizzando il metodo validate() dell'istanza del campo. Se utilizzato in un messaggio, questo metodo verifica che tutti i valori di un messaggio e dei relativi messaggi secondari siano validi. L'assegnazione di un valore non valido a un campo genera un ValidationError.

L'esempio seguente crea e inizializza gli oggetti Message in un'applicazione fittizia di compravendita di azioni.

from protorpc import messages

# Trade type.
class TradeType(messages.Enum):
    BUY = 1
    SELL = 2
    SHORT = 3
    CALL = 4

class Lot(messages.Message):
    price = messages.IntegerField(1, required=True)
    quantity = messages.IntegerField(2, required=True)

class Order(messages.Message):
    symbol = messages.StringField(1, required=True)
    total_quantity = messages.IntegerField(2, required=True)
    trade_type = messages.EnumField(TradeType, 3, required=True)
    lots = messages.MessageField(Lot, 4, repeated=True)
    limit = messages.IntegerField(5)

order = Order(symbol='GOOG',
              total_quantity=10,
              trade_type=TradeType.BUY)

lot1 = Lot(price=304,
           quantity=7)

lot2 = Lot(price=305,
           quantity=3)

order.lots = [lot1, lot2]

# Now object is initialized!
order.check_initialized()

Costruttore

Il costruttore della classe Message è definito come segue:

class Message(**kwargs)

Inizializza lo stato dei messaggi interni.

Un'applicazione inizializza un messaggio tramite il costruttore passando argomenti di parole chiave corrispondenti alle classi di campi. Ad esempio:

class Date(Message)
    day = IntegerField(1)
    month = IntegerField(2)
    year = IntegerField(3)

Dopo aver definito il campo della classe, puoi richiamare i valori dei campi in modo conciso. Le seguenti due invocazioni sono equivalenti:

date = Date(day=6, month=6, year=1911)

È equivalente a:

date = Date()
date.day = 6
date.month = 6
date.year = 1911

Metodi della classe

La classe Message fornisce i seguenti metodi di classe:

all_fields()
Recupera tutti gli oggetti di definizione dei campi. Restituisce un iteratore su tutti i valori in ordine arbitrario.
field_by_name(name)
Recupera i campi per nome. Restituisce un oggetto Field associato al nome.
Genera un KeyError se non viene trovato alcun campo con quel nome.
field_by_number(number)
Recupera un campo in base al numero. Restituisce l'oggetto campo associato a quel numero.
Genera un KeyError se non viene trovato alcun campo con quel numero.

Metodi dell'istanza

Le istanze di messaggi hanno i seguenti metodi:

check_initialized()
Verifica che tutti i campi obbligatori siano inizializzati.
Genera un ValidationError se l'oggetto Message non è inizializzato.
get_assigned_value(name)
Recupera il valore assegnato di un attributo. Se il valore non è impostato, restituisce None.
Argomenti:
name
Nome dell'attributo da ottenere.

Restituisce il valore assegnato di un attributo o None se l'attributo non ha un valore assegnato.

is_initialized(name)
Recupera lo stato di inizializzazione dell'oggetto Message. Restituisce True se il messaggio è valido, altrimenti restituisce False.
reset(name)
Reimposta il valore assegnato per un campo, che ripristina il valore predefinito o, se non è presente alcun valore predefinito, Nessuno.
Argomenti:
name
Nome del campo da reimpostare.