Event
An Event in KanthorQ represents a data transfer object (DTO) used to communicate between publishers and streams.
- Go
- PostgreSQL
type Event struct {
  Id        string   `json:"id" validate:"required"`
  Subject   string   `json:"subject" validate:"required,is_subject"`
  Body      []byte   `json:"body" validate:"required"`
  Metadata  Metadata `json:"metadata" validate:"required"`
  CreatedAt int64    `json:"created_at"`
}
-- Example of Event structure in a Stream
TABLE kanthorq_stream_order_update (
  id VARCHAR(64) NOT NULL,
  subject VARCHAR(128) NOT NULL,
  body BYTEA NOT NULL,
  metadata jsonb NOT NULL,
  created_at BIGINT NOT NULL DEFAULT EXTRACT(EPOCH FROM CURRENT_TIMESTAMP) * 1000
)
You might wonder why the Event struct is named kanthorq_stream_order_update in PostgreSQL—this is related to the Stream concept. Check the Stream Concept section for more information.
To ensure seamless communication and integration, we've established some rules that you MUST and SHOULD follow:
MUST Follow Requirements:
- 
The idproperty must be a Lexicographically Sortable Identifier. For example, if you're using UUIDs, please use UUIDv7. However, we recommend using ULID for this purpose.
- 
The subjectproperty must consist of multiple alphanumeric and hyphenated strings, separated by dots.- Correct Examples: order,order.created,v2.order.created,058434268238.order.created,-1002223543143.subscription.created,ap-southeast-1.user.created
- Incorrect Examples: order.,order.-,order..
 
- Correct Examples: 
- 
The bodyproperty stores arbitrary bytes, which only the sender and receiver can interpret. This is particularly useful for implementing end-to-end encryption, where the sender encrypts the data before sending it, and only the receiver can decrypt it.
SHOULD Follow Requirements:
- The metadataproperty should be a JSON object that stores additional information about the event. This can be used for implementing event filtering logic or as a telemetry carrier.
- The created_atproperty should contain the timestamp included in the id property. This ensures that events can be sorted chronologically by simply ordering them by their id.