:toc:
toc::[]
= End to End POC Code generation using Entity class
This article helps to create a sample application using CobiGen.
== Prerequisites
Download and install devonfw IDE by this https://devonfw.com/website/pages/docs/devonfw-guide_ide.wiki_setup.asciidoc.html[tutorial].
== Steps to create a Sample Project using CobiGen
The `HOW_TO` is divided in 2 parts:
. `BE`-Backend generator (`DB` + `DAO` + services)
. `FE`-Frontend generator (Web App Angular + Ionic App)
image:images/howtos/e2e_gen/image63.png[CobiGen code-first generation]
So, ready to go! We’re going to start with the `BE` part.
=== Backend
1.Under your path installation of devonfw, you can find the _eclipse-main.bat_ script. To run it, execute _installation_path_\eclipse-main.bat.This will open eclipse.
2.Create a project: Navigate in the folder containing the devonfw installation and then to `*workspaces/main*`. Right-click and choose "_Open devonfw CMD shell here_". Next, launch this command in the shell:
[source, java]
----
devon java create com.example.domain.myapp
----
3.In eclipse, import the project as a maven project as specified in the image below:
image:images/howtos/e2e_gen/image14.png[eclipse devon]
4.Click *FINISH*. Now you should have the following 4 projects:
image:images/howtos/e2e_gen/image15.png[eclipse package explorer]
5.Create a new *SQL* *file* `V0002__CreateTables_myapp.sql` inside _`myapp-core`_ , under the folder path _`/myapp-core/src/main/resources/db/migration/1.0`_ and insert the following script:
[source]
----
CREATE TABLE EMPLOYEE (
id BIGINT auto_increment, modificationCounter INTEGER NOT NULL,
employeeid BIGINT auto_increment,
name VARCHAR(255),
surname VARCHAR(255),
email VARCHAR(255),
PRIMARY KEY (employeeid)
);
----
*_WARNING 1_*: In this folder there is only one file (0001). You have to add the other files in progressive number order (i.e. 0002)! +
*_WARNING 2_*: There are 2 underscores in the name!
image:images/howtos/e2e_gen/image64.png[SQL file]
6.Create another SQL file analogously named `V0003__PopulateTables-myapp.sql` in the same folder and add following script about the INSERT to populate the table created before. Please note the warnings from the previous step here, as well.
[source]
----
INSERT INTO EMPLOYEE (id, modificationCounter, employeeid, name, surname,email) VALUES (1, 1, 1, 'John', 'Doe', 'john.doe@example.com');
INSERT INTO EMPLOYEE (id, modificationCounter, employeeid, name, surname,email) VALUES (2, 2, 2, 'Tom', 'Smith', 'tom.smith@example.com');
INSERT INTO EMPLOYEE (id, modificationCounter, employeeid, name, surname,email) VALUES (3, 3, 3, 'Joe', 'Schmoe', 'joe.schmoe@example.com');
----
image:images/howtos/e2e_gen/image65.png[SQL insert]
7.We will now create the Entity Class for the code generation. For this, create a package named `com.example.domain.myapp.employeemanagement.dataaccess.api` in the folder _`myapp-core/src/main/java`_. +
*_WARNING_*: It's important to follow this naming convention to ensure CobiGen is working properly.
image:images/howtos/e2e_gen/image66.png[package]
Now create a new class named `EmployeeEntity` in this package and paste the code below to turn it into a `JPA` Entity.
----
package com.example.domain.myapp.employeemanagement.dataaccess.api;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Column;
@Entity
@javax.persistence.Table(name = "EMPLOYEE")
public class EmployeeEntity {
@Column(name = "EMPLOYEEID")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long employeeId;
@Column(name = "NAME")
private String name;
@Column(name = "SURNAME")
private String surname;
@Column(name = "EMAIL")
private String email;
}
----
8.Generate `getters` and `setters` for all attributes, as you can see in the image below:
image:images/howtos/e2e_gen/image67.png[`getter & setter`]
image:images/howtos/e2e_gen/image68.png[`getter & setter`]
9.Now we can use CobiGen to generate code! First, right-click in the package explorer on `EmployeeEntity.java` -> `CobiGen` and select `Update Template`. Next, right-click on `EmployeeEntity.java` -> CobiGen -> Generate and tick the boxes as can be seen in the picture:
image:images/howtos/e2e_gen/image20.png[CobiGen option selection]
10.Click on *Finish* to complete the process. *The entire [.underline]#`BE` layer# structure including `CRUD` operation methods was auto generated.* +
Some classes are generated in the API part (_`myapp-api`)_, e.g. interfaces, as shown below:
image:images/howtos/e2e_gen/image22.png[be layer]
Other classes are generated in the core part (_`myapp-core`)_, like implementations, as shown below:
image:images/howtos/e2e_gen/image23.png[core folder]
11.The last step is to add the cross-domain process, as we are developing the JavaScript client and the server application separately. For this, we need to prepare the server side to accept requests from other domains, covering the following points:
* Accept request from other domains.
* Accept devonfw used headers like `X-CSRF-TOKEN` or `correlationId`.
* Be prepared to receive secured request (cookies).
Add these two kind of dependencies in the pom.xml of the _`myapp-core`_ folder, at the end of the list of dependencies:
[source, xml]
----
com.devonfw.java.starters
devon4j-starter-security-cors
com.devonfw.java.starters
devon4j-starter-security-csrf
----
image:images/howtos/e2e_gen/image70.png[pom xml]
12.Add these properties in your _application.properties_ file, in the `myapp-core` folder in the _resources/config_:
[source, properties]
----
security.cors.spring.allowCredentials=true
security.cors.spring.allowedOriginPatterns=*
security.cors.spring.allowedHeaders=*
security.cors.spring.allowedMethods=OPTIONS,HEAD,GET,PUT,POST,DELETE,PATCH
security.cors.pathPattern=/**
----
image:images/howtos/e2e_gen/image71.png[application properties]
13.To check if the `BE` layer has been generated properly, start the server by right-clicking on _`SpringBootApp.java`_ -> _run as -> Java Application_. If it looks like the image below, the `BE` part is done!
image:images/howtos/e2e_gen/image69.png[Spring boot run]
image:images/howtos/e2e_gen/image26.png[Spring boot run]
Optional step: +
14.To test if the `Backend` works properly, we perform a REST service test! For this, we use Postman. You can download it https://www.postman.com/downloads/[here]. +
First send a POST request for the body with the URL [source, URL].
----
http://localhost:8081/services/rest/employeemanagement/v1/employee/1
----
Under `Body`, insert the JSON containing
----
{
"j_username":"admin",
"j_password":"admin"
}
----
Click on send. "Status:200 OK" means it worked. +
Next, we create a new request, this time `GET` type with the URL
[source, URL]
----
http://localhost:8081/services/rest/employeemanagement/v1/employee/1
----
Click on send. If you get "Status:200 OK" again and see employee "John Doe" as you can see in the image below, the Backend works fine!
image:images/howtos/e2e_gen/image73.png[postman]
=== Frontend
Let's start with the Frontend! We want to create an *Angular Web App*:
1.To generate angular structure, download or clone *devon4ng-application-template* from
[source, URL]
https://github.com/devonfw/devon4ng-application-template
image:images/howtos/e2e_gen/image74.png[devon dist folder]
*IMPORTANT* if you download the zip of the source code, the name of the app MUST BE *devon4ng-application-template*. Extract it into your devonfw folder, under `_workspaces/main_`.
2.After downloading the `APP`, open the application in Eclipse. For this, right click on the left part of Eclipse and click "Import" +
image:images/howtos/e2e_gen/image83.png[import]
Then choose "Projects from Folder or Archive": +
image:images/howtos/e2e_gen/image82.png[import]
Select the folder containing the Angular `FE` Application, under `_workspaces/main_`.Click on *Finish* after all dependencies have been loaded.
image:images/howtos/e2e_gen/image84.png[import]
Now, you should have a structure like this:
image:images/howtos/e2e_gen/image86.png[import]
3.Right click on `EmployeeEto`.java file in the package `_com.example.domain.myapp.employeemanagement.logic.api.to_`, in the `BE` part (_`myapp-api_ module`). Choose `Cobigen -> Generate` and select the options as seen in the screenshot and click on *Finish*:
image:images/howtos/e2e_gen/image37.png[eclipse generate]
4.The entire `ANGULAR` structure has been auto generated and the generated code was merged into already existing code.
image:images/howtos/e2e_gen/image39.png[angular `ee` layer]
The *_app-routing.module.ts_* file (in `src/app`) should correspond to the code below, so copy the code and replace the existing content in your file with this:
[source, ts]
----
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { AuthGuard } from './core/security/auth-guard.service';
import { NavBarComponent } from './layout/nav-bar/nav-bar.component';
const routes: Routes = [{
path: '',
redirectTo: '/login',
pathMatch: 'full'
},
{
path: 'login',
loadChildren: () =>
import('./auth/auth.module').then(m => m.AuthDataModule)
},
{
path: 'home',
component: NavBarComponent,
canActivateChild: [
AuthGuard
],
children: [{
path: 'initial',
loadChildren: () =>
import('./home/initial-page/initial-page.module').then(
m => m.InitialPageModule,
)
},
{
path: 'employee',
loadChildren: () =>
import('./employee/employee.module').then(
m => m.EmployeeModule,
)
}
]
},
{
path: '**',
redirectTo: '/login'
},
];
@NgModule({
imports: [
RouterModule.forRoot(routes)
],
exports: [
RouterModule
]
})
export class AppRoutingModule {
}
----
5.To make the Employee Grid in you `FE` application visible, you have to replace the code in `nav-bar.component.html` with the code below:
[source, HTML]
----
----
6.Open the devon CMD shell and execute `devon npm install` in `_workspaces/main/devon4ng-application-template_`, which will download all the required libraries.
7.Check in the file *environment.ts* (in `src/app/environments`) if the server path is correct.
image:images/howtos/e2e_gen/image42.png[environment]
The values `PATH`, TCP port etc. in application.properties should match the image below. Set the security field to *CSRF* , if it is not configured this way already
image:images/howtos/e2e_gen/image43.png[configure]
[source, ts]
----
export const environment = {
production: false,
restPathRoot: 'http://localhost:8081/',
restServiceRoot: 'http://localhost:8081/services/rest/',
security: 'csrf'
};
----
8.For the last steps, the `BE` server should be running. Then run `*devon ng*` and then `*devon ng serve -o*` to start the Angular Application, in a CMD shell in your application folder (`_workspaces/main/devon4ng-application-template_`).
image:images/howtos/e2e_gen/image75.png[ng serve command]
9.If the command execution is *successful*, the screen shown below will appear and you would be automatically redirected to the URL:
[source, URL]
----
http://localhost:4200/login
----
image:images/howtos/e2e_gen/image77.png[angular web app]
To log into the web application, you can use the credentials *admin* for user and for password. +
Now the *`ANGULAR WebApp`* is done!