With notifications, business moments are communicated to all interested listeners a.k.a. subscribers of those event streams. eBay's most recent notification payloads are also secured using ECC signature headers.
This OpenAPI powered springboot SDK is designed to simplify processing eBay notifications. The application receives subscribed messages, validates the integrity of the message using the X-EBAY-SIGNATURE header and delegates to a custom configurable MessageProcessor for plugging in usecase specific processing logic.
This SDK is intended for the latest eBay notifications that use ECC signatures and JSON payloads. While this SDK is generic for any topics, it currently includes the schema definition for ACCOUNT_DELETION notifications.
This SDK is intended to bootstrap subscriptions to eBay Notifications and provides a ready springboot deployable. This SDK incorporates
- A deployable application that is generic across topics and can process incoming https notifications
- Allows registration of custom Message Processors.
- Declarative OpenAPI powered schema definitions and code generation
- Verify the integrity of the incoming messages
- Use key id from the decoded signature header to fetch public key required by the verification algorithm. An LRU cache is used to prevent refetches for same 'key'.
- On verification success, delegate processing to the registered custom message processor and respond with a 204 HTTP status code.
- On verification failure, respond back with a 412 HTTP status code
Prerequisites
maven: version 3.5.0 (or later)
jdk: 8
Install
mvn clean install
Configure
* Update application.yaml with path to client credentials (required to fetch Public Key from /commerce/notification/v1/public_key/{public_key_id}).
* Specify environment (PRODUCTION or SANDBOX). Default: PRODUCTION
For ACCOUNT_DELETION use case simply implement custom logic in AccountDeletionMessageProcessor.processInternal()
Onboard any new topic in 3 simple steps! :
- Add schema definition for new topic data to data.yaml
- Add a custom MessageProcessor for new topic that extends 'BaseMessageProcessor' abstract class and implement 'processInternal(T data)'
- Register the new MessageProcessor in NotificationConfig.registerMessageProcessors()
Run
java -jar target/notification-sdk-1.0.0-RELEASE.jar
Client Credentials Configuration Sample: ebay-config.yaml.
Production deploys
For production deploys please enable HTTPS.
Uses standard slf4j logging.
Once AsyncAPI opensource tooling supports an ability to limit code generation to models only from a subscriber facing contract, will switch the implementation to use AsyncAPI contracts exclusively. The schema definitions are externalized so a transition to AsyncAPI codegen would be trivial.
Copyright 2021 eBay Inc.
Developer: Sekhar Banerjee
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.