Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
S
Spring webflux kafka
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kenil Mavani
Spring webflux kafka
Commits
a01783bb
Commit
a01783bb
authored
Feb 06, 2023
by
Kenil Mavani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
m
parent
3fa299f2
Changes
9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
123 additions
and
57 deletions
+123
-57
pom.xml
pom.xml
+19
-44
KafkaProducerConfig.java
...in/java/com/example/kafka/config/KafkaProducerConfig.java
+14
-0
OrderController.java
...in/java/com/example/kafka/controller/OrderController.java
+23
-0
Order.java
src/main/java/com/example/kafka/entity/Order.java
+16
-0
OrderRepository.java
...in/java/com/example/kafka/repository/OrderRepository.java
+9
-0
OrderService.java
src/main/java/com/example/kafka/service/OrderService.java
+8
-0
OrderServiceImpl.java
.../java/com/example/kafka/serviceImpl/OrderServiceImpl.java
+19
-0
application.properties
src/main/resources/application.properties
+15
-0
KafkaApplicationTests.java
src/test/java/com/example/kafka/KafkaApplicationTests.java
+0
-13
No files found.
pom.xml
View file @
a01783bb
...
...
@@ -5,7 +5,7 @@
<parent>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-parent
</artifactId>
<version>
3.0.3-SNAPSHOT
</version>
<version>
2.7.7
</version>
<relativePath/>
<!-- lookup parent from repository -->
</parent>
<groupId>
com.example
</groupId>
...
...
@@ -14,18 +14,34 @@
<name>
kafka
</name>
<description>
Demo project for Spring Webflux and kafka
</description>
<properties>
<java.version>
1
7
</java.version>
<java.version>
1
.8
</java.version>
</properties>
<dependencies>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-data-mongodb-reactive
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-webflux
</artifactId>
</dependency>
<dependency>
<groupId>
org.projectlombok
</groupId>
<artifactId>
lombok
</artifactId>
<optional>
true
</optional>
</dependency>
<dependency>
<groupId>
io.projectreactor.kafka
</groupId>
<artifactId>
reactor-kafka
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.kafka
</groupId>
<artifactId>
spring-kafka
</artifactId>
</dependency>
<dependency>
<groupId>
org.apache.kafka
</groupId>
<artifactId>
kafka-clients
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-test
</artifactId>
...
...
@@ -36,11 +52,6 @@
<artifactId>
reactor-test
</artifactId>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
org.springframework.kafka
</groupId>
<artifactId>
spring-kafka-test
</artifactId>
<scope>
test
</scope>
</dependency>
</dependencies>
<build>
...
...
@@ -51,41 +62,5 @@
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>
spring-milestones
</id>
<name>
Spring Milestones
</name>
<url>
https://repo.spring.io/milestone
</url>
<snapshots>
<enabled>
false
</enabled>
</snapshots>
</repository>
<repository>
<id>
spring-snapshots
</id>
<name>
Spring Snapshots
</name>
<url>
https://repo.spring.io/snapshot
</url>
<releases>
<enabled>
false
</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>
spring-milestones
</id>
<name>
Spring Milestones
</name>
<url>
https://repo.spring.io/milestone
</url>
<snapshots>
<enabled>
false
</enabled>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>
spring-snapshots
</id>
<name>
Spring Snapshots
</name>
<url>
https://repo.spring.io/snapshot
</url>
<releases>
<enabled>
false
</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
</project>
src/main/java/com/example/kafka/config/KafkaProducerConfig.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
config
;
import
lombok.Data
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.stereotype.Component
;
@Component
@Data
public
class
KafkaProducerConfig
{
@Value
(
"${bootstrap.server}"
)
private
String
bootstrapper
;
}
src/main/java/com/example/kafka/controller/OrderController.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
controller
;
import
com.example.kafka.entity.Order
;
import
com.example.kafka.serviceImpl.OrderServiceImpl
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.HttpStatus
;
import
org.springframework.web.bind.annotation.*
;
import
reactor.core.publisher.Mono
;
@RestController
@RequestMapping
(
"/v1/order"
)
public
class
OrderController
{
@Autowired
private
OrderServiceImpl
orderService
;
@PostMapping
(
"/save"
)
@ResponseStatus
(
HttpStatus
.
ACCEPTED
)
public
Mono
<
Order
>
saveOrderDetails
(
@RequestBody
Order
order
){
return
orderService
.
saveOrderIntoDB
(
order
);
}
}
src/main/java/com/example/kafka/entity/Order.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
entity
;
import
lombok.*
;
import
org.springframework.data.mongodb.core.mapping.Document
;
@Data
@ToString
@EqualsAndHashCode
(
of
={
"id"
,
"name"
,
"amount"
})
@AllArgsConstructor
@NoArgsConstructor
@Document
(
value
=
"orders"
)
public
class
Order
{
private
String
id
;
private
String
name
;
private
double
amount
;
}
src/main/java/com/example/kafka/repository/OrderRepository.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
repository
;
import
com.example.kafka.entity.Order
;
import
org.springframework.data.mongodb.repository.ReactiveMongoRepository
;
import
org.springframework.stereotype.Repository
;
@Repository
public
interface
OrderRepository
extends
ReactiveMongoRepository
<
Order
,
String
>
{
}
src/main/java/com/example/kafka/service/OrderService.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
service
;
import
com.example.kafka.entity.Order
;
import
reactor.core.publisher.Mono
;
public
interface
OrderService
{
Mono
<
Order
>
saveOrderIntoDB
(
Order
order
);
}
src/main/java/com/example/kafka/serviceImpl/OrderServiceImpl.java
0 → 100644
View file @
a01783bb
package
com
.
example
.
kafka
.
serviceImpl
;
import
com.example.kafka.entity.Order
;
import
com.example.kafka.repository.OrderRepository
;
import
com.example.kafka.service.OrderService
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
reactor.core.publisher.Mono
;
@Service
public
class
OrderServiceImpl
implements
OrderService
{
@Autowired
private
OrderRepository
orderRepository
;
@Override
public
Mono
<
Order
>
saveOrderIntoDB
(
Order
order
)
{
return
orderRepository
.
save
(
order
);
}
}
src/main/resources/application.properties
View file @
a01783bb
bootstrap.server
=
localhost:9092
kafka.clientId
=
rewards-generator
spring.webflux.base-path
=
/api
spring.application.name
=
spring-webflux-kafka
data.mongodb.authentication-database
=
admin
data.mongodb.uri
=
mongodb://localhost:27017/test
data.mongodb.database
=
test
server.port
:
9000
logging.level.io.reflectoring
:
DEBUG
logging.level.org.springframework.web
:
INFO
logging.level.org.springframework.data.mongodb.core.ReactiveMongoTemplate
=
DEBUG
logging.level.reactor.netty.http.client
=
DEBUG
\ No newline at end of file
src/test/java/com/example/kafka/KafkaApplicationTests.java
deleted
100644 → 0
View file @
3fa299f2
package
com
.
example
.
kafka
;
import
org.junit.jupiter.api.Test
;
import
org.springframework.boot.test.context.SpringBootTest
;
@SpringBootTest
class
KafkaApplicationTests
{
@Test
void
contextLoads
()
{
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment