Skip to content

Commit

Permalink
Merge branch 'develop' into fix/3141bugs-in-angular
Browse files Browse the repository at this point in the history
  • Loading branch information
Ihar committed Jan 7, 2025
2 parents fb809b7 + 29a699a commit f056433
Show file tree
Hide file tree
Showing 1,113 changed files with 93,194 additions and 34,115 deletions.
872 changes: 872 additions & 0 deletions api-gateway/src/api/service/policy-labels.ts

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions api-gateway/src/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ import { WorkerTasksController } from './api/service/worker-tasks.js';
import { PolicyStatisticsApi } from './api/service/policy-statistics.js';
import { SchemaRulesApi } from './api/service/schema-rules.js';
import { loggerMongoProvider, pinoLoggerProvider } from './helpers/providers/index.js';
import { PolicyLabelsApi } from './api/service/policy-labels.js';

// const JSON_REQUEST_LIMIT = process.env.JSON_REQUEST_LIMIT || '1mb';
// const RAW_REQUEST_LIMIT = process.env.RAW_REQUEST_LIMIT || '1gb';
Expand Down Expand Up @@ -96,6 +97,7 @@ import { loggerMongoProvider, pinoLoggerProvider } from './helpers/providers/ind
PermissionsApi,
PolicyStatisticsApi,
SchemaRulesApi,
PolicyLabelsApi,
WorkerTasksController
],
providers: [
Expand Down
259 changes: 258 additions & 1 deletion api-gateway/src/helpers/guardians.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,13 @@ import {
StatisticDefinitionRelationshipsDTO,
SchemaRuleDTO,
SchemaRuleRelationshipsDTO,
SchemaRuleDataDTO
SchemaRuleDataDTO,
PolicyLabelDTO,
PolicyLabelDocumentDTO,
PolicyLabelRelationshipsDTO,
PolicyLabelDocumentRelationshipsDTO,
PolicyLabelComponentsDTO,
PolicyLabelFiltersDTO
} from '#middlewares';

/**
Expand Down Expand Up @@ -3197,4 +3203,255 @@ export class Guardians extends NatsService {
public async previewSchemaRule(zip: any, owner: IOwner) {
return await this.sendMessage(MessageAPI.PREVIEW_SCHEMA_RULE_FILE, { zip, owner });
}

/**
* Create policy label
*
* @param label
* @param owner
* @returns policy label
*/
public async createPolicyLabel(label: PolicyLabelDTO, owner: IOwner): Promise<PolicyLabelDTO> {
return await this.sendMessage(MessageAPI.CREATE_POLICY_LABEL, { label, owner });
}

/**
* Return policy labels
*
* @param filters
* @param owner
*
* @returns {ResponseAndCount<PolicyLabelDTO>}
*/
public async getPolicyLabels(filters: IFilter, owner: IOwner): Promise<ResponseAndCount<PolicyLabelDTO>> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABELS, { filters, owner });
}

/**
* Get policy label
*
* @param definitionId
* @param owner
* @returns Operation Success
*/
public async getPolicyLabelById(definitionId: string, owner: IOwner): Promise<PolicyLabelDTO> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL, { definitionId, owner });
}

/**
* Get relationships
*
* @param definitionId
* @param owner
*
* @returns Relationships
*/
public async getPolicyLabelRelationships(definitionId: string, owner: IOwner): Promise<PolicyLabelRelationshipsDTO> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_RELATIONSHIPS, { definitionId, owner });
}

/**
* Update policy label
*
* @param definitionId
* @param label
* @param owner
*
* @returns theme
*/
public async updatePolicyLabel(
definitionId: string,
label: PolicyLabelDTO,
owner: IOwner
): Promise<PolicyLabelDTO> {
return await this.sendMessage(MessageAPI.UPDATE_POLICY_LABEL, { definitionId, label, owner });
}

/**
* Delete policy label
*
* @param definitionId
* @param owner
*
* @returns Operation Success
*/
public async deletePolicyLabel(definitionId: string, owner: IOwner): Promise<boolean> {
return await this.sendMessage(MessageAPI.DELETE_POLICY_LABEL, { definitionId, owner });
}

/**
* Publish policy label
*
* @param definitionId
* @param owner
*
* @returns Operation Success
*/
public async publishPolicyLabel(definitionId: string, owner: IOwner): Promise<PolicyLabelDTO> {
return await this.sendMessage(MessageAPI.PUBLISH_POLICY_LABEL, { definitionId, owner });
}

/**
* Async publish policy
* @param definitionId
* @param owner
* @param task
*/
public async publishPolicyLabelAsync(
definitionId: string,
owner: IOwner,
task: NewTask
): Promise<NewTask> {
return await this.sendMessage(MessageAPI.PUBLISH_POLICY_LABEL_ASYNC, { definitionId, owner, task });
}

