2018-11-17 02:14:32 +00:00
|
|
|
|
using Mapster;
|
2018-11-17 02:44:08 +00:00
|
|
|
|
using Microsoft.AspNetCore.SignalR;
|
2018-11-17 02:14:32 +00:00
|
|
|
|
using Microsoft.Extensions.Logging;
|
2018-11-17 02:44:08 +00:00
|
|
|
|
using Newtonsoft.Json;
|
|
|
|
|
using Roadie.Api.Hubs;
|
2018-11-17 02:14:32 +00:00
|
|
|
|
using Roadie.Library;
|
2018-11-15 00:16:25 +00:00
|
|
|
|
using Roadie.Library.Caching;
|
|
|
|
|
using Roadie.Library.Configuration;
|
|
|
|
|
using Roadie.Library.Encoding;
|
|
|
|
|
using Roadie.Library.Models;
|
|
|
|
|
using Roadie.Library.Models.Pagination;
|
|
|
|
|
using Roadie.Library.Models.Users;
|
|
|
|
|
using Roadie.Library.Utility;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Linq.Dynamic.Core;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using data = Roadie.Library.Data;
|
|
|
|
|
|
|
|
|
|
namespace Roadie.Api.Services
|
|
|
|
|
{
|
2018-11-15 04:11:25 +00:00
|
|
|
|
public class PlayActivityService : ServiceBase, IPlayActivityService
|
2018-11-15 00:16:25 +00:00
|
|
|
|
{
|
2018-11-17 02:44:08 +00:00
|
|
|
|
protected IHubContext<PlayActivityHub> PlayActivityHub { get; }
|
|
|
|
|
|
2018-11-15 00:16:25 +00:00
|
|
|
|
public PlayActivityService(IRoadieSettings configuration,
|
|
|
|
|
IHttpEncoder httpEncoder,
|
|
|
|
|
IHttpContext httpContext,
|
|
|
|
|
data.IRoadieDbContext dbContext,
|
|
|
|
|
ICacheManager cacheManager,
|
2018-11-17 02:44:08 +00:00
|
|
|
|
ILogger<PlayActivityService> logger,
|
|
|
|
|
IHubContext<PlayActivityHub> playHubContext)
|
2018-11-15 00:16:25 +00:00
|
|
|
|
: base(configuration, httpEncoder, dbContext, cacheManager, logger, httpContext)
|
|
|
|
|
{
|
2018-11-17 02:44:08 +00:00
|
|
|
|
this.PlayActivityHub = playHubContext;
|
2018-11-15 00:16:25 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-12-24 19:40:49 +00:00
|
|
|
|
public Task<Library.Models.Pagination.PagedResult<PlayActivityList>> List(PagedRequest request, User roadieUser = null, DateTime? newerThan = null)
|
2018-11-15 00:16:25 +00:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var sw = new Stopwatch();
|
|
|
|
|
sw.Start();
|
|
|
|
|
|
|
|
|
|
var result = (from t in this.DbContext.Tracks
|
|
|
|
|
join rm in this.DbContext.ReleaseMedias on t.ReleaseMediaId equals rm.Id
|
|
|
|
|
join r in this.DbContext.Releases on rm.ReleaseId equals r.Id
|
|
|
|
|
join trackArtist in this.DbContext.Artists on t.ArtistId equals trackArtist.Id into tas
|
|
|
|
|
from trackArtist in tas.DefaultIfEmpty()
|
|
|
|
|
join usertrack in this.DbContext.UserTracks on t.Id equals usertrack.TrackId
|
|
|
|
|
join u in this.DbContext.Users on usertrack.UserId equals u.Id
|
|
|
|
|
join releaseArtist in this.DbContext.Artists on r.ArtistId equals releaseArtist.Id
|
2018-11-25 20:43:52 +00:00
|
|
|
|
where(newerThan == null || usertrack.LastPlayed >= newerThan)
|
2018-11-15 04:11:25 +00:00
|
|
|
|
where ((roadieUser == null && !(u.IsPrivate ?? false)) || (roadieUser != null && (usertrack != null && usertrack.User.Id == roadieUser.Id)))
|
2018-11-15 00:16:25 +00:00
|
|
|
|
where (request.FilterValue.Length == 0 || (request.FilterValue.Length > 0 && (
|
|
|
|
|
t.Title != null && t.Title.ToLower().Contains(request.Filter.ToLower()) ||
|
|
|
|
|
t.AlternateNames != null && t.AlternateNames.ToLower().Contains(request.Filter.ToLower())
|
|
|
|
|
)))
|
|
|
|
|
select new PlayActivityList
|
|
|
|
|
{
|
|
|
|
|
Release = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = r.Title,
|
|
|
|
|
Value = r.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
Track = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = t.Title,
|
|
|
|
|
Value = t.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
User = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = u.UserName,
|
|
|
|
|
Value = u.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
Artist = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = releaseArtist.Name,
|
|
|
|
|
Value = releaseArtist.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
TrackArtist = trackArtist == null ? null : new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = trackArtist.Name,
|
|
|
|
|
Value = trackArtist.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
PlayedDateDateTime = usertrack.LastPlayed,
|
|
|
|
|
ReleasePlayUrl = $"{ this.HttpContext.BaseUrl }/play/release/{ r.RoadieId}",
|
|
|
|
|
Rating = t.Rating,
|
|
|
|
|
UserRating = usertrack.Rating,
|
2018-11-18 14:42:02 +00:00
|
|
|
|
TrackPlayUrl = $"{ this.HttpContext.BaseUrl }/play/track/{ t.RoadieId}.mp3",
|
2018-11-15 00:16:25 +00:00
|
|
|
|
ArtistThumbnail = this.MakeArtistThumbnailImage(trackArtist != null ? trackArtist.RoadieId : releaseArtist.RoadieId),
|
|
|
|
|
ReleaseThumbnail = this.MakeReleaseThumbnailImage(r.RoadieId),
|
|
|
|
|
UserThumbnail = this.MakeUserThumbnailImage(u.RoadieId)
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
var sortBy = string.IsNullOrEmpty(request.Sort) ? request.OrderValue(new Dictionary<string, string> { { "PlayedDateDateTime", "DESC" } }) : request.OrderValue(null);
|
|
|
|
|
var rowCount = result.Count();
|
|
|
|
|
var rows = result.OrderBy(sortBy).Skip(request.SkipValue).Take(request.LimitValue).ToArray();
|
|
|
|
|
sw.Stop();
|
2018-12-24 19:40:49 +00:00
|
|
|
|
return Task.FromResult(new Library.Models.Pagination.PagedResult<PlayActivityList>
|
2018-11-15 00:16:25 +00:00
|
|
|
|
{
|
|
|
|
|
TotalCount = rowCount,
|
|
|
|
|
CurrentPage = request.PageValue,
|
|
|
|
|
TotalPages = (int)Math.Ceiling((double)rowCount / request.LimitValue),
|
|
|
|
|
OperationTime = sw.ElapsedMilliseconds,
|
|
|
|
|
Rows = rows
|
2018-12-24 19:40:49 +00:00
|
|
|
|
});
|
2018-11-15 00:16:25 +00:00
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
this.Logger.LogError(ex);
|
|
|
|
|
}
|
2018-12-24 19:40:49 +00:00
|
|
|
|
return Task.FromResult(new Library.Models.Pagination.PagedResult<PlayActivityList>());
|
2018-11-15 00:16:25 +00:00
|
|
|
|
}
|
2018-11-17 02:14:32 +00:00
|
|
|
|
|
2018-11-17 02:44:08 +00:00
|
|
|
|
public async Task<OperationResult<PlayActivityList>> CreatePlayActivity(User roadieUser, TrackStreamInfo streamInfo)
|
2018-11-17 02:14:32 +00:00
|
|
|
|
{
|
|
|
|
|
var sw = Stopwatch.StartNew();
|
|
|
|
|
|
|
|
|
|
var track = this.GetTrack(streamInfo.Track.Value);
|
|
|
|
|
if (track == null)
|
|
|
|
|
{
|
2018-11-17 02:44:08 +00:00
|
|
|
|
return new OperationResult<PlayActivityList>($"CreatePlayActivity: Unable To Find Track [{ streamInfo.Track.Value }]");
|
2018-11-17 02:14:32 +00:00
|
|
|
|
}
|
|
|
|
|
if (!track.IsValid)
|
|
|
|
|
{
|
2018-11-17 02:44:08 +00:00
|
|
|
|
return new OperationResult<PlayActivityList>($"CreatePlayActivity: Invalid Track. Track Id [{streamInfo.Track.Value}], FilePath [{track.FilePath}], Filename [{track.FileName}]");
|
2018-11-17 02:14:32 +00:00
|
|
|
|
}
|
2018-11-23 04:18:48 +00:00
|
|
|
|
data.UserTrack userTrack = null;
|
2018-11-17 02:14:32 +00:00
|
|
|
|
var now = DateTime.UtcNow;
|
|
|
|
|
track.PlayedCount = (track.PlayedCount ?? 0) + 1;
|
2018-11-23 04:18:48 +00:00
|
|
|
|
var user = this.GetUser(roadieUser?.UserId);
|
|
|
|
|
if (user != null)
|
2018-11-17 02:14:32 +00:00
|
|
|
|
{
|
2018-11-23 04:18:48 +00:00
|
|
|
|
userTrack = user.TrackRatings.FirstOrDefault(x => x.TrackId == track.Id);
|
|
|
|
|
if (userTrack == null)
|
2018-11-17 02:14:32 +00:00
|
|
|
|
{
|
2018-11-23 04:18:48 +00:00
|
|
|
|
userTrack = new data.UserTrack(now)
|
|
|
|
|
{
|
|
|
|
|
UserId = user.Id,
|
|
|
|
|
TrackId = track.Id
|
|
|
|
|
};
|
|
|
|
|
this.DbContext.UserTracks.Add(userTrack);
|
|
|
|
|
}
|
|
|
|
|
userTrack.LastPlayed = now;
|
|
|
|
|
userTrack.PlayedCount++;
|
|
|
|
|
this.CacheManager.ClearRegion(user.CacheRegion);
|
2018-11-17 02:14:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-11-21 06:34:53 +00:00
|
|
|
|
var release = this.GetRelease(track.ReleaseMedia.Release.RoadieId);
|
|
|
|
|
release.LastPlayed = now;
|
|
|
|
|
release.PlayedCount++;
|
|
|
|
|
|
2018-12-01 18:05:24 +00:00
|
|
|
|
var artist = this.GetArtist(release.Artist.RoadieId);
|
|
|
|
|
artist.LastPlayed = now;
|
|
|
|
|
artist.PlayedCount++;
|
|
|
|
|
|
2018-11-17 02:14:32 +00:00
|
|
|
|
this.CacheManager.ClearRegion(track.CacheRegion);
|
|
|
|
|
this.CacheManager.ClearRegion(track.ReleaseMedia.Release.CacheRegion);
|
|
|
|
|
this.CacheManager.ClearRegion(track.ReleaseMedia.Release.Artist.CacheRegion);
|
|
|
|
|
|
2018-11-17 02:44:08 +00:00
|
|
|
|
var pl = new PlayActivityList
|
|
|
|
|
{
|
|
|
|
|
Artist = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = track.ReleaseMedia.Release.Artist.Name,
|
|
|
|
|
Value = track.ReleaseMedia.Release.Artist.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
TrackArtist = track.TrackArtist == null ? null : new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = track.TrackArtist.Name,
|
|
|
|
|
Value = track.TrackArtist.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
Release = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = track.ReleaseMedia.Release.Title,
|
|
|
|
|
Value = track.ReleaseMedia.Release.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
Track = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = track.Title,
|
|
|
|
|
Value = track.RoadieId.ToString()
|
|
|
|
|
},
|
|
|
|
|
User = new DataToken
|
|
|
|
|
{
|
|
|
|
|
Text = roadieUser.UserName,
|
|
|
|
|
Value = roadieUser.UserId.ToString()
|
|
|
|
|
},
|
2018-11-23 04:18:48 +00:00
|
|
|
|
PlayedDateDateTime = userTrack?.LastPlayed,
|
2018-11-17 02:44:08 +00:00
|
|
|
|
ReleasePlayUrl = $"{ this.HttpContext.BaseUrl }/play/release/{ track.ReleaseMedia.Release.RoadieId}",
|
|
|
|
|
Rating = track.Rating,
|
2018-11-23 04:18:48 +00:00
|
|
|
|
UserRating = userTrack?.Rating,
|
2018-11-18 14:42:02 +00:00
|
|
|
|
TrackPlayUrl = $"{ this.HttpContext.BaseUrl }/play/track/{ track.RoadieId}.mp3",
|
2018-11-17 02:44:08 +00:00
|
|
|
|
ArtistThumbnail = this.MakeArtistThumbnailImage(track.TrackArtist != null ? track.TrackArtist.RoadieId : track.ReleaseMedia.Release.Artist.RoadieId),
|
|
|
|
|
ReleaseThumbnail = this.MakeReleaseThumbnailImage(track.ReleaseMedia.Release.RoadieId),
|
|
|
|
|
UserThumbnail = this.MakeUserThumbnailImage(roadieUser.UserId)
|
|
|
|
|
};
|
2018-11-17 02:14:32 +00:00
|
|
|
|
|
2018-11-17 02:44:08 +00:00
|
|
|
|
if (!roadieUser.IsPrivate)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2018-12-14 03:52:14 +00:00
|
|
|
|
await this.PlayActivityHub.Clients.All.SendAsync("SendActivity",pl);
|
2018-11-17 02:44:08 +00:00
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
this.Logger.LogError(ex);
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-11-17 02:14:32 +00:00
|
|
|
|
|
|
|
|
|
await this.DbContext.SaveChangesAsync();
|
|
|
|
|
sw.Stop();
|
2018-11-17 02:44:08 +00:00
|
|
|
|
return new OperationResult<PlayActivityList>
|
2018-11-17 02:14:32 +00:00
|
|
|
|
{
|
2018-11-17 02:44:08 +00:00
|
|
|
|
Data = pl,
|
2018-11-17 02:14:32 +00:00
|
|
|
|
IsSuccess = userTrack != null,
|
|
|
|
|
OperationTime = sw.ElapsedMilliseconds
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|
2018-11-15 00:16:25 +00:00
|
|
|
|
}
|
2018-11-16 03:37:00 +00:00
|
|
|
|
}
|