public async Task <IActionResult> AcceptOrganisationInvite( [HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = "OrganisationInvite/{OrganisationInviteId}")] HttpRequest req, ILogger log) { log.LogInformation("C# HTTP trigger function(AcceptOrganisationInvite) processed a request."); try { var accessTokenResult = _tokenProvider.ValidateToken(req); if (accessTokenResult.Status != AccessTokenStatus.Valid) { return(new UnauthorizedResult()); } string requestBody = await new StreamReader(req.Body).ReadToEndAsync(); var organisationInvite = JsonConvert.DeserializeObject <OrganisationInvite>(requestBody); Guid userAccountId = new Guid(accessTokenResult.Principal.Claims.First(c => c.Type == "UserAccount").Value); var organisationInviteRepo = new OrganisationInviteRepository(); organisationInvite = organisationInviteRepo.GetOrganisationInviteById(organisationInvite.OrganisationInviteId); if (userAccountId != organisationInvite.InviteeId) { return(new BadRequestObjectResult("User sending request is not the invitee")); } var organisationMembership = new OrganisationMembership() { OrganisationId = organisationInvite.OrganisationId, UserAccountId = organisationInvite.InviteeId, OrganisationInviteId = organisationInvite.OrganisationInviteId, UserType = organisationInvite.InviteUserType }; var organisationMembershipRepo = new OrganisationMembershipRepository(); if (organisationMembershipRepo.AlreadyHasAMembershipInOrganisation(userAccountId, organisationInvite.OrganisationId)) { return(new BadRequestObjectResult("User already a member of this Organisation.")); } organisationMembershipRepo.CreateOrganisationMembership(organisationMembership); organisationInviteRepo.UseOrganisationInvite(organisationInvite.OrganisationInviteId); // return JWT with the newly joined Organisation's Id var jwt = _tokenCreator.CreateToken(userAccountId, organisationInvite.OrganisationId); return(new OkObjectResult(jwt)); } catch (Exception exception) { return(new BadRequestObjectResult(exception.Message)); } }
public async Task <IActionResult> CreateOrganisation( [HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = "Organisation/CreateOrganisation")] HttpRequest req, ILogger log) { log.LogInformation("C# HTTP trigger function(CreateOrganisation) processed a request."); try { var accessTokenResult = _tokenProvider.ValidateToken(req); if (accessTokenResult.Status == AccessTokenStatus.Valid) { Guid userAccountId = new Guid(accessTokenResult.Principal.Claims.First(c => c.Type == "UserAccount").Value); log.LogInformation($"JWT validated for UserAccount: {userAccountId}."); string requestBody = await new StreamReader(req.Body).ReadToEndAsync(); var organisationCreateModel = JsonConvert.DeserializeObject <OrganisationCreateModel>(requestBody); var organisation = new Organisation() { OrganisationName = organisationCreateModel.OrganisationName, CreatedById = userAccountId }; var organisationRepo = new OrganisationRepository(); var organisationId = organisationRepo.CreateOrganisation(organisation); var organisationMembership = new OrganisationMembership() { OrganisationId = organisationId, UserAccountId = userAccountId, UserType = UserType.OrganisationOwner, OrganisationInviteId = null }; // store the OrganisationMembership var organisationMembershipRepo = new OrganisationMembershipRepository(); organisationMembershipRepo.CreateOrganisationMembership(organisationMembership); // create JWT with the OrganisationId as var jwt = _tokenCreator.CreateToken(userAccountId, organisationId); return(new OkObjectResult(jwt)); } else { return(new UnauthorizedResult()); } } catch (Exception exception) { return(new BadRequestObjectResult(exception.Message)); } }
/// <summary> /// Only for changing a user's role in the organisation /// </summary> /// <param name="organisationMembership"></param> public void UpdateOrganisationMembership(OrganisationMembership organisationMembership) { using (var db = new SqlConnection(_connectionString)) { var parameters = new { organisationMembership.UserType }; var sql = SqlCrudHelper.GetUpdateStatement(parameters, organisationMembership.GetType().Name); sql += " WHERE OrganisationMembershipId = @OrganisationMembershipId"; db.Execute(sql, organisationMembership); } }
public Guid CreateOrganisationMembership(OrganisationMembership organisationMembership) { using (var db = new SqlConnection(_connectionString)) { var parameters = new { organisationMembership.OrganisationId, organisationMembership.UserAccountId, organisationMembership.UserType, organisationMembership.OrganisationInviteId }; var sql = SqlCrudHelper.GetInsertStatement(parameters, organisationMembership.GetType().Name, "OrganisationMembershipId"); Guid newId = db.ExecuteScalar <Guid>(sql, parameters); return(newId); } }