using System.Data; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; using PluralKit.Core; namespace PluralKit.API.Controllers { [ApiController] [Route("m")] public class MemberController: ControllerBase { private MemberStore _members; private IDbConnection _conn; private TokenAuthService _auth; public MemberController(MemberStore members, IDbConnection conn, TokenAuthService auth) { _members = members; _conn = conn; _auth = auth; } [HttpGet("{hid}")] public async Task> GetMember(string hid) { var member = await _members.GetByHid(hid); if (member == null) return NotFound("Member not found."); return Ok(member); } [HttpPatch("{hid}")] [RequiresSystem] public async Task> PatchMember(string hid, [FromBody] PKMember newMember) { var member = await _members.GetByHid(hid); if (member == null) return NotFound("Member not found."); if (member.System != _auth.CurrentSystem.Id) return Unauthorized($"Member '{hid}' is not part of your system."); // Explicit bounds checks if (newMember.Name.Length > Limits.MaxMemberNameLength) return BadRequest($"Member name too long ({newMember.Name.Length} > {Limits.MaxMemberNameLength}."); if (newMember.Pronouns.Length > Limits.MaxPronounsLength) return BadRequest($"Member pronouns too long ({newMember.Pronouns.Length} > {Limits.MaxPronounsLength}."); if (newMember.Description.Length > Limits.MaxDescriptionLength) return BadRequest($"Member descriptions too long ({newMember.Description.Length} > {Limits.MaxDescriptionLength}."); // Sanity bounds checks if (newMember.AvatarUrl.Length > 1000 || newMember.Prefix.Length > 1000 || newMember.Suffix.Length > 1000) return BadRequest(); member.Name = newMember.Name; member.Color = newMember.Color; member.AvatarUrl = newMember.AvatarUrl; member.Birthday = newMember.Birthday; member.Pronouns = newMember.Pronouns; member.Description = newMember.Description; member.Prefix = newMember.Prefix; member.Suffix = newMember.Suffix; await _members.Save(member); return Ok(); } } }