Skip to content

A translator for events between the Eiffel event protocol and the CDEvents protocol

License

Notifications You must be signed in to change notification settings

eiffel-community/eiffel-translator-cdevents

Eiffel Community Repository Template

Sandbox badge

Eiffel Translator CDEvents

A translator for events between the Eiffel event protocol and the CDEvents protocol.

CDEvents builds upon CloudEvents and listens on HTTP bindings.

Translate CDEvents to Eiffel events:

  • The translator API (http://<eiffel-translator-cdevents-host:port>/translate/eiffel) needs to be subscribed with the specific CloudEvents broker to receive the CDEvents of different types.
  • When this translator (/translate/eiffel) receives a CDEvent from configured CloudEvents broker (cloudevent.broker.url), the CDEvent will be translated to a mapped Eiffel event and send to the RabbitMQ message broker through configured RemRemPublish URL (remrem.publish.url).

Translate Eiffel events to CDEvents:

  • This translator is implemented with an AMQP RabbitMQ listener, which receives the Eiffel events from configured Rabbit MQ host (rabbitmq.host) and exchange(rabbitmq.exchange) with specific routing filters configured (rabbitmq.routingkey)
  • When this translator receives an Eiffel event, the Eiffel event will be translated to a mapped CDEvent and send to the configured CloudEvents broker (cloudevent.broker.url)

Code of Conduct and Contributing

To get involved, please see Code of Conduct and contribution guidelines.

Note that these files are located in the .github repository. See this page for further details regarding default community health files.

About this repository

The contents of this repository are licensed under the Apache License 2.0.

About Eiffel

This repository forms part of the Eiffel Community. Eiffel is a protocol for technology agnostic machine-to-machine communication in continuous integration and delivery pipelines, aimed at securing scalability, flexibility and traceability. Eiffel is based on the concept of decentralized real time messaging, both to drive the continuous integration and delivery system and to document it.

Visit Eiffel Community to get started and get involved.

How to Run

Configure RabbitMQ, CloudEvents broker and Eiffel REMReM Publish URLs in the application.properties

#RabbitMQ host details
rabbitmq.host=127.0.0.1
rabbitmq.username=myuser
rabbitmq.password=myuser
rabbitmq.exchange=ei-poc-4
rabbitmq.routingkey=#

#CloudEvent broker
cloudevent.broker.url=http://127.0.0.1:8090/default/events-broker

#Eiffel-remrem-publish
remrem.publish.url=http://127.0.0.1:8096/generateAndPublish

Go to the root directory of the Eiffel Translator CDEvents source and run the Spring boot command

./mvnw spring-boot:run

The Eiffel Translator CDEvents application boots up with connecting to RabbitMQ on port 5672 and declaring RabbitMQ Queue for receiving Eiffel messages.

The Eiffel Translator CDEvents application will be running and accessible on http://127.0.0.1:8080/translate/

Now the endpoint URL http://127.0.0.1:8080/translate/eiffel can be subscribed with CloudEvents broker to receive CDEvents

The Eiffel Translator CDEvents application can be run on Docker container with the below commands from the root directory

./mvnw spring-boot:build-image -Dspring-boot.build-image.imageName=eiffel/eiffel-translator-cdevents

docker run -d -p 8080:8080 -t eiffel/eiffel-translator-cdevents

Check Eiffel CDEvents mapping to know how different Eiffel events map to CDEvents

About

A translator for events between the Eiffel event protocol and the CDEvents protocol

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published