A minimal example of a connector using the service-integration SDK
- Java 8
- Docker
- Mysql running on
localhost:3306
withroot/password
- run
ChattyPieConnectorApplication
./mvnw spring-boot:run
This starts the connector application's http server and exposes the main
endpoint localhost:8080/api/v1/integration/processEvent
which a marketplace
can send event notifications to.
- By default, it starts on port
8080
. - To override, add the
-Dserver.port=XXXX
jvm arg
By default the application is expecting a MySQL instance to be running
at localhost:3306
and a smtp server running on localhost:3025
.
If you do not have both, we offer a docker compose file at the root. Run it with
docker-compose up
To verify that the server is running correctly, check if a GET request at the /health
endpoint of a running CPC instance. For example, if the connector were deployed at https://example.com the health
endpoint would be https://example.com/health and it would be expected to return returns 200(OK) if the server is
up and running.
Let's say you want to add a new column to the company_account
table and expose it as a field in the CompanyAccount
bean.
Let's walk through the process required for that.
- Add
.sql
migration file insrc/main/resources/db.migration/
: this new file should contain the addition of your new column. - Run the migrations against your local db. To do this, start the app -
./mvnw spring-boot:run
.
- Classes such as
CompanyAccount
andChatroomCreationRecord
are beans generated byQueryDSL
based on your database tables. - When making table changes, you need to regenerate the beans so they reflect the new table state.
- Regenerate the beans with:
mvn clean generate-sources -DskipDbCodeGeneration=false
- This assumes a default db at localhost:3306 with
root/password
. - Optional params available to override those defaults are:
-Dmodel.source.db.username=[your-local-db-user]
-Dmodel.source.db.password=[your-local-db-password]
-Dmodel.source.db.url=[connection-string-for-your-db-here]
- This assumes a default db at localhost:3306 with
- The updated sources will be regenerated in
src/main/java/com/chattypie/persistence/model
- Commit the updated files like any other sources.
- Note: keep in mind this entire package is autogenerated, so do not edit any code in it: your changes will be overridden the next time someone regenerates the beans.
Using the versions
maven plugin, you can keep
your dependencies & maven plugins up-to-date. Most of those commands directly modify your pom.xml
.
- update the
spring-boot
parent version:./mvnw versions:update-parent
- update all dependencies:
./mvnw versions:use-latest-releases
- Warning: this might take a long time to complete
- display available maven plugin updates
./mvnw versions:display-plugin-updates
- If newer versions are available, you will need to manually update
pom.xml
.
- If newer versions are available, you will need to manually update