Skip to content
Snippets Groups Projects
Select Git revision
  • 26f9ec1a26f68badd1e795e30dad13447f6be8b9
  • master default protected
  • dev protected
  • Issue/3003-stsInstitute
  • gitkeep
  • Issue/2449-GuidPidSlugToProjectSettings
  • Issue/2309-docs
  • Fix/xxxx-updateDependencies
  • Issue/2364-testingKpiParser
  • Issue/2287-guestRole
  • Test/xxxx-pipelineTriggers
  • Issue/2102-gitLabResTypeRCV
  • Issue/2278-gitlabToS
  • Issue/2101-gitLabResTypeUi
  • Issue/1788-extractionCronjob
  • Issue/2183-kpiGeneratorResource
  • Issue/2222-resourceDateCreated
  • Issue/2221-projectDateCreated
  • Issue/1321-pidEnquiryOverhaul
  • Issue/1999-gitlabResourcesLib
  • Issue/1951-quotaImplementation
  • v2.22.0
  • v2.20.0
  • v2.19.1
  • v2.19.0
  • v2.18.0
  • v2.17.0
  • v2.16.2
  • v2.16.1
  • v2.16.0
  • v2.15.0
  • v2.14.0
  • v2.13.0
  • v2.12.1
  • v2.12.0
  • v2.11.1
  • v2.11.0
  • v2.10.1
  • v2.10.0
  • v2.9.1
  • v2.9.0
41 results

ApiTokenModel.cs

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    ApiTokenModel.cs 3.63 KiB
    using Coscine.Database.DataModel;
    using Coscine.Database.ReturnObjects;
    using LinqToDB;
    using System;
    using System.Collections.Generic;
    using System.Linq.Expressions;
    using System.Linq;
    
    namespace Coscine.Database.Models
    {
        public class ApiTokenModel : DatabaseModel<ApiToken>
        {
            public override Expression<Func<ApiToken, Guid>> GetIdFromObject()
            {
                return databaseObject => databaseObject.Id;
            }
    
            public override ITable<ApiToken> GetITableFromDatabase(CoscineDB db)
            {
                return db.ApiTokens;
            }
    
            public override void SetObjectId(ApiToken databaseObject, Guid id)
            {
                databaseObject.Id = id;
            }
    
            public IEnumerable<ApiTokenObject> GetTokens(string userId)
            {
                return GetTokens(new Guid(userId));
            }
    
            public IEnumerable<ApiTokenObject> GetTokens(User user)
            {
                return GetTokens(user.Id);
            }
    
            public IEnumerable<ApiTokenObject> GetTokens(Guid userId)
            {
                return GetAllWhere((tableEntry) => tableEntry.UserId == userId)
                    .Select(x => new ApiTokenObject { Created = x.Creation, Expires = x.Expiration, Token = x.Token, Description = x.Description })
                    .OrderBy(x => x.Created);
            }
    
            public ApiTokenObject GetToken(string userId, string token)
            {
                var t = GetWhere(x => x.UserId.ToString() == userId && x.Token.ToLower() == token.ToLower());
                if(t == null)
                {
                    return null;
                }
                return new ApiTokenObject { Created = t.Creation, Expires = t.Expiration, Token = t.Token, Description = t.Description };
            }
    
            private ApiToken GetApiToken(string token)
            {
                return GetWhere(x => x.Token.ToLower() == token.ToLower());
            }
    
            public bool Valiate(string token, User user)
            {
                return Valiate(token, user.Id);
            }
    
            public bool Valiate(string token, string userId)
            {
                return Valiate(token, new Guid(userId));
            }
    
            public bool Valiate(string token, Guid userId)
            {
                var t = GetApiToken(token);
                return t != null && t.UserId == userId
                    && t.Expiration.ToUniversalTime() < DateTime.Now.ToUniversalTime()
                    && t.Creation.ToUniversalTime() > DateTime.Now.ToUniversalTime();
            }
    
            public User GetUser(string token)
            {
                return GetUser(GetApiToken(token));
            }
    
            public User GetUser(ApiToken token)
            {
                var userModel = new UserModel();
                return userModel.GetWhere(x => x.Id == token.UserId);
            }
    
            public string GenerateToken(Guid user, string desciption, uint expiresInDays = 370)
            {
                // Minimum of 7 and maximum of 370
                expiresInDays = Math.Min(expiresInDays, 370);
                expiresInDays = Math.Max(expiresInDays, 7);
    
                var token = Guid.NewGuid().ToString("N").ToLower();
    
                Insert(new ApiToken {
                    Creation = DateTime.Now.ToUniversalTime(),
                    Expiration = DateTime.Now.AddDays(expiresInDays).ToUniversalTime(),
                    UserId = user,
                    Token = token,
                    Description = desciption
                });
    
                return token;
            }
    
            public void Revoke(ApiToken token)
            {
                Delete(token);
            }
    
            public void Revoke(Guid tokenId)
            {
                Revoke(GetApiToken(tokenId.ToString()));
            }
    
            public void Revoke(string tokenId)
            {
                Revoke(GetApiToken(tokenId));
            }
        }
    }