Sleep and Steps

- added sleep
- added steps
- bertter DB filling
This commit is contained in:
2018-09-23 18:39:59 +02:00
parent c807c474c4
commit a1019dd62e
17 changed files with 386 additions and 69 deletions

View File

@@ -11,6 +11,8 @@ namespace SeniorAssistant.Controllers.Services
public class CrudTimeController<TEntity> : BaseController
where TEntity : class, IHasTime
{
static readonly object Empty = new { };
[HttpGet]
public async Task<IEnumerable<TEntity>> Read() => await Db.GetTable<TEntity>().ToListAsync();
@@ -18,31 +20,54 @@ namespace SeniorAssistant.Controllers.Services
public async Task<IEnumerable<TEntity>> Read(string username) => await Db.GetTable<TEntity>().Where(e => e.Username.Equals(username)).ToListAsync();
[HttpGet("{username}/{date:regex((today|\\d{{4}}-\\d{{2}}-\\d{{2}}))}/{hour:range(0, 23)?}")]
public async Task<IEnumerable<TEntity>> Read(string username, string date, int hour = -1)
{
DateTime time = (date.Equals("today") ? DateTime.Now : DateTime.ParseExact(date, "yyyy-MM-dd", null) );
public async Task<IEnumerable<TEntity>> Read(string username, string date, int hour = -1) => await Read(username, date, date, hour);
return await Db.GetTable<TEntity>().Where(e =>
e.Username.Equals(username) &&
(time.Year == 0 || e.Time.Year == time.Year) &&
(time.Month == 0 || e.Time.Month == time.Month) &&
(time.Day == 0 || e.Time.Day == time.Day) &&
(hour < 0 || e.Time.Hour == hour)
).ToListAsync();
[HttpGet("{username}/{from:regex((today|\\d{{4}}-\\d{{2}}-\\d{{2}}))}/{to:regex((today|\\d{{4}}-\\d{{2}}-\\d{{2}}))}/{hour:range(0, 23)?}")]
public async Task<IEnumerable<TEntity>> Read(string username, string from, string to, int hour = -1)
{
try
{
DateTime dateFrom = (from.Equals("today") ? DateTime.Now : DateTime.ParseExact(from, "yyyy-MM-dd", null));
DateTime dateTo = (to.Equals("today") ? DateTime.Now : DateTime.ParseExact(to, "yyyy-MM-dd", null));
return await Db.GetTable<TEntity>().Where(e => e.Username.Equals(username) && dateFrom.Date<=e.Time.Date && dateTo.Date>=e.Time.Date && (hour < 0 || e.Time.Hour == hour)).ToListAsync();
}
catch
{
return new List<TEntity>();
}
}
[HttpGet("{username}/last/{hour:min(1)}")]
public async Task<IEnumerable<TEntity>> Read(string username, int hour)
{
DateTime date = DateTime.Now.AddHours(-hour);
return await Db.GetTable<TEntity>().Where(e => e.Username.Equals(username) && date <= e.Time).ToListAsync();
}
[NonAction]
public async Task<TEntity> Read(string username, DateTime date) => await Db.GetTable<TEntity>().FirstOrDefaultAsync(e => e.Username.Equals(username) && date == e.Time);
[HttpPost]
public async Task Create([FromBody]TEntity item) => await Db.InsertAsync(item);
[HttpPut]
public async Task<object> Update([FromBody]TEntity item)
{
var e = await Read(item.Username, item.Time);
if (e == null)
{
await Create(item);
}
else
{
await Db.UpdateAsync(item);
}
return Empty;
}
/*
[HttpPost("{username}")]
public async Task Create([FromBody]TEntity item) => await Db.InsertAsync(item);
[HttpPut("{username}/{date}/{time}")]
public async Task Update(string username, [FromBody]TEntity item)
{
item.Username = username;
await Db.UpdateAsync(item);
}
[HttpDelete("{username}")]
public async Task Delete(string username) => await Db.GetTable<TEntity>().Where(c => c.Username.Equals(username)).DeleteAsync();
*/