You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
3.1 KiB
89 lines
3.1 KiB
using BaseService.BaseData.JobManagement.Dto;
|
|
using BaseService.Permissions;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Linq.Dynamic.Core;
|
|
using System.Threading.Tasks;
|
|
using Volo.Abp;
|
|
using Volo.Abp.Application.Dtos;
|
|
using Volo.Abp.Application.Services;
|
|
using Volo.Abp.Domain.Repositories;
|
|
|
|
namespace BaseService.BaseData.JobManagement
|
|
{
|
|
[Authorize(BaseServicePermissions.Job.Default)]
|
|
public class JobAppService : ApplicationService, IJobAppService
|
|
{
|
|
private readonly IRepository<Job, Guid> _repository;
|
|
|
|
public JobAppService(IRepository<Job, Guid> repository)
|
|
{
|
|
_repository = repository;
|
|
}
|
|
|
|
[Authorize(BaseServicePermissions.Job.Create)]
|
|
public async Task<JobDto> Create(CreateOrUpdateJobDto input)
|
|
{
|
|
var exist = await _repository.FirstOrDefaultAsync(_ => _.Name == input.Name);
|
|
if (exist != null)
|
|
{
|
|
throw new BusinessException("名称:" + input.Name + "岗位已存在");
|
|
}
|
|
|
|
var result = await _repository.InsertAsync(new Job(GuidGenerator.Create(),CurrentTenant.Id, input.Name, input.Enabled, input.Sort, input.Description));
|
|
return ObjectMapper.Map<Job, JobDto>(result);
|
|
}
|
|
|
|
[Authorize(BaseServicePermissions.Job.Delete)]
|
|
public async Task Delete(List<Guid> ids)
|
|
{
|
|
foreach (var id in ids)
|
|
{
|
|
await _repository.DeleteAsync(id);
|
|
}
|
|
}
|
|
|
|
public async Task<JobDto> Get(Guid id)
|
|
{
|
|
var result = await _repository.GetAsync(id);
|
|
return ObjectMapper.Map<Job, JobDto>(result);
|
|
}
|
|
|
|
public async Task<PagedResultDto<JobDto>> GetAll(GetJobInputDto input)
|
|
{
|
|
var query = (await _repository.GetQueryableAsync()).WhereIf(!string.IsNullOrWhiteSpace(input.Filter), _ => _.Name.Contains(input.Filter));
|
|
|
|
var totalCount = await query.CountAsync();
|
|
var items = await query.OrderBy(input.Sorting ?? "Sort")
|
|
.Skip(input.SkipCount)
|
|
.Take(input.MaxResultCount)
|
|
.ToListAsync();
|
|
|
|
var dots = ObjectMapper.Map<List<Job>, List<JobDto>>(items);
|
|
return new PagedResultDto<JobDto>(totalCount, dots);
|
|
}
|
|
|
|
public async Task<ListResultDto<JobDto>> GetAllJobs()
|
|
{
|
|
var jobs = await _repository.GetListAsync();
|
|
|
|
return new ListResultDto<JobDto>(ObjectMapper.Map<List<Job>, List<JobDto>>(jobs));
|
|
}
|
|
|
|
[Authorize(BaseServicePermissions.Job.Update)]
|
|
public async Task<JobDto> Update(Guid id, CreateOrUpdateJobDto input)
|
|
{
|
|
var job = await _repository.GetAsync(id);
|
|
|
|
job.Name = input.Name;
|
|
job.Enabled = input.Enabled;
|
|
job.Sort = input.Sort;
|
|
job.Description = input.Description;
|
|
|
|
return ObjectMapper.Map<Job, JobDto>(job);
|
|
}
|
|
}
|
|
}
|
|
|