|
- using System;
- using System.Data;
- using System.Threading.Tasks;
- using Dapper;
- using DotNetCore.CAP;
- using Microsoft.AspNetCore.Mvc;
- using MySql.Data.MySqlClient;
-
- namespace Sample.RabbitMQ.MySql.Controllers
- {
- [Route("api/[controller]")]
- public class ValuesController : Controller
- {
- private readonly ICapPublisher _capBus;
-
- public ValuesController(ICapPublisher capPublisher)
- {
- _capBus = capPublisher;
- }
-
- [Route("~/without/transaction")]
- public async Task<IActionResult> WithoutTransaction()
- {
- await _capBus.PublishAsync("sample.rabbitmq.mysql", new Person()
- {
- Id = 123,
- Name = "Bar"
- });
-
- return Ok();
- }
-
- [Route("~/adonet/transaction")]
- public IActionResult AdonetWithTransaction()
- {
- using (var connection = new MySqlConnection(AppDbContext.ConnectionString))
- {
- using (var transaction = connection.BeginTransaction(_capBus, true))
- {
- //your business code
- connection.Execute("insert into test(name) values('test')", transaction: (IDbTransaction)transaction.DbTransaction);
-
- //for (int i = 0; i < 5; i++)
- //{
- _capBus.Publish("sample.rabbitmq.mysql", DateTime.Now);
- //}
- }
- }
-
- return Ok();
- }
-
- [Route("~/ef/transaction")]
- public IActionResult EntityFrameworkWithTransaction([FromServices]AppDbContext dbContext)
- {
- using (var trans = dbContext.Database.BeginTransaction(_capBus, autoCommit: false))
- {
- dbContext.Persons.Add(new Person() { Name = "ef.transaction" });
-
- for (int i = 0; i < 1; i++)
- {
- _capBus.Publish("sample.rabbitmq.mysql", DateTime.Now);
- }
-
- dbContext.SaveChanges();
-
- trans.Commit();
- }
- return Ok();
- }
-
- [NonAction]
- [CapSubscribe("sample.rabbitmq.mysql")]
- public void Subscriber(DateTime p)
- {
- Console.WriteLine($@"{DateTime.Now} Subscriber invoked, Info: {p}");
- }
-
- [NonAction]
- [CapSubscribe("sample.rabbitmq.mysql", Group = "group.test2")]
- public void Subscriber2(DateTime p, [FromCap]CapHeader header)
- {
- Console.WriteLine($@"{DateTime.Now} Subscriber invoked, Info: {p}");
- }
- }
- }
|