@kenniy/godeye-data-contracts
Version:
Enterprise-grade base repository architecture for GOD-EYE microservices with zero overhead and maximum code reuse
88 lines (87 loc) • 3.69 kB
JavaScript
;
/**
* User-specific Query DTO
* Extends base with User entity fields and relations
*/
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.UserQueryDto = void 0;
const class_validator_1 = require("class-validator");
const class_transformer_1 = require("class-transformer");
const swagger_1 = require("@nestjs/swagger");
const base_query_dto_1 = require("./base-query.dto");
class UserQueryDto extends base_query_dto_1.BaseQueryDto {
/**
* Define User entity relations for smart include parsing
*/
getKnownRelations() {
return ['profile', 'business', 'posts', 'files', 'createdBy', 'updatedBy'];
}
buildWhereClause() {
const where = super.buildWhereClause() || {};
if (this.userType)
where.userType = this.userType;
if (this.email)
where.email = this.email;
if (this.verified !== undefined)
where.verified = this.verified;
// Date range filters
if (this.createdAfter || this.createdBefore) {
where.createdAt = {};
if (this.createdAfter)
where.createdAt.$gte = new Date(this.createdAfter);
if (this.createdBefore)
where.createdAt.$lte = new Date(this.createdBefore);
}
return where;
}
}
exports.UserQueryDto = UserQueryDto;
__decorate([
(0, swagger_1.ApiPropertyOptional)({
example: 'business',
enum: ['business', 'individual'],
description: 'User type filter'
}),
(0, class_validator_1.IsOptional)(),
(0, class_validator_1.IsEnum)(['business', 'individual']),
__metadata("design:type", String)
], UserQueryDto.prototype, "userType", void 0);
__decorate([
(0, swagger_1.ApiPropertyOptional)({ example: 'john@example.com', description: 'Filter by email' }),
(0, class_validator_1.IsOptional)(),
(0, class_validator_1.IsString)(),
__metadata("design:type", String)
], UserQueryDto.prototype, "email", void 0);
__decorate([
(0, swagger_1.ApiPropertyOptional)({ example: true, description: 'Filter by verification status' }),
(0, class_validator_1.IsOptional)(),
(0, class_transformer_1.Type)(() => Boolean),
__metadata("design:type", Boolean)
], UserQueryDto.prototype, "verified", void 0);
__decorate([
(0, swagger_1.ApiPropertyOptional)({
example: '2023-01-01',
description: 'Created after date (ISO string)'
}),
(0, class_validator_1.IsOptional)(),
(0, class_validator_1.IsString)(),
__metadata("design:type", String)
], UserQueryDto.prototype, "createdAfter", void 0);
__decorate([
(0, swagger_1.ApiPropertyOptional)({
example: '2023-12-31',
description: 'Created before date (ISO string)'
}),
(0, class_validator_1.IsOptional)(),
(0, class_validator_1.IsString)(),
__metadata("design:type", String)
], UserQueryDto.prototype, "createdBefore", void 0);