You can publish a CloudEvents event directly to an Eventarc Advanced
bus in a supported format using the Google Cloud CLI or by sending a request to
the Eventarc Publishing REST API. You can also use the
Eventarc client libraries
to access the Eventarc APIs from a supported language.
Before using any of the request data,
make the following replacements:
The full resource name of the bus in the format
projects/PROJECT_ID/locations/LOCATION/messageBuses/BUS_NAME
Replace the following:
PROJECT_ID: the Google Cloud
project ID for the bus project.
LOCATION: the
region in which the bus is
deployed—for example, us-central1.
BUS_NAME: the name of
the bus to which to publish the event.
SPEC_VERSION: the version of the
CloudEvents specification which the event uses—for example, 1.0.
EVENT_TYPE: the type of event related
to the originating occurrence.
EVENT_SOURCE: the event source of a
published event.
EVENT_ID: the event identifier.
Producers must ensure that source + id is unique for each distinct
event.
CONTENT_TYPE (optional): the content
type of data value. If a JSON format event has no datacontenttype
attribute, then it is assumed that the data is a JSON value conforming to the
application/json media type.
DATA_PAYLOAD (optional): the event
payload encoded into the media format specified by datacontenttype and adhering to
dataschema when those attributes are present.
To send your request, expand one of these options:
curl (Linux, macOS, or Cloud Shell)
Save the request body in a file named request.json.
Run the following command in the terminal to create or overwrite
this file in the current directory:
Save the request body in a file named request.json.
Run the following command in the terminal to create or overwrite
this file in the current directory:
Copy the request body and open the
method reference page.
The APIs Explorer panel opens on the right side of the page.
You can interact with this tool to send requests.
Paste the request body in this tool, complete any other required fields, and click Execute.
If successful, the server returns an HTTP 200 OK status code and the empty response
body in JSON format:
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-04-02 UTC."],[[["Eventarc Advanced allows direct publishing of CloudEvents to an Eventarc bus using the Google Cloud CLI or the Eventarc Publishing REST API."],["The `gcloud beta eventarc message-buses publish` command facilitates event publishing, supporting Avro, JSON, or individual event data with attributes."],["The REST API's `projects.locations.messageBuses.publish` method can be used to publish events, requiring a JSON message body that specifies event attributes like `specversion`, `type`, `source`, and `id`."],["The gcloud CLI can be used through the terminal and the REST API through curl (Linux, macOS, or Cloud Shell), Powershell (Windows), and the API explorer (browser)."],["Eventarc Advanced is currently a Pre-GA feature and is subject to limited support."]]],[]]