Files
Swarm/DysonNetwork.Sphere/Publisher/PublisherSubscriptionController.cs

150 lines
4.9 KiB
C#

using DysonNetwork.Shared.Models;
using DysonNetwork.Shared.Proto;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
namespace DysonNetwork.Sphere.Publisher;
[ApiController]
[Route("/api/publishers")]
public class PublisherSubscriptionController(
PublisherSubscriptionService subs,
AppDatabase db,
ILogger<PublisherSubscriptionController> logger
)
: ControllerBase
{
public class SubscribeRequest
{
public int? Tier { get; set; }
}
[HttpGet("{name}/subscription")]
[Authorize]
public async Task<ActionResult<SnPublisherSubscription>> CheckSubscriptionStatus(string name)
{
if (HttpContext.Items["CurrentUser"] is not Account currentUser) return Unauthorized();
// Check if the publisher exists
var publisher = await db.Publishers.FirstOrDefaultAsync(p => p.Name == name);
if (publisher == null)
return NotFound("Publisher not found");
var subscription = await subs.GetSubscriptionAsync(Guid.Parse(currentUser.Id), publisher.Id);
if (subscription is null) return NotFound("Subscription not found");
return subscription;
}
[HttpPost("{name}/subscribe")]
[Authorize]
public async Task<ActionResult<SnPublisherSubscription>> Subscribe(
string name,
[FromBody] SubscribeRequest request)
{
if (HttpContext.Items["CurrentUser"] is not Account currentUser) return Unauthorized();
// Check if the publisher exists
var publisher = await db.Publishers.FirstOrDefaultAsync(p => p.Name == name);
if (publisher == null)
return NotFound("Publisher not found");
try
{
var subscription = await subs.CreateSubscriptionAsync(
Guid.Parse(currentUser.Id),
publisher.Id,
request.Tier ?? 0
);
return subscription;
}
catch (Exception ex)
{
logger.LogError(ex, "Error subscribing to publisher {PublisherName}", name);
return StatusCode(500, "Failed to create subscription");
}
}
[HttpPost("{name}/unsubscribe")]
[Authorize]
public async Task<ActionResult> Unsubscribe(string name)
{
if (HttpContext.Items["CurrentUser"] is not Account currentUser) return Unauthorized();
// Check if the publisher exists
var publisher = await db.Publishers.FirstOrDefaultAsync(e => e.Name == name);
if (publisher == null)
return NotFound("Publisher not found");
var success = await subs.CancelSubscriptionAsync(Guid.Parse(currentUser.Id), publisher.Id);
if (success)
return Ok(new { message = "Subscription cancelled successfully" });
return NotFound("Active subscription not found");
}
/// <summary>
/// Get all subscriptions for the current user
/// </summary>
/// <returns>List of active subscriptions</returns>
[HttpGet("subscriptions")]
[Authorize]
public async Task<ActionResult<List<SnPublisherSubscription>>> GetCurrentSubscriptions(
[FromQuery] int offset = 0,
[FromQuery] int take = 20
)
{
if (HttpContext.Items["CurrentUser"] is not Account currentUser) return Unauthorized();
var accountId = Guid.Parse(currentUser.Id);
var pubQuery = db.PublisherSubscriptions
.Include(ps => ps.Publisher)
.Where(ps => ps.AccountId == accountId && ps.Status == PublisherSubscriptionStatus.Active)
.OrderByDescending(ps => ps.CreatedAt)
.AsQueryable();
var totalCount = await pubQuery.CountAsync();
var subscriptions = await pubQuery
.Take(take)
.Skip(offset)
.ToListAsync();
Response.Headers["X-Total"] = totalCount.ToString();
return Ok(subscriptions);
}
/// <summary>
/// Get all subscriptions of categories and tags for the current user
/// </summary>
/// <returns>List of active subscription</returns>
[HttpGet("subscriptions/categories")]
[Authorize]
public async Task<ActionResult<List<SnPostCategorySubscription>>> ListCategoriesSubscription(
[FromQuery] int offset = 0,
[FromQuery] int take = 20
)
{
if (HttpContext.Items["CurrentUser"] is not Account currentUser) return Unauthorized();
var accountId = Guid.Parse(currentUser.Id);
var pubQuery = db.PostCategorySubscriptions
.Include(ps => ps.Tag)
.Include(ps => ps.Category)
.Where(ps => ps.AccountId == accountId)
.OrderByDescending(ps => ps.CreatedAt)
.AsQueryable();
var totalCount = await pubQuery.CountAsync();
var subscriptions = await pubQuery
.Take(take)
.Skip(offset)
.ToListAsync();
Response.Headers["X-Total"] = totalCount.ToString();
return Ok(subscriptions);
}
}