This is an example implementation of the YaaS "Wishlist" service based on Java. It uses the RAML definition generated by the SDK without modifications. It shows how to implement a basic service and how to integrate with other services on YaaS.
This project is licensed under the Apache Software License, v. 2 except as noted otherwise in the LICENSE file.
You can open the API Console in a separate window by using the following link:
You can use playground
as the value for hybris-tenant
(the project ID) to use it as a sandbox when experimenting with the service.
Alternatively, you can create a project in the Builder that contains a subscription to the package "Java Jersey Wishlist Example" with the ID logvqzfhlrk5
.
This service provides REST endpoints for interacting with several YaaS Core and Commerce services.
The endpoint /wishlists
enables you to:
- Interact with wishlists in a CRUD fashion.
- Get a list of all wishlists within a tenant.
- Create a new wishlist.
- Get a specific wishlist based on an ID.
- Update a specific wishlist based on an ID.
- Delete a specific wishlist based on an ID.
See also WishlistService.java.
An email is sent to the wishlist owner when a wishlist is created. For more details, have a look at the sendMail
method in WishlistService.java.
The endpoint /wishlists/{wishlistId}/media
enables you to:
- Get a list of all media for the wishlist.
- Create a new medium.
- Delete a specific medium based on an ID.
See also WishlistMediaService.java
When a wishlist is being created, the implementation checks if its owner exists as a customer.
You can find the details at the beginning of the post
method in WishlistService.java.
Showcase how a service can be written using Java. Demonstrate the integration with other services on YaaS, including authentication. Topics covered:
- Usage of Spring framework
- Property handling
- Authentication with the YaaS platform
- Consumption of YaaS services
- Deployment to Cloud Foundry
- Testing
- Core Services
In order to build the service locally, you need to create an Application within your Project/Site, which subscribes to the following packages and scopes:
- Email Package (Scopes:
hybris.email_send
,hybris.email_manage
) - Core Services Package (Scopes:
hybris.media_manage
,hybris.document_manage
,hybris.document_view
) - Commerce as a Service Package (Scope:
hybris.customer_read
)
You must then set the following environment variables:
YAAS_CLIENT
: Your Application's IdentifierYAAS_CLIENT_ID
: Your Application's Client IDYAAS_CLIENT_SECRET
: Your Application's Client SecretYAAS_CLIENT_IS_APPLICATION
: Set this parameter in default.properties totrue
. (Because you are using the Application's credentials, you are running in single tenant mode. Therefore, you must set this flag totrue
.)
You must store the ID of your Project/Site as TENANT
in TestConstants.java.
You also need to create a customer in your tenant and store it as CUSTOMER
in TestConstants.java.
Finally, use mvn clean install
to build the service and run the tests.
To run it locally, you can call mvn jetty:run
and navigate to the local API Console.
If you get failed tests while building with mvn clean install
, such as response code expected:201 but was:500"
,
then it probably means that the test cannot connect to the Core services due to your proxy settings.
Hint: In that case, you might want to try it out with:
mvn clean install -Dhttp.proxyPort=8080 -Dhttp.proxyHost=proxy.wdf.sap.corp -Dhttps.proxyPort=8080 -Dhttps.proxyHost=proxy.wdf.sap.corp