/**
* Load policy label file for import
* @param zip
* @param owner
*/
public async importPolicyLabel(zip: any, policyId: string, owner: IOwner): Promise<any> {
return await this.sendMessage(MessageAPI.IMPORT_POLICY_LABEL_FILE, { zip, policyId, owner });
}

/**
* Get policy label export file
* @param definitionId
* @param owner
*/
public async exportPolicyLabel(definitionId: string, owner: IOwner) {
const file = await this.sendMessage(MessageAPI.EXPORT_POLICY_LABEL_FILE, { definitionId, owner }) as any;
return Buffer.from(file, 'base64');
}

/**
* Get policy label info from file
* @param zip
* @param owner
*/
public async previewPolicyLabel(zip: any, owner: IOwner): Promise<PolicyLabelDTO> {
return await this.sendMessage(MessageAPI.PREVIEW_POLICY_LABEL_FILE, { zip, owner });
}

/**
* Search labels and statistics
* @param options
* @param owner
*/
public async searchComponents(
options: PolicyLabelFiltersDTO,
owner: IOwner
): Promise<PolicyLabelComponentsDTO> {
return await this.sendMessage(MessageAPI.SEARCH_POLICY_LABEL_COMPONENTS, { options, owner });
}

/**
* Return documents
*
* @param definitionId
* @param owner
* @param pageIndex
* @param pageSize
*
* @returns {ResponseAndCount<any>}
*/
public async getPolicyLabelTokens(
definitionId: string,
owner: IOwner,
pageIndex?: number,
pageSize?: number
): Promise<ResponseAndCount<any>> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_TOKENS, { definitionId, owner, pageIndex, pageSize });
}

/**
* Return documents
*
* @param documentId
* @param definitionId
* @param owner
*
* @returns {any}
*/
public async getPolicyLabelTokenDocuments(
documentId: string,
definitionId: string,
owner: IOwner,
): Promise<any> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_TOKEN_DOCUMENTS, { documentId, definitionId, owner });
}

/**
* Create label document
*
* @param definitionId
* @param data
* @param owner
*
* @returns report
*/
public async createLabelDocument(
definitionId: string,
data: PolicyLabelDocumentDTO,
owner: IOwner
): Promise<PolicyLabelDocumentDTO> {
return await this.sendMessage(MessageAPI.CREATE_POLICY_LABEL_DOCUMENT, { definitionId, data, owner });
}

/**
* Return label documents
*
* @param definitionId
* @param filters
* @param owner
*
* @returns {ResponseAndCount<PolicyLabelDocumentDTO>}
*/
public async getLabelDocuments(
definitionId: string,
filters: IFilter,
owner: IOwner
): Promise<ResponseAndCount<PolicyLabelDocumentDTO>> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_DOCUMENTS,
{ definitionId, filters, owner }
);
}

/**
* Get label document
*
* @param definitionId
* @param documentId
* @param owner
*
* @returns Operation Success
*/
public async getLabelDocument(
definitionId: string,
documentId: string,
owner: IOwner
): Promise<PolicyLabelDocumentDTO> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_DOCUMENT,
{ definitionId, documentId, owner }
);
}

/**
* Get statistic assessment relationships
*
* @param definitionId
* @param documentId
* @param owner
*
* @returns Operation Success
*/
public async getLabelDocumentRelationships(
definitionId: string,
documentId: string,
owner: IOwner
): Promise<PolicyLabelDocumentRelationshipsDTO> {
return await this.sendMessage(MessageAPI.GET_POLICY_LABEL_DOCUMENT_RELATIONSHIPS,
{ definitionId, documentId, owner }
);
}
}
3 changes: 2 additions & 1 deletion api-gateway/src/helpers/task-manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,8 @@ export class TaskManager {
[TaskAction.CREATE_TOOL, 8],
[TaskAction.IMPORT_TOOL_FILE, 9],
[TaskAction.IMPORT_TOOL_MESSAGE, 11],
[TaskAction.MIGRATE_DATA, 4]
[TaskAction.MIGRATE_DATA, 4],
[TaskAction.PUBLISH_POLICY_LABEL, 4]
]);

/**
Expand Down
3 changes: 2 additions & 1 deletion api-gateway/src/middlewares/validation/schemas/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,5 @@ export * from './policies.dto.js'
export * from './profiles.dto.js'
export * from './worker-tasks.dto.js'
export * from './policy-statistics.dto.js'
export * from './schema-rules.dto.js'
export * from './schema-rules.dto.js'
export * from './policy-labels.dto.js'
Loading

0 comments on commit f056433

Please sign in to comment.