@xdev-asia/xdev-knowledge-mcp 1.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +137 -0
- package/content/blog/ai/ai-trong-y-te-healthcare.md +1364 -0
- package/content/blog/ai/gemma-4-mo-hinh-ai-mo-manh-nhat-google-agentic-edge.md +401 -0
- package/content/blog/ai/ollama-mlx-apple-silicon-chay-ai-local-nhanh-hon-3x.md +406 -0
- package/content/blog/database/ma-hoa-du-lieu-healthcare.md +518 -0
- package/content/blog/devops/cai-dat-harbor-tren-ubuntu-24-04.md +168 -0
- package/content/blog/devops/cai-dat-kvm-tren-ubuntu-24-04.md +159 -0
- package/content/blog/devops/cai-dat-kvm-tren-ubuntu-quan-ly-vm-qua-cockpit-web-ui.md +915 -0
- package/content/blog/devops/circuit-breaker-pattern-trong-spring-boot-huong-dan-chi-tiet-tu-a-z.md +1259 -0
- package/content/blog/devops/huong-dan-toan-dien-ve-backup-va-restore-postgresql.md +446 -0
- package/content/blog/devops/huong-dan-upgrade-postgresql-17-6-len-18-1-chuan-production.md +482 -0
- package/content/blog/devops/xay-dung-postgresql-high-availability-cluster-voi-ansible.md +105 -0
- package/content/blog/linux/cai-dat-openvpn-tren-ubuntu-2404.md +43 -0
- package/content/blog/programming/claude-code-source-code-bi-mat-buddy-ultraplan.md +970 -0
- package/content/blog/programming/xay-dung-ai-agent-platform-voi-xclaw-huong-dan-thuc-chien.md +1032 -0
- package/content/blog/security/thiet-ke-kien-truc-phan-quyen-du-lieu-theo-cap-hanh-chinh.md +399 -0
- package/content/metadata/authors/duy-tran.md +23 -0
- package/content/metadata/categories/architecture.md +20 -0
- package/content/metadata/categories/backend.md +23 -0
- package/content/metadata/categories/database-course.md +23 -0
- package/content/metadata/categories/database.md +23 -0
- package/content/metadata/categories/devops.md +23 -0
- package/content/metadata/categories/kubernetes.md +23 -0
- package/content/metadata/categories/linux.md +23 -0
- package/content/metadata/categories/security.md +23 -0
- package/content/metadata/categories/spring-boot.md +23 -0
- package/content/metadata/categories/web-server.md +23 -0
- package/content/metadata/tags/adobe.md +13 -0
- package/content/metadata/tags/aes-256.md +13 -0
- package/content/metadata/tags/ai-agents.md +13 -0
- package/content/metadata/tags/ai-coding.md +13 -0
- package/content/metadata/tags/ai.md +13 -0
- package/content/metadata/tags/aks.md +13 -0
- package/content/metadata/tags/ansible.md +13 -0
- package/content/metadata/tags/anthropic.md +13 -0
- package/content/metadata/tags/apigateway.md +13 -0
- package/content/metadata/tags/argocd.md +13 -0
- package/content/metadata/tags/audit-logging.md +13 -0
- package/content/metadata/tags/authorization.md +13 -0
- package/content/metadata/tags/automated-failover.md +13 -0
- package/content/metadata/tags/backend.md +13 -0
- package/content/metadata/tags/backup-recovery.md +13 -0
- package/content/metadata/tags/backup.md +13 -0
- package/content/metadata/tags/best-practices.md +13 -0
- package/content/metadata/tags/bun.md +13 -0
- package/content/metadata/tags/caching.md +13 -0
- package/content/metadata/tags/canarydeployment.md +13 -0
- package/content/metadata/tags/careerdevelopment.md +13 -0
- package/content/metadata/tags/cdn.md +13 -0
- package/content/metadata/tags/chinh-sua-anh.md +13 -0
- package/content/metadata/tags/chrome-extension.md +13 -0
- package/content/metadata/tags/cicd.md +13 -0
- package/content/metadata/tags/circuit-breaker.md +13 -0
- package/content/metadata/tags/cka.md +13 -0
- package/content/metadata/tags/ckad.md +13 -0
- package/content/metadata/tags/claude-code.md +13 -0
- package/content/metadata/tags/cloud-native.md +13 -0
- package/content/metadata/tags/cloudcomputing.md +13 -0
- package/content/metadata/tags/cluster-management.md +13 -0
- package/content/metadata/tags/cockpit.md +13 -0
- package/content/metadata/tags/container-orchestration.md +13 -0
- package/content/metadata/tags/container.md +13 -0
- package/content/metadata/tags/database-administration.md +13 -0
- package/content/metadata/tags/database-clustering.md +13 -0
- package/content/metadata/tags/database-migration.md +13 -0
- package/content/metadata/tags/database.md +13 -0
- package/content/metadata/tags/datamanagement.md +13 -0
- package/content/metadata/tags/design-pattern.md +13 -0
- package/content/metadata/tags/developer-tools.md +13 -0
- package/content/metadata/tags/devops.md +13 -0
- package/content/metadata/tags/disaster-recovery.md +13 -0
- package/content/metadata/tags/distributed-systems.md +13 -0
- package/content/metadata/tags/docker-registry.md +13 -0
- package/content/metadata/tags/docker.md +13 -0
- package/content/metadata/tags/easy-rsa.md +13 -0
- package/content/metadata/tags/eks.md +13 -0
- package/content/metadata/tags/encryption.md +13 -0
- package/content/metadata/tags/enterprise-architecture.md +13 -0
- package/content/metadata/tags/enterprise.md +13 -0
- package/content/metadata/tags/etcd.md +13 -0
- package/content/metadata/tags/failover.md +13 -0
- package/content/metadata/tags/fault-tolerance.md +13 -0
- package/content/metadata/tags/generative-fill.md +13 -0
- package/content/metadata/tags/gitops.md +13 -0
- package/content/metadata/tags/gke.md +13 -0
- package/content/metadata/tags/grafana.md +13 -0
- package/content/metadata/tags/hands-on.md +13 -0
- package/content/metadata/tags/handson.md +13 -0
- package/content/metadata/tags/harbor.md +13 -0
- package/content/metadata/tags/healthcare.md +13 -0
- package/content/metadata/tags/helm.md +13 -0
- package/content/metadata/tags/high-availability.md +13 -0
- package/content/metadata/tags/highavailability.md +13 -0
- package/content/metadata/tags/hipaa.md +13 -0
- package/content/metadata/tags/homelab.md +13 -0
- package/content/metadata/tags/hono.md +13 -0
- package/content/metadata/tags/http2.md +13 -0
- package/content/metadata/tags/https.md +13 -0
- package/content/metadata/tags/hypervisor.md +13 -0
- package/content/metadata/tags/iam.md +10 -0
- package/content/metadata/tags/infrastructure-as-code.md +13 -0
- package/content/metadata/tags/infrastructure.md +13 -0
- package/content/metadata/tags/ingress.md +13 -0
- package/content/metadata/tags/istio.md +13 -0
- package/content/metadata/tags/java.md +13 -0
- package/content/metadata/tags/javascript.md +13 -0
- package/content/metadata/tags/k8s.md +13 -0
- package/content/metadata/tags/keycloak.md +10 -0
- package/content/metadata/tags/kimchi.md +13 -0
- package/content/metadata/tags/kubernetes.md +13 -0
- package/content/metadata/tags/kvm.md +13 -0
- package/content/metadata/tags/ldap.md +10 -0
- package/content/metadata/tags/libvirt.md +13 -0
- package/content/metadata/tags/linux.md +13 -0
- package/content/metadata/tags/loadbalancer.md +13 -0
- package/content/metadata/tags/mcp.md +13 -0
- package/content/metadata/tags/mfa.md +10 -0
- package/content/metadata/tags/microservices.md +13 -0
- package/content/metadata/tags/mien-phi.md +13 -0
- package/content/metadata/tags/mongodb.md +13 -0
- package/content/metadata/tags/monitoring.md +13 -0
- package/content/metadata/tags/monorepo.md +13 -0
- package/content/metadata/tags/multi-tenant.md +13 -0
- package/content/metadata/tags/networking.md +13 -0
- package/content/metadata/tags/nginx.md +13 -0
- package/content/metadata/tags/oauth2.md +10 -0
- package/content/metadata/tags/oidc.md +10 -0
- package/content/metadata/tags/open-source.md +13 -0
- package/content/metadata/tags/openvpn.md +13 -0
- package/content/metadata/tags/passkeys.md +10 -0
- package/content/metadata/tags/patroni.md +13 -0
- package/content/metadata/tags/performance.md +13 -0
- package/content/metadata/tags/pg-upgrade.md +13 -0
- package/content/metadata/tags/phi.md +13 -0
- package/content/metadata/tags/photoshop-web.md +13 -0
- package/content/metadata/tags/photoshop.md +13 -0
- package/content/metadata/tags/pii.md +13 -0
- package/content/metadata/tags/postgresql-18.md +13 -0
- package/content/metadata/tags/postgresql-high-availability-voi-patroni-etcd-course.md +13 -0
- package/content/metadata/tags/postgresql.md +13 -0
- package/content/metadata/tags/production-deployment.md +13 -0
- package/content/metadata/tags/production.md +13 -0
- package/content/metadata/tags/prometheus.md +13 -0
- package/content/metadata/tags/qemu.md +13 -0
- package/content/metadata/tags/rag.md +13 -0
- package/content/metadata/tags/ratelimiting.md +13 -0
- package/content/metadata/tags/rbac.md +13 -0
- package/content/metadata/tags/react.md +13 -0
- package/content/metadata/tags/realworld.md +13 -0
- package/content/metadata/tags/replication.md +13 -0
- package/content/metadata/tags/resilience4j.md +13 -0
- package/content/metadata/tags/rest-api.md +13 -0
- package/content/metadata/tags/reverseproxy.md +13 -0
- package/content/metadata/tags/rls.md +13 -0
- package/content/metadata/tags/roeadwarrior.md +13 -0
- package/content/metadata/tags/runtime.md +13 -0
- package/content/metadata/tags/saml.md +10 -0
- package/content/metadata/tags/security.md +13 -0
- package/content/metadata/tags/self-hosted.md +13 -0
- package/content/metadata/tags/server.md +13 -0
- package/content/metadata/tags/spring-boot.md +13 -0
- package/content/metadata/tags/sre.md +13 -0
- package/content/metadata/tags/ssl.md +13 -0
- package/content/metadata/tags/sso.md +10 -0
- package/content/metadata/tags/statefulset.md +13 -0
- package/content/metadata/tags/storage.md +13 -0
- package/content/metadata/tags/streaming-replication.md +13 -0
- package/content/metadata/tags/system-administration.md +13 -0
- package/content/metadata/tags/system-design.md +13 -0
- package/content/metadata/tags/systemadmin.md +13 -0
- package/content/metadata/tags/systemadministration.md +13 -0
- package/content/metadata/tags/thiet-ke-do-hoa.md +13 -0
- package/content/metadata/tags/tutorial.md +13 -0
- package/content/metadata/tags/typescript.md +13 -0
- package/content/metadata/tags/ubuntu-2404.md +13 -0
- package/content/metadata/tags/ubuntu.md +13 -0
- package/content/metadata/tags/virtual-machines.md +13 -0
- package/content/metadata/tags/virtualization.md +13 -0
- package/content/metadata/tags/vpn-server.md +13 -0
- package/content/metadata/tags/web-ui.md +13 -0
- package/content/metadata/tags/webserver.md +13 -0
- package/content/metadata/tags/workflow.md +13 -0
- package/content/pages/chinh-sach-quyen-rieng-tu.md +31 -0
- package/content/pages/dieu-khoan-su-dung.md +26 -0
- package/content/pages/gioi-thieu.md +23 -0
- package/content/pages/privacy-policy.md +100 -0
- package/content/pages/your-privacy-choices.md +53 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/02-bai-1-tong-quan-ai-ml-dl-va-llm.md +274 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/03-bai-2-toan-hoc-cho-ai.md +552 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/04-bai-3-neural-networks-co-ban.md +557 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-ai-deep-learning/lessons/05-bai-4-deep-learning-overview.md +471 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/06-bai-5-attention-mechanism.md +262 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/07-bai-6-kien-truc-transformer.md +360 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/08-bai-7-bert-va-encoder-only-models.md +328 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/09-bai-8-gpt-va-decoder-only-models.md +358 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/02-phan-2-kien-truc-transformer/lessons/10-bai-9-tokenization.md +506 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/11-bai-10-pre-training-llms.md +283 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/12-bai-11-supervised-fine-tuning.md +469 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/13-bai-12-peft-lora-qlora.md +420 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/03-phan-3-training-fine-tuning/lessons/14-bai-13-rlhf-va-alignment.md +419 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/15-bai-14-prompt-engineering.md +334 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/16-bai-15-advanced-prompting.md +352 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/17-bai-16-rag-retrieval-augmented-generation.md +428 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/04-phan-4-prompting-rag/lessons/18-bai-17-vector-databases.md +471 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/05-phan-5-ai-applications/lessons/19-bai-18-ai-agents.md +455 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/05-phan-5-ai-applications/lessons/20-bai-19-llm-apis.md +441 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-nang-cao/lessons/21-bai-20-deploying-llms-va-evaluation.md +456 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-nang-cao/lessons/22-bai-21-ollama-apple-silicon.md +1254 -0
- package/content/series/ai/ai-llm-tu-co-ban-den-nang-cao/index.md +376 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/01-bai-1-tong-quan-fashion-ai-platform-tach-lop-ai.md +292 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/02-bai-2-kien-truc-ai-system-microservices-model-pipeline.md +403 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/01-phan-1-kien-truc-ai-system/lessons/03-bai-3-ai-tech-stack-diffusion-vision-llm-mlops.md +427 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/04-bai-4-text-to-design-fine-tune-stable-diffusion.md +435 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/05-bai-5-image-reference-analysis-clip-style-transfer.md +349 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/06-bai-6-multi-modal-generation-text-image.md +260 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/02-phan-2-ai-design-generation-engine/lessons/07-bai-7-prompt-engineering-cho-fashion.md +269 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/08-bai-8-print-ready-ai-layout-rules-safe-margins.md +322 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/09-bai-9-auto-scaling-design-resize-theo-size-form.md +242 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/10-bai-10-ai-editing-assistant-natural-language.md +319 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/03-phan-3-ai-design-optimization-editing/lessons/11-bai-11-ai-typography-generate-text-font-placement.md +285 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/12-bai-12-style-analysis-engine-phan-tich-gu-tham-my.md +257 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/13-bai-13-behavioral-learning-hoc-hanh-vi-preference.md +303 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/14-bai-14-ai-recommendation-system-goi-y-design.md +258 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/04-phan-4-ai-personalization-recommendation/lessons/15-bai-15-ai-size-recommendation-body-measurement.md +264 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/16-bai-16-body-estimation-du-doan-body-shape.md +317 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/17-bai-17-3d-avatar-generation-tao-avatar.md +339 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/18-bai-18-garment-rendering-render-ao-len-avatar.md +325 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/05-phan-5-virtual-try-on-computer-vision/lessons/19-bai-19-real-time-virtual-try-on-360-rotation.md +371 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/20-bai-20-print-file-optimization-rgb-cmyk-dpi.md +364 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/21-bai-21-ai-auto-tagging-gan-tag-phan-loai.md +363 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/22-bai-22-ai-product-generation-title-description-mockup.md +327 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/23-bai-23-trending-detection-xu-huong-content-moderation.md +402 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/chapters/06-phan-6-ai-cho-production-pipeline/lessons/24-bai-24-production-deployment-mlops-pipeline-scaling.md +574 -0
- package/content/series/ai/ai-thuc-chien-fashion-print-on-demand/index.md +482 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/02-bai-1-ai-y-te-tong-quan.md +388 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/03-bai-2-du-lieu-y-te-dicom-fhir.md +576 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/01-phan-1-nen-tang-ai-y-te-medical-data/lessons/04-bai-3-medical-image-processing.md +534 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/05-bai-4-cnn-medical-classification.md +614 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/06-bai-5-unet-segmentation.md +525 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/02-phan-2-medical-imaging-ai-computer-vision-cho-y-te/lessons/07-bai-6-detection-pathology.md +627 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/08-bai-7-clinical-nlp.md +223 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/09-bai-8-medical-qa-chatbot.md +318 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/10-bai-9-drug-discovery-gnn.md +300 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/03-phan-3-clinical-nlp-genomics-ai/lessons/11-bai-10-genomics-protein.md +302 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/12-bai-11-federated-learning-y-te.md +291 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/13-bai-12-xai-y-te.md +276 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/14-bai-13-fda-regulatory.md +267 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/15-bai-14-deploy-medical-ai.md +332 -0
- package/content/series/ai/ai-trong-y-te-healthcare/chapters/04-phan-4-production-compliance/lessons/16-bai-15-capstone-medical-ai.md +435 -0
- package/content/series/ai/ai-trong-y-te-healthcare/index.md +208 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/02-bai-1-agent-la-gi.md +365 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/03-bai-2-llm-apis-masterclass.md +271 -0
- package/content/series/ai/build-ai-agents/chapters/01-phan-1-nen-tang-agent/lessons/04-bai-3-prompt-engineering-cho-agent.md +164 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/05-bai-4-function-calling.md +161 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/06-bai-5-xay-dung-custom-tools.md +124 -0
- package/content/series/ai/build-ai-agents/chapters/02-phan-2-function-calling-tool-use/lessons/07-bai-6-the-agent-loop.md +117 -0
- package/content/series/ai/build-ai-agents/chapters/03-phan-3-rag-memory/lessons/08-bai-7-rag-cho-agent.md +82 -0
- package/content/series/ai/build-ai-agents/chapters/03-phan-3-rag-memory/lessons/09-bai-8-agent-memory.md +76 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/10-bai-9-langchain-langgraph.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/11-bai-10-crewai.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/04-phan-4-agentic-frameworks/lessons/12-bai-11-advanced-patterns.md +73 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/13-bai-12-mcp.md +68 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/14-bai-13-a2a-protocol.md +65 -0
- package/content/series/ai/build-ai-agents/chapters/05-phan-5-mcp-a2a-multi-agent/lessons/15-bai-14-multi-agent-orchestration.md +76 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/16-bai-15-guardrails-safety.md +74 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/17-bai-16-observability-evaluation.md +74 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/18-bai-17-deploy-agent-production.md +85 -0
- package/content/series/ai/build-ai-agents/chapters/06-phan-6-production/lessons/19-bai-18-capstone-project.md +129 -0
- package/content/series/ai/build-ai-agents/index.md +372 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/02-bai-1-computer-vision-la-gi.md +450 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/03-bai-2-cnn-deep-dive.md +514 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/01-phan-1-nen-tang-cv/lessons/04-bai-3-transfer-learning.md +427 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/05-bai-4-yolo-object-detection.md +374 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/06-bai-5-train-yolo-custom.md +440 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/02-phan-2-object-detection/lessons/07-bai-6-realtime-detection.md +359 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/08-bai-7-image-segmentation.md +310 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/09-bai-8-sam-segment-anything.md +373 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/10-bai-9-image-generation.md +332 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/03-phan-3-segmentation-modern-cv/lessons/11-bai-10-vision-transformer-clip.md +413 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/04-phan-4-ung-dung-thuc-te/lessons/12-bai-11-ocr-document-understanding.md +353 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/04-phan-4-ung-dung-thuc-te/lessons/13-bai-12-multimodal-ai.md +342 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/05-phan-5-deployment-capstone/lessons/14-bai-13-edge-deployment.md +628 -0
- package/content/series/ai/computer-vision-deep-learning/chapters/05-phan-5-deployment-capstone/lessons/15-bai-14-capstone.md +653 -0
- package/content/series/ai/computer-vision-deep-learning/index.md +287 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/02-bai-1-fine-tuning-la-gi.md +247 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/03-bai-2-fine-tuning-vs-rag.md +224 -0
- package/content/series/ai/fine-tuning-llm/chapters/01-phan-1-tong-quan-chien-luoc/lessons/04-bai-3-chi-phi-fine-tuning.md +129 -0
- package/content/series/ai/fine-tuning-llm/chapters/02-phan-2-chuan-bi-du-lieu/lessons/05-bai-4-thu-thap-thiet-ke-dataset.md +102 -0
- package/content/series/ai/fine-tuning-llm/chapters/02-phan-2-chuan-bi-du-lieu/lessons/06-bai-5-data-cleaning-augmentation.md +96 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/07-bai-6-vertex-ai-setup.md +93 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/08-bai-7-fine-tune-gemini-flash.md +107 -0
- package/content/series/ai/fine-tuning-llm/chapters/03-phan-3-fine-tuning-gemini/lessons/09-bai-8-fine-tune-gemini-production.md +83 -0
- package/content/series/ai/fine-tuning-llm/chapters/04-phan-4-fine-tuning-openai/lessons/10-bai-9-fine-tune-openai.md +79 -0
- package/content/series/ai/fine-tuning-llm/chapters/04-phan-4-fine-tuning-openai/lessons/11-bai-10-lora-qlora.md +96 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/12-bai-11-metrics-danh-gia-llm.md +100 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/13-bai-12-llm-as-a-judge.md +93 -0
- package/content/series/ai/fine-tuning-llm/chapters/05-phan-5-danh-gia-model/lessons/14-bai-13-evaluation-pipeline.md +101 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/15-bai-14-deployment.md +88 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/16-bai-15-common-pitfalls.md +81 -0
- package/content/series/ai/fine-tuning-llm/chapters/06-phan-6-production/lessons/17-bai-16-capstone.md +118 -0
- package/content/series/ai/fine-tuning-llm/index.md +363 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/01-phan-1-foundation-gemma-4-local-stack/lessons/01-bai-1-thiet-ke-local-ai-architecture-cho-team-dev.md +343 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/01-phan-1-foundation-gemma-4-local-stack/lessons/02-bai-2-setup-gemma-4-voi-ollama-va-open-webui-tren-mac.md +106 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/02-phan-2-integration-api-prompting/lessons/03-bai-3-xay-api-gateway-cho-gemma-4-va-policy-tang-ung-dung.md +108 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/02-phan-2-integration-api-prompting/lessons/04-bai-4-prompt-contracts-json-schema-va-regression-test-cho-llm.md +102 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/03-phan-3-rag-engineering-du-lieu-noi-bo/lessons/05-bai-5-ingestion-chunking-va-vector-indexing-cho-tieng-viet.md +101 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/03-phan-3-rag-engineering-du-lieu-noi-bo/lessons/06-bai-6-hybrid-retrieval-bm25-vector-reranker.md +84 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/04-phan-4-reliability-cost-production-hardening/lessons/07-bai-7-eval-framework-observability-va-slo-cho-genai.md +82 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/chapters/04-phan-4-reliability-cost-production-hardening/lessons/08-bai-8-hardening-va-rollout-local-ai-stack-cho-doanh-nghiep.md +90 -0
- package/content/series/ai/gemma-4-local-ai-engineering-tren-mac/index.md +64 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/02-bai-1-generative-ai-la-gi.md +233 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/03-bai-2-gan.md +299 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/01-phan-1-nen-tang-generative-ai/lessons/04-bai-3-vae.md +280 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/05-bai-4-diffusion-models.md +229 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/06-bai-5-stable-diffusion.md +236 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/02-phan-2-diffusion-models/lessons/07-bai-6-prompt-engineering.md +227 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/08-bai-7-controlnet.md +220 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/09-bai-8-inpainting.md +242 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/03-phan-3-image-generation-nang-cao/lessons/10-bai-9-lora-custom-training.md +254 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/04-phan-4-dall-e-midjourney-apis/lessons/11-bai-10-dall-e-3-api.md +251 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/04-phan-4-dall-e-midjourney-apis/lessons/12-bai-11-midjourney-flux.md +220 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/13-bai-12-video-generation.md +242 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/14-bai-13-audio-music.md +232 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/05-phan-5-video-generation/lessons/15-bai-14-3d-generation.md +245 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/16-bai-15-comfyui.md +260 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/17-bai-16-api-server.md +349 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/18-bai-17-ai-safety.md +280 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/chapters/06-phan-6-production/lessons/19-bai-18-capstone.md +379 -0
- package/content/series/ai/generative-ai-tao-hinh-anh-video/index.md +339 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/02-bai-1-recsys-tong-quan.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/03-bai-2-collaborative-filtering.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/01-phan-1-nen-tang-recommendation-systems/lessons/04-bai-3-matrix-factorization.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/05-bai-4-content-based-features.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/06-bai-5-neural-cf-embedding.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/07-bai-6-two-tower-retrieval.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/02-phan-2-deep-learning-cho-recommendation/lessons/08-bai-7-sequence-models-recsys.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/09-bai-8-gnn-recommendation.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/10-bai-9-knowledge-graph-recsys.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/03-phan-3-advanced-recsys-knowledge-graph-multi-task-gnn/lessons/11-bai-10-multi-task-ranking.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/12-bai-11-llm-recommendations.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/13-bai-12-production-recsys-architecture.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/14-bai-13-ab-testing-evaluation.md +103 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/chapters/04-phan-4-recsys-production-deploy-scale/lessons/15-bai-14-capstone-recsys.md +53 -0
- package/content/series/ai/he-thong-goi-y-recommendation-systems/index.md +199 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/01-bai-1-ml-la-gi.md +206 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/02-bai-2-setup-moi-truong-ml.md +242 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/03-bai-3-python-pandas-crash-course.md +243 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/04-bai-4-model-dau-tien-baseline.md +186 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/01-phan-0-khoi-dong-cho-nguoi-moi-week-0/lessons/05-bai-5-mini-project-1-du-doan-gia-nha.md +165 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/06-bai-6-linear-regression-gradient-descent.md +113 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/07-bai-7-logistic-regression.md +100 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/08-bai-8-metrics-quan-trong.md +96 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/09-bai-9-overfitting-underfitting.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/02-phan-1-supervised-learning-nen-tang/lessons/10-bai-10-mini-project-2-churn.md +100 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/11-bai-11-missing-categorical-feature-engineering.md +89 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/12-bai-12-pipelines-columntransformer.md +91 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/13-bai-13-cross-validation-tuning.md +86 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/14-bai-14-data-leakage-error-analysis.md +85 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/03-phan-2-workflow-chuan-cong-nghiep/lessons/15-bai-15-challenge-house-prices.md +84 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/index.md +27 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/16-bai-16-decision-tree-random-forest-xgboost.md +82 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/17-bai-17-clustering.md +81 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/18-bai-18-pca-tsne-umap.md +76 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/19-bai-19-anomaly-detection.md +76 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/04-phan-3-thuat-toan-nang-cao-vua-du-dung/lessons/20-bai-20-time-series-forecasting.md +84 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/index.md +28 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/21-bai-21-explainability-fairness.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/22-bai-22-model-serving-fastapi-docker.md +95 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/23-bai-23-monitoring-drift-retraining.md +88 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/chapters/05-phan-4-production-explainability-va-capstone/lessons/24-bai-24-capstone-ml-end-to-end.md +74 -0
- package/content/series/ai/machine-learning-tu-co-ban-den-nang-cao/index.md +364 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/02-bai-1-mlops-la-gi.md +342 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/03-bai-2-experiment-tracking.md +522 -0
- package/content/series/ai/mlops-llmops/chapters/01-phan-1-mlops-foundations/lessons/04-bai-3-data-versioning.md +493 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/05-bai-4-model-registry.md +459 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/06-bai-5-cicd-cho-ml.md +531 -0
- package/content/series/ai/mlops-llmops/chapters/02-phan-2-ml-infrastructure/lessons/07-bai-6-infrastructure.md +548 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/08-bai-7-llmops-vs-mlops.md +413 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/09-bai-8-prompt-management.md +514 -0
- package/content/series/ai/mlops-llmops/chapters/03-phan-3-llmops/lessons/10-bai-9-llm-observability.md +487 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/11-bai-10-cost-optimization.md +511 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/12-bai-11-guardrails-compliance.md +614 -0
- package/content/series/ai/mlops-llmops/chapters/04-phan-4-production-governance/lessons/13-bai-12-capstone.md +712 -0
- package/content/series/ai/mlops-llmops/index.md +276 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/02-bai-1-multimodal-ai-la-gi.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/03-bai-2-clip-contrastive-learning.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/01-phan-1-nen-tang-multimodal-learning/lessons/04-bai-3-vision-encoders-vit.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/05-bai-4-image-captioning.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/06-bai-5-vqa.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/07-bai-6-llava-vlm.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/02-phan-2-vision-language-models-vlms/lessons/08-bai-7-gpt4v-gemini.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/09-bai-8-document-ai-ocr.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/10-bai-9-video-understanding.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/03-phan-3-document-ai-video-understanding/lessons/11-bai-10-text-to-image.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/12-bai-11-multimodal-rag.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/13-bai-12-embodied-ai.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/14-bai-13-deploy-multimodal.md +103 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/chapters/04-phan-4-advanced-multimodal-production/lessons/15-bai-14-capstone-multimodal.md +53 -0
- package/content/series/ai/multimodal-ai-thi-giac-ngon-ngu/index.md +199 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/02-bai-1-nlp-la-gi.md +241 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/03-bai-2-text-preprocessing.md +298 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nlp/lessons/04-bai-3-tokenization-deep-dive.md +235 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/05-bai-4-bow-tfidf-ngrams.md +170 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/06-bai-5-word-embeddings.md +247 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/02-phan-2-bieu-dien-ngon-ngu/lessons/07-bai-6-sentence-document-embeddings.md +189 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/08-bai-7-rnn-lstm.md +182 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/09-bai-8-attention-mechanism.md +168 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/03-phan-3-deep-learning-nlp/lessons/10-bai-9-transformer.md +181 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/11-bai-10-bert.md +170 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/12-bai-11-gpt-autoregressive.md +149 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/04-phan-4-pretrained-language-models/lessons/13-bai-12-hugging-face-ecosystem.md +203 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/14-bai-13-text-classification-sentiment.md +203 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/15-bai-14-ner.md +207 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/16-bai-15-question-answering.md +209 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/05-phan-5-bai-toan-ung-dung/lessons/17-bai-16-summarization-translation.md +164 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/18-bai-17-nlp-tieng-viet.md +190 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/19-bai-18-nlp-pipeline-production.md +243 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/20-bai-19-llm-nlp-hien-dai.md +219 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/chapters/06-phan-6-production-xu-huong/lessons/21-bai-20-capstone-project.md +270 -0
- package/content/series/ai/nlp-tu-co-ban-den-nang-cao/index.md +401 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/01-bai-1-apple-silicon-ai-tai-sao-m-chip-la-vua-inference-local.md +216 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/02-bai-2-cai-dat-ollama-tu-zero-den-chay-llm-trong-5-phut.md +353 -0
- package/content/series/ai/ollama-apple-silicon/chapters/01-phan-1-nen-tang-ollama-apple-silicon/lessons/03-bai-3-chon-model-phu-hop-so-sanh-llm-cho-mac.md +267 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/04-bai-4-mlx-framework-apple-intelligence-duoi-nap-capo.md +267 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/05-bai-5-cai-dat-mlx-lm-va-chay-model-mlx-quantized.md +372 -0
- package/content/series/ai/ollama-apple-silicon/chapters/02-phan-2-mlx-tang-toc-3x/lessons/06-bai-6-ollama-mlx-backend-ket-hop-tot-nhat-cua-hai-the-gioi.md +314 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/07-bai-7-ollama-rest-api-openai-compatible-endpoint.md +395 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/08-bai-8-python-integration-xay-chatbot-local-voi-ollama.md +450 -0
- package/content/series/ai/ollama-apple-silicon/chapters/03-phan-3-tich-hop-api-lap-trinh/lessons/09-bai-9-vision-models-phan-tich-hinh-anh-khong-can-cloud.md +392 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/10-bai-10-toi-uu-hieu-nang-ram-context-concurrency.md +497 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/11-bai-11-modelfiles-custom-models-va-system-prompts.md +481 -0
- package/content/series/ai/ollama-apple-silicon/chapters/04-phan-4-toi-uu-quan-ly-production/lessons/12-bai-12-workflow-hoan-chinh-personal-ai-setup-2026.md +637 -0
- package/content/series/ai/ollama-apple-silicon/index.md +57 -0
- package/content/series/ai/ollama-apple-silicon/index.md.tmp +239 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/02-bai-1-prompt-engineering-la-gi.md +362 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/03-bai-2-system-prompts-persona.md +433 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/01-phan-1-nen-tang/lessons/04-bai-3-few-shot-zero-shot.md +424 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/05-bai-4-chain-of-thought.md +320 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/06-bai-5-tree-of-thoughts.md +294 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/02-phan-2-ky-thuat-nang-cao/lessons/07-bai-6-structured-output.md +355 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/08-bai-7-prompt-cho-code.md +323 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/09-bai-8-prompt-data-business.md +333 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/03-phan-3-ung-dung-thuc-te/lessons/10-bai-9-multimodal-prompting.md +327 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/11-bai-10-prompt-testing.md +437 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/12-bai-11-prompt-versioning.md +473 -0
- package/content/series/ai/prompt-engineering-masterclass/chapters/04-phan-4-production/lessons/13-bai-12-capstone.md +423 -0
- package/content/series/ai/prompt-engineering-masterclass/index.md +266 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/02-bai-1-rag-la-gi.md +349 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/03-bai-2-embedding-models.md +308 -0
- package/content/series/ai/rag-thuc-chien/chapters/01-phan-1-nen-tang-rag/lessons/04-bai-3-vector-databases.md +351 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/05-bai-4-document-loading.md +302 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/06-bai-5-chunking-strategies.md +320 -0
- package/content/series/ai/rag-thuc-chien/chapters/02-phan-2-document-processing/lessons/07-bai-6-metadata-hybrid-search.md +385 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/08-bai-7-query-transformation.md +335 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/09-bai-8-reranking-compression.md +319 -0
- package/content/series/ai/rag-thuc-chien/chapters/03-phan-3-query-retrieval/lessons/10-bai-9-graph-rag.md +351 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/11-bai-10-multimodal-rag.md +359 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/12-bai-11-agentic-rag.md +366 -0
- package/content/series/ai/rag-thuc-chien/chapters/04-phan-4-advanced-rag/lessons/13-bai-12-rag-evaluation.md +318 -0
- package/content/series/ai/rag-thuc-chien/chapters/05-phan-5-production-capstone/lessons/14-bai-13-deploy-rag-production.md +395 -0
- package/content/series/ai/rag-thuc-chien/chapters/05-phan-5-production-capstone/lessons/15-bai-14-capstone.md +409 -0
- package/content/series/ai/rag-thuc-chien/index.md +285 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/02-bai-1-rl-la-gi.md +139 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/03-bai-2-dynamic-programming.md +139 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/04-bai-3-monte-carlo-td.md +154 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-rl/lessons/05-bai-4-q-learning.md +148 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/06-bai-5-dqn.md +161 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/07-bai-6-policy-gradient.md +144 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/08-bai-7-ppo.md +130 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/02-phan-2-deep-rl/lessons/09-bai-8-sac.md +126 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/10-bai-9-gymnasium.md +149 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/11-bai-10-custom-env.md +142 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/03-phan-3-frameworks/lessons/12-bai-11-robotics.md +116 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/13-bai-12-rlhf.md +122 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/14-bai-13-dpo.md +118 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/15-bai-14-multi-agent.md +120 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/16-bai-15-rl-production.md +153 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/chapters/04-phan-4-rlhf-production/lessons/17-bai-16-capstone.md +156 -0
- package/content/series/ai/reinforcement-learning-tu-co-ban-den-nang-cao/index.md +280 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/02-bai-1-digital-audio-signal-processing.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/03-bai-2-audio-feature-extraction.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/01-phan-1-nen-tang-xu-ly-am-thanh-tin-hieu/lessons/04-bai-3-audio-classification.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/05-bai-4-asr-architecture.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/06-bai-5-whisper-modern-asr.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/02-phan-2-speech-recognition-asr-nhan-dang-giong-noi/lessons/07-bai-6-realtime-asr-streaming.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/08-bai-7-tts-tacotron-vits.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/09-bai-8-voice-cloning.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/03-phan-3-text-to-speech-voice-technologies/lessons/10-bai-9-speaker-verification-diarization.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/11-bai-10-speech-enhancement.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/12-bai-11-music-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/13-bai-12-emotion-recognition.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/14-bai-13-vietnamese-speech-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/15-bai-14-deploy-speech-ai.md +103 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/chapters/04-phan-4-advanced-audio-ai-production/lessons/16-bai-15-capstone-voice-assistant.md +53 -0
- package/content/series/ai/speech-audio-ai-xu-ly-giong-noi-am-thanh/index.md +208 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/02-bai-1-time-series-fundamentals.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/03-bai-2-arima-sarima-ets.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/01-phan-1-nen-tang-time-series-analysis/lessons/04-bai-3-prophet-forecasting.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/05-bai-4-feature-engineering.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/06-bai-5-xgboost-lightgbm.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/02-phan-2-machine-learning-cho-time-series/lessons/07-bai-6-multivariate-hierarchical.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/08-bai-7-lstm-sequence-models.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/09-bai-8-transformers-time-series.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/03-phan-3-deep-learning-cho-time-series/lessons/10-bai-9-foundation-models.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/11-bai-10-anomaly-detection.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/12-bai-11-classification-clustering.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/13-bai-12-financial-time-series.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/14-bai-13-production-pipeline.md +103 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/chapters/04-phan-4-ung-dung-production/lessons/15-bai-14-capstone-forecasting.md +53 -0
- package/content/series/ai/time-series-ai-du-doan-chuoi-thoi-gian/index.md +199 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/01-bai-1-tong-quan-kien-truc.md +287 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/02-bai-2-setup-typescript-monorepo.md +283 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/03-bai-3-dual-database.md +212 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/01-phan-1-kien-truc-monorepo/lessons/04-bai-4-api-gateway-hono.md +143 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/05-bai-5-llm-router.md +268 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/06-bai-6-tool-registry.md +208 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/07-bai-7-agent-class.md +248 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/02-phan-2-llm-engine-agent-core/lessons/08-bai-8-streaming-eventbus.md +234 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/09-bai-9-document-processor.md +214 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/10-bai-10-embedding-vector-store.md +236 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/03-phan-3-rag-pipeline/lessons/11-bai-11-rag-engine.md +240 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/04-phan-4-workflow-engine/lessons/12-bai-12-workflow-engine.md +222 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/04-phan-4-workflow-engine/lessons/13-bai-13-workflow-validation-execution.md +260 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/14-bai-14-skill-system.md +224 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/15-bai-15-domain-packs.md +220 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/05-phan-5-skills-domains-plugins/lessons/16-bai-16-plugin-mcp.md +304 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/06-phan-6-multi-tenant-rbac-channels/lessons/17-bai-17-multi-tenant-rbac.md +291 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/06-phan-6-multi-tenant-rbac-channels/lessons/18-bai-18-chat-channels.md +212 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/07-phan-7-frontend-monitoring-production/lessons/19-bai-19-react-frontend.md +1025 -0
- package/content/series/ai/xay-dung-ai-agent-platform/chapters/07-phan-7-frontend-monitoring-production/lessons/20-bai-20-monitoring-deploy.md +352 -0
- package/content/series/ai/xay-dung-ai-agent-platform/index.md +388 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/01-bai-1-cloud-native-la-gi-nguyen-ly-va-twelve-factor-app.md +298 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/02-bai-2-container-docker-nen-tang-dong-goi-ung-dung.md +364 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/01-phan-1-cloud-native-foundations/lessons/03-bai-3-kubernetes-architecture-core-concepts.md +460 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/04-bai-4-microservices-design-principles-srp-ddd-bounded-context.md +328 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/05-bai-5-synchronous-communication-rest-api-grpc.md +379 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/06-bai-6-asynchronous-communication-message-queue-event-streaming.md +303 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/02-phan-2-system-design-communication-patterns/lessons/07-bai-7-api-gateway-pattern-kong-apisix-envoy.md +314 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/08-bai-8-database-per-service-polyglot-persistence.md +270 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/09-bai-9-event-sourcing-cqrs.md +302 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/10-bai-10-saga-pattern-distributed-transactions.md +479 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/03-phan-3-data-management/lessons/11-bai-11-data-consistency-patterns-outbox-cdc-eventual-consistency.md +445 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/12-bai-12-service-discovery-registry.md +459 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/13-bai-13-service-mesh-istio-linkerd.md +423 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/04-phan-4-service-mesh-networking/lessons/14-bai-14-zero-trust-security-mtls.md +444 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/15-bai-15-metrics-prometheus-grafana.md +541 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/16-bai-16-logging-structured-logging-loki-elk.md +510 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/05-phan-5-observability/lessons/17-bai-17-distributed-tracing-opentelemetry-jaeger.md +583 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/18-bai-18-circuit-breaker-retry-patterns.md +471 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/19-bai-19-bulkhead-rate-limiting-health-check-patterns.md +493 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/06-phan-6-resiliency-patterns/lessons/20-bai-20-chaos-engineering-kiem-chung-do-tin-cay.md +414 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/21-bai-21-cicd-pipeline-cho-microservices.md +461 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/22-bai-22-gitops-voi-argocd.md +499 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/07-phan-7-cicd-deployment/lessons/23-bai-23-deployment-strategies-canary-blue-green-progressive-delivery.md +496 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/24-bai-24-authentication-authorization-oauth2-jwt-oidc.md +485 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/25-bai-25-secrets-management-container-security.md +533 -0
- package/content/series/architecture/cloud-native-microservices-architecture/chapters/08-phan-8-security-production-readiness/lessons/26-bai-26-production-readiness-checklist-lo-trinh-trien-khai.md +499 -0
- package/content/series/architecture/cloud-native-microservices-architecture/index.md +396 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/01-bai-1-gioi-thieu-hl7-va-lich-su-chuan-du-lieu-y-te.md +296 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/02-bai-2-tong-quan-fhir-r5-kien-truc-va-nguyen-tac-thiet-ke.md +447 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hl7-va-fhir/lessons/03-bai-3-cai-dat-moi-truong-phat-trien-fhir.md +413 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/04-bai-4-patient-practitioner-organization-resources-hanh-chinh.md +446 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/05-bai-5-encounter-condition-observation-resources-lam-sang.md +548 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/06-bai-6-medication-medicationrequest-immunization-resources-thuoc.md +363 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/02-phan-2-fhir-resources-cot-loi/lessons/07-bai-7-diagnosticreport-procedure-allergyintolerance-resources-chan-doan.md +411 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/08-bai-8-fhir-restful-api-crud-search-history-va-versioning.md +324 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/09-bai-9-bundle-transaction-va-batch-xu-ly-nhieu-resources.md +319 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/03-phan-3-fhir-restful-api-va-data-exchange/lessons/10-bai-10-search-parameters-va-tim-kiem-nang-cao.md +219 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/11-bai-11-fhir-data-types-primitive-complex-va-special.md +318 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/12-bai-12-terminologies-codesystem-valueset-conceptmap.md +278 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/04-phan-4-data-types-terminologies-va-profiles/lessons/13-bai-13-profiles-extensions-va-implementation-guides.md +320 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/14-bai-14-fhir-documents-va-messaging.md +277 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/15-bai-15-fhir-subscriptions-va-real-time-notifications.md +250 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/16-bai-16-smart-on-fhir-oauth2-va-ung-dung-y-te.md +243 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/05-phan-5-tich-hop-messaging-va-security/lessons/17-bai-17-security-privacy-va-consent-trong-fhir.md +358 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/18-bai-18-hands-on-xay-dung-fhir-server-voi-hapi-fhir.md +399 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/19-bai-19-hands-on-fhir-client-va-tich-hop-ung-dung.md +353 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/20-bai-20-hands-on-xay-dung-implementation-guide-cho-viet-nam.md +335 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/06-phan-6-thuc-hanh-xay-dung-he-thong-fhir/lessons/21-bai-21-hands-on-tich-hop-fhir-voi-emr-his-thuc-te.md +453 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/22-bai-22-fhir-performance-scalability-va-monitoring.md +353 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/23-bai-23-fhir-trong-boi-canh-y-te-viet-nam.md +244 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/24-bai-24-case-studies-us-core-ips-va-trien-khai-thuc-te.md +247 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-quy-mo-va-tuong-lai/lessons/25-bai-25-tuong-lai-fhir-r6-ai-ml-genomics-va-xu-huong-moi.md +404 -0
- package/content/series/architecture/hl7-fhir-chuan-du-lieu-y-te-tu-co-ban-den-nang-cao/index.md +427 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/01-bai-1-tong-quan-data-platform-evolution-architecture-patterns.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/02-bai-2-data-lakehouse-architecture-iceberg-delta-lake-hudi.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/01-phan-1-data-platform-foundations/lessons/03-bai-3-data-mesh-domain-oriented-data-architecture.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/04-bai-4-batch-processing-etl-elt-voi-airflow-dbt.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/05-bai-5-stream-processing-kafka-flink-real-time-pipeline.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/06-bai-6-change-data-capture-cdc-debezium-event-sourcing.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/02-phan-2-data-ingestion-pipeline/lessons/07-bai-7-data-integration-api-ingestion.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/08-bai-8-data-modeling-dimensional-modeling-activity-schema.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/09-bai-9-storage-layer-object-storage-columnar-formats-partitioning.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/03-phan-3-data-storage-modeling/lessons/10-bai-10-query-engines-trino-duckdb-materialized-views.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/11-bai-11-data-quality-framework-testing-monitoring-alerting.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/12-bai-12-data-catalog-discovery-metadata-management.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/13-bai-13-data-governance-access-control.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/04-phan-4-data-quality-governance/lessons/14-bai-14-data-contracts-schema-evolution.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/15-bai-15-semantic-layer-metrics-store-business-logic.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/16-bai-16-bi-visualization-dashboard-architecture.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/05-phan-5-analytics-semantic-layer/lessons/17-bai-17-real-time-analytics-clickhouse-streaming-dashboards.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/18-bai-18-feature-store-feature-engineering-at-scale.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/19-bai-19-ml-pipeline-integration-training-serving-data.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/06-phan-6-ml-data-platform/lessons/20-bai-20-reverse-etl-operational-analytics.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-infrastructure-cost-optimization.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-data-platform-security-privacy.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-dataops-platform-engineering.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-observability-cho-data-platform.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-uber-netflix-airbnb-spotify.md +155 -0
- package/content/series/architecture/kien-truc-data-platform-analytics/index.md +318 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/01-bai-1-tong-quan-edtech-domain-analysis-business-models.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/02-bai-2-lms-platform-architecture-microservices-ddd.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/01-phan-1-edtech-foundations/lessons/03-bai-3-learning-standards-scorm-xapi-lti.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/04-bai-4-course-management-system-curriculum-enrollment.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/05-bai-5-content-authoring-rich-media.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/06-bai-6-video-delivery-hls-dash-adaptive-streaming.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/02-phan-2-course-content-management/lessons/07-bai-7-live-class-webinar-architecture.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/08-bai-8-assessment-engine-question-bank-quiz-system.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/09-bai-9-coding-assessment-auto-grading.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/10-bai-10-gamification-engine-points-badges-leaderboards.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/03-phan-3-assessment-gamification/lessons/11-bai-11-certificate-engine-credential-verification.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/12-bai-12-adaptive-learning-personalized-learning-paths.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/13-bai-13-ai-tutor-learning-assistant.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/04-phan-4-personalization-ai/lessons/14-bai-14-recommendation-engine-what-to-learn-next.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/15-bai-15-real-time-collaboration-shared-workspace.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/16-bai-16-discussion-forum-social-learning.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/05-phan-5-collaboration-community/lessons/17-bai-17-notification-engagement-engine.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/18-bai-18-learning-analytics-tracking-insights.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/19-bai-19-marketplace-instructor-platform.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/06-phan-6-analytics-business/lessons/20-bai-20-payment-subscription-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-mobile-first-architecture-offline-learning.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-scalability-performance-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-security-privacy-cho-edtech.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-accessibility-internationalization.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-coursera-udemy-duolingo-khan-academy.md +155 -0
- package/content/series/architecture/kien-truc-edtech-lms-platform/index.md +314 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/01-bai-1-tong-quan-enterprise-ai-chatbot.md +234 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/02-bai-2-platform-architecture-overview.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/01-phan-1-foundation-platform-overview/lessons/03-bai-3-multi-model-gateway.md +663 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/01-bai-4-conversation-management.md +486 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/02-bai-5-rag-pipeline.md +450 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/03-bai-6-prompt-engineering-engine.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/02-phan-2-core-chatbot-engine/lessons/04-bai-7-streaming-realtime.md +557 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/01-bai-8-function-calling-tool-use.md +409 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/02-bai-9-multi-agent-orchestration.md +423 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/03-bai-10-planning-reflection.md +463 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/03-phan-3-agentic-architecture/lessons/04-bai-11-structured-data-querying.md +382 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/01-bai-12-guardrails-ai-safety.md +396 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/02-bai-13-knowledge-base-management.md +376 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/03-bai-14-multi-tenant-architecture.md +345 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/04-phan-4-enterprise-features-safety/lessons/04-bai-15-analytics-observability.md +350 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/01-bai-16-multi-channel-integration.md +381 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/02-bai-17-human-handoff-hybrid-support.md +384 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/03-bai-18-chatbot-evaluation-testing.md +355 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/05-phan-5-multi-channel-scale/lessons/04-bai-19-personalization-long-term-memory.md +405 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/01-bai-20-domain-specific-ai.md +330 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/02-bai-21-multimodal-ai.md +364 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/06-phan-6-advanced-ai-capabilities/lessons/03-bai-22-workflow-automation.md +526 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/01-bai-23-gpu-infrastructure.md +473 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/02-bai-24-security-compliance.md +510 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/chapters/07-phan-7-infrastructure-security-production/lessons/03-bai-25-case-studies.md +721 -0
- package/content/series/architecture/kien-truc-enterprise-ai-chatbot-platform/index.md +407 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/01-bai-1-tong-quan-event-driven-architecture-why-events-matter.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/02-bai-2-domain-events-event-modeling.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/01-phan-1-event-driven-foundations/lessons/03-bai-3-messaging-patterns-pub-sub-queue-stream.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/04-bai-4-kafka-architecture-brokers-partitions-replication.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/05-bai-5-kafka-producers-consumers-advanced-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/06-bai-6-kafka-streams-ksqldb.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/02-phan-2-kafka-deep-dive/lessons/07-bai-7-schema-registry-data-serialization.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/08-bai-8-event-sourcing-immutable-event-log-source-of-truth.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/09-bai-9-cqrs-command-query-responsibility-segregation.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/10-bai-10-event-store-implementation-postgresql-eventstoredb.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/03-phan-3-event-sourcing-cqrs/lessons/11-bai-11-projections-read-model-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/12-bai-12-saga-pattern-managing-distributed-transactions.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/13-bai-13-outbox-pattern-reliable-event-publishing.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/14-bai-14-dead-letter-queue-error-handling.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/04-phan-4-distributed-patterns/lessons/15-bai-15-idempotency-exactly-once-processing.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/16-bai-16-event-driven-microservices-communication-patterns.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/17-bai-17-event-driven-data-consistency-conflict-resolution.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/18-bai-18-event-versioning-schema-evolution.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/05-phan-5-advanced-patterns/lessons/19-bai-19-process-manager-workflow-engine.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/20-bai-20-kafka-operations-monitoring-tuning-troubleshooting.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/21-bai-21-testing-event-driven-systems.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/06-phan-6-operations-production/lessons/22-bai-22-observability-cho-event-driven-systems.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/23-bai-23-migration-to-event-driven-strangler-fig-pattern.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/24-bai-24-apache-pulsar-alternatives.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/chapters/07-phan-7-case-studies/lessons/25-bai-25-case-studies-uber-wix-booking-com-linkedin.md +155 -0
- package/content/series/architecture/kien-truc-event-driven-microservices-chuyen-sau/index.md +316 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/01-bai-1-tong-quan-fintech-domain-analysis-business-models.md +331 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/02-bai-2-platform-architecture-overview-microservices-ddd-cho-fintech.md +399 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/01-phan-1-nen-tang-fintech-payment/lessons/03-bai-3-regulatory-compliance-pci-dss-psd2-quy-dinh-nhnn.md +319 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/04-bai-4-payment-gateway-architecture-luong-thanh-toan-end-to-end.md +408 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/05-bai-5-payment-processing-authorization-capture-settlement.md +349 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/06-bai-6-multi-psp-integration-vnpay-momo-zalopay-stripe.md +267 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/02-phan-2-core-payment-engine/lessons/07-bai-7-reconciliation-settlement-engine.md +257 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/08-bai-8-digital-wallet-architecture-e-wallet-balance-management.md +277 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/09-bai-9-double-entry-ledger-system-accounting-engine.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/10-bai-10-transaction-processing-acid-idempotency-saga-pattern.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/03-phan-3-digital-wallet-ledger-system/lessons/11-bai-11-currency-exchange-rate-engine-multi-currency.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/12-bai-12-fraud-detection-system-rule-engine-ml-models.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/13-bai-13-anti-money-laundering-aml-kyc-pipeline.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/04-phan-4-risk-management-fraud-detection/lessons/14-bai-14-risk-scoring-real-time-transaction-monitoring.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/15-bai-15-core-banking-architecture-account-management.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/16-bai-16-lending-platform-loan-origination-underwriting.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/17-bai-17-credit-scoring-engine-data-pipeline-ml.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/05-phan-5-banking-lending-platform/lessons/18-bai-18-interest-calculation-amortization-engine.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/19-bai-19-financial-data-pipeline-event-streaming-cdc.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/20-bai-20-reporting-business-intelligence-regulatory-reports.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/06-phan-6-data-platform-analytics/lessons/21-bai-21-real-time-analytics-dashboard.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/22-bai-22-security-architecture-encryption-hsm-tokenization.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/23-bai-23-infrastructure-high-availability-multi-region-dr.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/24-bai-24-performance-scalability-handling-peak-transactions.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/chapters/07-phan-7-infrastructure-security-production/lessons/25-bai-25-case-studies-vnpay-momo-grabpay-stripe.md +155 -0
- package/content/series/architecture/kien-truc-fintech-payment-platform/index.md +402 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/01-bai-1-tong-quan-fashion-design-print-on-demand.md +169 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/02-bai-2-product-lifecycle-design-workflow.md +265 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/01-phan-1-tong-quan-domain-fashion-pod/lessons/03-bai-3-system-architecture-overview.md +298 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/01-bai-4-design-studio-canvas-editor.md +374 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/02-bai-5-ai-design-generation.md +435 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/03-bai-6-ai-pattern-textile-design.md +350 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/02-phan-2-ai-powered-design-studio/lessons/04-bai-7-mockup-engine-3d-visualization.md +407 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/01-bai-8-product-catalog-sku-architecture.md +349 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/02-bai-9-multi-channel-sales-integration.md +329 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/03-bai-10-pricing-engine-revenue-model.md +349 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/03-phan-3-product-ecommerce-platform/lessons/04-bai-11-cart-checkout-payment.md +373 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/01-bai-12-order-management-system.md +372 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/02-bai-13-print-production-pipeline.md +329 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/03-bai-14-supplier-network-routing-engine.md +355 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/04-phan-4-order-processing-fulfillment/lessons/04-bai-15-shipping-logistics.md +355 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/01-bai-16-ai-recommendation-personalization.md +294 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/02-bai-17-ai-quality-control.md +344 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/05-phan-5-ai-intelligence-personalization/lessons/03-bai-18-ai-trend-forecasting-demand-prediction.md +353 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/01-bai-19-data-architecture-event-streaming.md +358 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/02-bai-20-analytics-dashboard.md +134 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/06-phan-6-data-platform-analytics/lessons/03-bai-21-ml-pipeline-feature-store.md +160 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/01-bai-22-infrastructure-devops-kubernetes.md +96 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/02-bai-23-performance-scaling.md +127 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/03-bai-24-security-ip-protection-compliance.md +135 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/chapters/07-phan-7-operations-security-scale/lessons/04-bai-25-case-studies-industry-analysis.md +130 -0
- package/content/series/architecture/kien-truc-he-thong-fashion-design-print-on-demand/index.md +402 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/01-bai-1-tong-quan-saas-business-models-metrics-architecture.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/02-bai-2-multi-tenancy-deep-dive-isolation-strategies-trade-offs.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/01-phan-1-saas-foundations/lessons/03-bai-3-platform-architecture-overview-ddd-microservices-cho-saas.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/04-bai-4-tenant-lifecycle-management-provisioning-configuration.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/05-bai-5-identity-access-management-multi-tenant-auth-sso.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/06-bai-6-onboarding-engine-self-service-signup-guided-setup.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/02-phan-2-tenant-management-identity/lessons/07-bai-7-data-isolation-multi-tenant-database-patterns.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/08-bai-8-subscription-engine-plans-pricing-lifecycle.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/09-bai-9-usage-metering-billing-engine.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/03-phan-3-billing-subscription-engine/lessons/10-bai-10-entitlement-system-feature-gating.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/11-bai-11-feature-flags-configuration-management.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/12-bai-12-plugin-extension-architecture-marketplace.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/13-bai-13-white-labeling-custom-branding.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/04-phan-4-core-platform-features/lessons/14-bai-14-notification-communication-engine.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/15-bai-15-api-design-developer-experience.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/16-bai-16-data-import-export-migration-tools.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/17-bai-17-search-analytics-per-tenant.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/05-phan-5-data-api-platform/lessons/18-bai-18-audit-logging-compliance.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/19-bai-19-noisy-neighbor-resource-isolation.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/20-bai-20-multi-region-deployment-data-residency.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/06-phan-6-scaling-operations/lessons/21-bai-21-tenant-aware-cicd-infrastructure-automation.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-observability-sre-cho-multi-tenant.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-security-architecture-cho-saas.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-admin-portal-self-service-operations.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-slack-notion-atlassian-linear.md +155 -0
- package/content/series/architecture/kien-truc-multi-tenant-saas-platform/index.md +314 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/01-bai-1-tong-quan-platform-engineering-why-what-how.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/02-bai-2-developer-experience-dx-measuring-improving.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/01-phan-1-platform-engineering-foundations/lessons/03-bai-3-platform-architecture-overview-layers-components.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/04-bai-4-backstage-internal-developer-portal.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/05-bai-5-service-catalog-software-templates.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/06-bai-6-api-portal-documentation.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/02-phan-2-developer-portal/lessons/07-bai-7-golden-paths-paved-roads.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/08-bai-8-self-service-infrastructure-provisioning-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/09-bai-9-infrastructure-as-code-terraform-crossplane-pulumi.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/10-bai-10-environment-management-dev-staging-production.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/03-phan-3-self-service-infrastructure/lessons/11-bai-11-database-middleware-self-service.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/12-bai-12-cicd-platform-architecture-pipeline-as-code.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/13-bai-13-gitops-deployment-automation.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/14-bai-14-container-image-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/04-phan-4-cicd-platform/lessons/15-bai-15-testing-platform-shift-left-quality-gates.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/16-bai-16-security-platform-policy-as-code.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/17-bai-17-supply-chain-security-sbom-slsa.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/05-phan-5-security-compliance-platform/lessons/18-bai-18-cost-management-finops-platform.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/19-bai-19-observability-platform-metrics-logs-traces.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/20-bai-20-sre-platform-slo-error-budgets-incident-management.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/06-phan-6-observability-platform/lessons/21-bai-21-logging-audit-platform.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-platform-team-organization-operating-model.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-platform-migration-adoption.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-measuring-platform-success-metrics-roi.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-spotify-netflix-airbnb-mercado-libre.md +155 -0
- package/content/series/architecture/kien-truc-platform-engineering-internal-developer-portal/index.md +316 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/01-bai-1-tong-quan-iot-platform-architecture-ecosystem.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/02-bai-2-iot-protocols-mqtt-coap-amqp-websocket.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/01-phan-1-iot-foundations/lessons/03-bai-3-platform-architecture-overview-cloud-edge-hybrid.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/04-bai-4-device-management-provisioning-registry-lifecycle.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/05-bai-5-iot-security-device-authentication-encryption.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/06-bai-6-ota-updates-remote-configuration.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/02-phan-2-device-connectivity/lessons/07-bai-7-gateway-architecture-protocol-translation.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/08-bai-8-edge-computing-architecture-processing-at-the-edge.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/09-bai-9-edge-ai-on-device-inference.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/03-phan-3-edge-computing/lessons/10-bai-10-edge-cloud-synchronization-offline-mode.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/11-bai-11-time-series-database-timescaledb-influxdb-questdb.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/12-bai-12-iot-data-pipeline-ingestion-processing-storage.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/04-phan-4-data-processing-storage/lessons/13-bai-13-rule-engine-complex-event-processing.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/14-bai-14-digital-twin-architecture-virtual-representation.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/15-bai-15-real-time-monitoring-dashboard-visualization.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/05-phan-5-digital-twin-visualization/lessons/16-bai-16-predictive-maintenance-anomaly-detection.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/17-bai-17-smart-factory-industrial-iot-iiot-architecture.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/18-bai-18-smart-building-energy-management.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/19-bai-19-connected-vehicles-fleet-management.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/06-phan-6-industry-applications/lessons/20-bai-20-agriculture-iot-environmental-monitoring.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/21-bai-21-scalability-handling-millions-of-devices.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/22-bai-22-iot-platform-on-kubernetes.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/23-bai-23-iot-data-analytics-machine-learning.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/24-bai-24-observability-monitoring-cho-iot-platform.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/chapters/07-phan-7-production-case-studies/lessons/25-bai-25-case-studies-aws-iot-azure-iot-bosch-iot.md +155 -0
- package/content/series/architecture/kien-truc-real-time-iot-platform/index.md +314 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/01-bai-1-ohdsi-la-gi-tong-quan-he-sinh-thai-va-tam-nhin.md +275 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/02-bai-2-omop-cdm-cau-truc-nguyen-ly-domain.md +439 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/01-phan-1-tong-quan-ohdsi-omop-cdm/lessons/03-bai-3-athena-tra-cuu-quan-ly-standardized-vocabularies.md +390 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/04-bai-4-whiterabbit-rabbit-in-a-hat-khao-sat-du-lieu-thiet-ke-etl.md +326 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/05-bai-5-usagi-mapping-ma-nguon-sang-omop-standard-concepts.md +327 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/02-phan-2-etl-chuan-hoa-du-lieu/lessons/06-bai-6-xay-dung-etl-pipeline-tu-du-lieu-nguon-sang-omop-cdm.md +452 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/07-bai-7-cai-dat-omop-cdm-database-tren-postgresql.md +400 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/08-bai-8-webapi-cai-dat-cau-hinh-rest-api.md +395 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/03-phan-3-trien-khai-platform/lessons/09-bai-9-atlas-cai-dat-tich-hop-webapi-giao-dien-tong-quan.md +300 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/10-bai-10-atlas-concept-sets-cohort-definitions.md +341 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/11-bai-11-atlas-characterization-incidence-rates-pathways.md +310 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/04-phan-4-phan-tich-du-lieu-atlas/lessons/12-bai-12-atlas-population-level-estimation-patient-level-prediction.md +453 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/13-bai-13-achilles-data-characterization-source-profiling.md +382 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/14-bai-14-data-quality-dashboard-danh-gia-chat-luong-du-lieu-cdm.md +409 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/05-phan-5-data-quality-advanced-analytics/lessons/15-bai-15-hades-r-packages-cho-nghien-cuu-quan-sat.md +537 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/06-phan-6-production-network-studies/lessons/16-bai-16-trien-khai-ohdsi-stack-tren-docker-kubernetes.md +650 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/chapters/06-phan-6-production-network-studies/lessons/17-bai-17-network-studies-best-practices-nghien-cuu-da-trung-tam.md +520 -0
- package/content/series/architecture/ohdsi-omop-cdm-phan-tich-du-lieu-y-te-toan-dien/index.md +341 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/01-bai-1-system-design-la-gi-tong-quan-va-roadmap.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/02-bai-2-performance-vs-scalability.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/03-bai-3-latency-throughput-availability-consistency.md +355 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/01-phan-1-nen-tang-system-design/lessons/04-bai-4-networking-fundamentals.md +318 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/05-bai-5-load-balancer.md +339 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/06-bai-6-cdn.md +222 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/07-bai-7-caching-strategies.md +279 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/02-phan-2-infrastructure-components/lessons/08-bai-8-reverse-proxy-api-gateway.md +268 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/09-bai-9-sql-vs-nosql.md +252 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/10-bai-10-database-replication.md +268 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/11-bai-11-database-sharding.md +294 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/03-phan-3-database-architecture/lessons/12-bai-12-data-storage-patterns.md +310 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/13-bai-13-message-queues.md +289 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/14-bai-14-event-driven-architecture.md +319 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/04-phan-4-async-processing/lessons/15-bai-15-stream-processing.md +309 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/16-bai-16-monolith-to-microservices.md +292 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/17-bai-17-service-communication.md +328 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/18-bai-18-domain-driven-design.md +317 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/05-phan-5-architectural-patterns/lessons/19-bai-19-serverless-cloud-native.md +291 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/20-bai-20-high-availability.md +274 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/21-bai-21-disaster-recovery.md +281 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/22-bai-22-security-architecture.md +309 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/06-phan-6-reliability-security-observability/lessons/23-bai-23-observability.md +356 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/24-bai-24-url-shortener.md +257 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/25-bai-25-chat-system.md +266 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/26-bai-26-news-feed.md +252 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/27-bai-27-video-streaming.md +271 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/28-bai-28-ride-sharing.md +290 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/07-phan-7-case-studies/lessons/29-bai-29-e-commerce.md +311 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/chapters/08-phan-8-production-ready/lessons/30-bai-30-architecture-decision-records.md +361 -0
- package/content/series/architecture/system-architecture-from-zero-to-hero/index.md +486 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/01-bai-1-tu-monolith-den-microservices-micro-frontend.md +238 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/02-bai-2-domain-driven-design-tu-duy-phan-tach-he-thong.md +259 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/01-phan-1-nen-tang-evolution-of-architecture/lessons/03-bai-3-kien-truc-tong-quan-full-stack.md +160 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/04-bai-4-service-decomposition.md +195 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/05-bai-5-api-design-masterclass.md +211 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/02-phan-2-thiet-ke-microservices-backend/lessons/06-bai-6-inter-service-communication.md +185 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/07-bai-7-database-per-service.md +153 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/08-bai-8-saga-pattern.md +176 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/03-phan-3-data-architecture/lessons/09-bai-9-event-sourcing-cqrs.md +171 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/10-bai-10-micro-frontend-la-gi.md +141 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/11-bai-11-integration-strategies.md +141 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/04-phan-4-micro-frontend-kien-truc-nguyen-ly/lessons/12-bai-12-module-federation-deep-dive.md +203 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/13-bai-13-shell-application.md +169 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/14-bai-14-state-management.md +157 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/15-bai-15-design-system.md +134 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/05-phan-5-xay-dung-micro-frontend-thuc-te/lessons/16-bai-16-authentication-sso.md +159 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/17-bai-17-bff-pattern.md +174 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/18-bai-18-api-gateway.md +224 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/06-phan-6-api-gateway-bff-layer/lessons/19-bai-19-graphql-federation.md +223 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/20-bai-20-testing-microservices.md +222 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/21-bai-21-testing-micro-frontend.md +185 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/07-phan-7-testing-full-stack/lessons/22-bai-22-contract-testing.md +212 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/23-bai-23-mono-repo-vs-multi-repo.md +198 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/24-bai-24-cicd-pipeline.md +249 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/08-phan-8-cicd-deployment-strategies/lessons/25-bai-25-deployment-strategies.md +213 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/26-bai-26-observability.md +207 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/27-bai-27-performance-optimization.md +218 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/09-phan-9-observability-production-readiness/lessons/28-bai-28-production-readiness.md +242 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/10-phan-10-case-studies-migration/lessons/29-bai-29-case-study-ecommerce.md +219 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/chapters/10-phan-10-case-studies-migration/lessons/30-bai-30-migration-guide.md +281 -0
- package/content/series/architecture/thiet-ke-he-thong-microservices-micro-frontend/index.md +550 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/01-bai-1-tong-quan-he-thong-notification-bai-toan-gui-trieu-email.md +200 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/02-bai-2-kien-truc-tong-quan-high-level-design.md +369 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/01-phan-1-nen-tang-bai-toan-notification/lessons/03-bai-3-design-patterns-cho-email-system-quy-mo-lon.md +375 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/04-bai-4-message-queue-xuong-song-cua-notification-system.md +355 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/05-bai-5-event-driven-notification-pipeline-voi-kafka.md +434 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/02-phan-2-message-queue-event-driven/lessons/06-bai-6-priority-queue-va-scheduling-engine.md +388 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/07-bai-7-smtp-deep-dive-hieu-email-delivery-tu-goc.md +372 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/08-bai-8-email-service-providers-ses-sendgrid-mailgun.md +434 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/03-phan-3-email-infrastructure/lessons/09-bai-9-template-engine-va-content-pipeline.md +431 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/10-bai-10-rate-limiting-throttling-kiem-soat-toc-do-gui.md +267 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/11-bai-11-batch-processing-worker-pool-architecture.md +294 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/04-phan-4-xu-ly-quy-mo-scaling-to-millions/lessons/12-bai-12-retry-dead-letter-queue-error-handling.md +272 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/13-bai-13-email-deliverability-spf-dkim-dmarc.md +235 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/14-bai-14-monitoring-metrics-alerting.md +258 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/chapters/05-phan-5-deliverability-monitoring-production/lessons/15-bai-15-production-deployment-case-study-gui-10-trieu-email.md +289 -0
- package/content/series/architecture/thiet-ke-he-thong-notification-gui-email-quy-mo-lon/index.md +313 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/01-bai-1-tong-quan-bao-mat-du-lieu-y-te-hipaa-hl7-fhir.md +317 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/02-bai-2-kien-truc-microservices-an-toan-cho-y-te.md +574 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/03-bai-3-phan-loai-du-lieu-y-te-phi-va-danh-gia-rui-ro.md +375 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/01-phan-1-nen-tang-bao-mat-du-lieu-y-te/lessons/04-bai-4-threat-modeling-stride-dread-cho-his.md +491 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/01-bai-5-thiet-ke-keycloak-realm-chuan-y-te.md +515 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/02-bai-6-rbac-abac-phan-quyen-nhan-vien-y-te.md +494 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/03-bai-7-smart-on-fhir-oauth2-oidc-healthcare-apis.md +497 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/02-phan-2-identity-access-management-keycloak/lessons/04-bai-8-mfa-passkeys-emergency-access-nhan-vien-y-te.md +405 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/01-bai-9-postgresql-security-hardening-toan-dien.md +1036 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/02-bai-10-ma-hoa-du-lieu-at-rest-in-transit-postgresql.md +1028 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/03-bai-11-row-level-security-column-encryption-phi.md +1093 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/03-phan-3-bao-mat-postgresql-du-lieu-y-te/lessons/04-bai-12-audit-logging-cdc-pgaudit.md +1226 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/01-bai-13-quarkus-security-oidc-jwt-rbac.md +1317 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/02-bai-14-api-gateway-rate-limiting-waf.md +1287 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/03-bai-15-ma-hoa-du-lieu-end-to-end-microservices.md +1232 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/04-phan-4-bao-mat-microservices-quarkus/lessons/04-bai-16-mtls-service-mesh-inter-service-communication.md +1387 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/01-bai-17-hipaa-technical-safeguards-implementation.md +1500 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/02-bai-18-centralized-audit-trail-opentelemetry-elk.md +1415 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/03-bai-19-data-masking-anonymization-de-identification.md +1376 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/05-phan-5-compliance-audit-data-protection/lessons/04-bai-20-backup-dr-business-continuity-du-lieu-y-te.md +1351 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/01-bai-21-zero-trust-architecture-he-thong-y-te.md +1507 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/02-bai-22-container-kubernetes-security-healthcare.md +1521 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/03-bai-23-penetration-testing-vulnerability-assessment-y-te.md +1697 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/chapters/06-phan-6-nang-cao-va-du-an-thuc-hanh/lessons/04-bai-24-capstone-xay-dung-secure-healthcare-platform.md +1881 -0
- package/content/series/devsecops/bao-mat-du-lieu-y-te-cho-microservices/index.md +441 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/01-bai-1-tong-quan-kien-truc-microservices-on-premises.md +964 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/02-bai-2-lap-ke-hoach-phan-cung-va-network-topology.md +1019 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/03-bai-3-chuan-bi-linux-os-va-system-tuning.md +731 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/01-phan-1-nen-tang-thiet-ke-ha-tang/lessons/04-bai-4-load-balancer-cho-kubernetes-api-server.md +708 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/01-bai-5-cai-dat-containerd-va-kubeadm.md +410 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/02-bai-6-khoi-tao-kubernetes-ha-control-plane.md +449 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/03-bai-7-join-them-control-plane-va-worker-nodes.md +356 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/04-bai-8-cai-dat-cilium-cni.md +547 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/05-bai-9-metallb-loadbalancer-cho-on-premises.md +369 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/02-phan-2-kubernetes-ha-cluster/lessons/06-bai-10-etcd-van-hanh-backup-va-disaster-recovery.md +546 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/01-bai-11-kien-truc-distributed-storage-voi-rook-ceph.md +426 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/02-bai-12-cai-dat-rook-ceph-operator-va-cephcluster.md +383 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/03-bai-13-cephblockpool-storageclass-va-pvc.md +392 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/04-bai-14-cephfs-shared-filesystem-cho-readwritemany.md +307 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/03-phan-3-distributed-storage-rook-ceph/lessons/05-bai-15-ceph-monitoring-tuning-va-troubleshooting.md +329 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/01-bai-16-kien-truc-postgresql-ha-voi-patroni-va-cloudnativepg.md +302 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/02-bai-17-deploy-cloudnativepg-operator-va-postgresql-cluster.md +367 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/03-bai-18-postgresql-backup-pitr-va-disaster-recovery.md +319 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/04-bai-19-postgresql-failover-testing-va-switchover.md +277 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/04-phan-4-postgresql-ha-patroni-cloudnativepg/lessons/05-bai-20-postgresql-monitoring-tuning-va-day-2-operations.md +409 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/01-bai-21-rabbitmq-ha-cluster-tren-kubernetes.md +487 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/02-bai-22-apache-kafka-cluster-voi-strimzi-operator.md +573 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/05-phan-5-message-queue-ha/lessons/03-bai-23-redis-ha-sentinel-va-cluster-mode.md +482 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/01-bai-24-kien-truc-istio-service-mesh.md +364 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/02-bai-25-istio-traffic-management.md +375 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/03-bai-26-istio-gateway-va-ingress.md +385 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/06-phan-6-service-mesh-ingress-istio/lessons/04-bai-27-istio-security-authorizationpolicy.md +350 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/01-bai-28-gitops-voi-argocd.md +396 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/02-bai-29-helm-charts-cho-microservices.md +423 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/03-bai-30-secrets-management-vault.md +368 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/07-phan-7-gitops-argocd-helm-vault/lessons/04-bai-31-cicd-pipeline-gitops.md +345 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/01-bai-32-prometheus-stack-monitoring.md +409 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/02-bai-33-loki-centralized-logging.md +337 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/03-bai-34-tempo-distributed-tracing.md +388 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/08-phan-8-observability-prometheus-loki-tempo/lessons/04-bai-35-grafana-dashboards-va-slo-monitoring.md +347 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/01-bai-36-rbac-va-pod-security-standards.md +314 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/02-bai-37-kyverno-policy-engine.md +402 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/03-bai-38-falco-runtime-security.md +307 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/09-phan-9-security-hardening/lessons/04-bai-39-harbor-registry-va-image-security.md +350 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/01-bai-40-canary-va-blue-green-deployment.md +320 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/02-bai-41-horizontal-va-vertical-pod-autoscaling.md +343 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/03-bai-42-resource-management-va-scheduling.md +301 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/10-phan-10-deployment-patterns-auto-scaling/lessons/04-bai-43-multi-tenancy-va-namespace-isolation.md +316 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/11-phan-11-disaster-recovery-chaos-engineering/lessons/01-bai-44-disaster-recovery-va-backup-strategies.md +309 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/11-phan-11-disaster-recovery-chaos-engineering/lessons/02-bai-45-chaos-engineering-voi-litmus.md +325 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/01-bai-46-production-readiness-checklist.md +183 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/02-bai-47-day-2-operations-va-maintenance.md +302 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/03-bai-48-performance-testing-va-optimization.md +284 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/04-bai-49-troubleshooting-guide.md +256 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/chapters/12-phan-12-production-operations-capstone/lessons/05-bai-50-capstone-project-ecommerce-microservices.md +289 -0
- package/content/series/devsecops/deploy-microservices-on-premises-voi-kubernetes-ha/index.md +851 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/01-bai-1-gioi-thieu-docker-container-va-virtualization.md +229 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/02-bai-2-cai-dat-docker-va-cac-lenh-co-ban.md +242 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/03-bai-3-docker-images-build-pull-va-quan-ly.md +230 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-docker/lessons/04-bai-4-docker-containers-vong-doi-va-quan-ly.md +256 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/05-bai-5-dockerfile-tu-a-den-z.md +330 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/06-bai-6-multi-stage-builds-va-toi-uu-docker-image.md +243 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/07-bai-7-docker-registry-docker-hub-va-private-registry.md +184 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/02-phan-2-dockerfile-va-image-optimization/lessons/08-bai-8-docker-compose-co-ban.md +324 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/09-bai-9-docker-networking-deep-dive.md +192 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/10-bai-10-docker-volumes-va-persistent-storage.md +254 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/11-bai-11-docker-compose-nang-cao.md +297 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-storage-compose-nang-cao/lessons/12-bai-12-environment-variables-secrets-va-configuration.md +245 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/13-bai-13-docker-security-best-practices.md +249 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/14-bai-14-docker-logging-va-monitoring.md +316 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/15-bai-15-docker-trong-ci-cd-pipeline.md +298 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/04-phan-4-security-monitoring-cicd/lessons/16-bai-16-docker-performance-tuning.md +238 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/17-bai-17-docker-swarm-container-orchestration.md +347 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/18-bai-18-docker-cho-microservices-architecture.md +434 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/19-bai-19-docker-voi-kubernetes-migration-path.md +408 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/20-bai-20-production-deployment-va-troubleshooting.md +602 -0
- package/content/series/devsecops/docker-tu-co-ban-den-nang-cao/index.md +519 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/01-bai-1-gioi-thieu-hashicorp-vault-secret-management-trong-enterprise.md +200 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/02-bai-2-cai-dat-vault-standalone-docker-va-kubernetes.md +217 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/03-bai-3-vault-cli-api-va-web-ui.md +151 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/04-bai-4-seal-unseal-auto-unseal-va-recovery-keys.md +866 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-hashicorp-vault/lessons/05-bai-5-tokens-leases-va-renewal.md +985 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/06-bai-6-kv-secrets-engine-static-secrets-management.md +642 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/07-bai-7-database-secrets-engine-dynamic-credentials.md +645 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/08-bai-8-pki-secrets-engine-certificate-authority.md +708 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/09-bai-9-transit-secrets-engine-encryption-as-a-service.md +703 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/02-phan-2-secrets-engines/lessons/10-bai-10-aws-azure-gcp-va-cloud-secrets-engines.md +753 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/11-bai-11-auth-methods-co-ban-token-userpass-va-approle.md +553 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/12-bai-12-ldap-oidc-va-jwt-auth-methods.md +397 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/13-bai-13-kubernetes-aws-va-cloud-auth-methods.md +329 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/14-bai-14-policies-acl-sentinel-va-rbac.md +388 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-methods-xac-thuc-va-uy-quyen/lessons/15-bai-15-identity-secrets-engine-entities-va-mfa.md +314 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/16-bai-16-ssh-secrets-engine-va-totp.md +256 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/17-bai-17-transform-va-tokenization-data-protection.md +238 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/04-phan-4-secrets-engines-nang-cao/lessons/18-bai-18-kmip-consul-nomad-secrets-engines-va-custom-plugins.md +292 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/05-phan-5-vault-agent-proxy-va-kubernetes-integration/lessons/19-bai-19-vault-agent-va-vault-proxy.md +396 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/05-phan-5-vault-agent-proxy-va-kubernetes-integration/lessons/20-bai-20-vault-tren-kubernetes-helm-operator-va-csi.md +407 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/21-bai-21-tich-hop-vault-voi-spring-boot-va-nodejs.md +313 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/22-bai-22-vault-voi-terraform-ansible-va-cicd-pipelines.md +408 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/23-bai-23-high-availability-integrated-storage-va-production-hardening.md +334 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/24-bai-24-vault-enterprise-namespaces-replication-va-dr.md +255 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-enterprise-va-van-hanh/lessons/25-bai-25-monitoring-audit-logging-backup-restore-va-troubleshooting.md +366 -0
- package/content/series/devsecops/hashicorp-vault-tu-co-ban-den-nang-cao/index.md +655 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/01-bai-1-gioi-thieu-keycloak-iam-va-sso-trong-enterprise.md +237 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/02-bai-2-cai-dat-keycloak-standalone-docker-va-kubernetes.md +288 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/03-bai-3-admin-console-va-tao-realm-dau-tien.md +495 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/04-bai-4-quan-ly-users-groups-va-user-profile.md +582 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-keycloak/lessons/05-bai-5-roles-permissions-va-access-control.md +771 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/01-bai-6-openid-connect-clients-cau-hinh-tu-a-den-z.md +1008 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/02-bai-7-saml-clients-va-protocol-mappers.md +681 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/03-bai-8-client-scopes-token-management-va-dpop.md +744 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/02-phan-2-sso-protocols/lessons/04-bai-9-client-policies-va-advanced-client-configuration.md +781 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/01-bai-10-authentication-flows-tuy-chinh-luong-xac-thuc.md +566 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/02-bai-11-multi-factor-authentication-otp-webauthn-va-passkeys.md +587 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-mfa-identity-brokering/lessons/03-bai-12-identity-brokering-va-social-login.md +707 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/01-bai-13-user-federation-ldap-va-active-directory.md +645 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/02-bai-14-organizations-multi-tenancy-va-ciam.md +465 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/03-bai-15-authorization-services-phan-quyen-chi-tiet.md +801 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/04-phan-4-user-federation-organizations-authorization/lessons/04-bai-16-workflows-tu-dong-hoa-quan-tri-voi-iga.md +861 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/01-bai-17-tuy-chinh-giao-dien-keycloak-themes.md +869 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/02-bai-18-event-system-va-audit-logging.md +894 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/05-phan-5-themes-events-security-vault/lessons/03-bai-19-bao-mat-nang-cao-va-vault-integration.md +858 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/01-bai-20-tich-hop-spring-boot-va-quarkus.md +1039 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/02-bai-21-tich-hop-react-angular-va-nodejs.md +1146 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/06-phan-6-tich-hop-ung-dung-thuc-te/lessons/03-bai-22-api-gateway-nginx-va-microservices.md +1076 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/01-bai-23-trien-khai-production-va-performance-tuning.md +931 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/02-bai-24-high-availability-clustering-va-multi-site.md +1225 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/chapters/07-phan-7-production-ha-kubernetes/lessons/03-bai-25-kubernetes-operator-monitoring-va-admin-cli.md +1654 -0
- package/content/series/devsecops/keycloak-tu-co-ban-den-nang-cao/index.md +677 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/02-bai-1-gioi-thieu-kubernetes-va-container-orchestration.md +466 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/03-bai-2-kien-truc-kubernetes.md +458 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/04-bai-3-cai-dat-moi-truong-kubernetes-2026.md +597 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/01-module-1-gioi-thieu-va-kien-truc/lessons/05-thuc-hanh-1-thiet-lap-cluster-va-cong-cu.md +656 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/06-bai-5-pods.md +217 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/07-bai-6-replicasets-va-deployments.md +261 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/08-bai-7-services-va-endpointslices.md +195 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/09-bai-8-namespaces.md +212 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/02-module-2-kubernetes-objects-co-ban/lessons/10-thuc-hanh-2-kubernetes-objects-co-ban.md +325 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/11-bai-10-configmaps-va-secrets.md +767 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/12-bai-11-persistent-storage.md +476 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/13-bai-12-statefulsets.md +556 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/03-module-3-configuration-va-storage/lessons/14-thuc-hanh-3-configuration-va-storage.md +322 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/15-bai-14-kubernetes-networking-model.md +164 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/16-bai-15-gateway-api-chuan-moi-thay-ingress.md +275 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/17-bai-16-network-policies.md +264 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/04-module-4-networking/lessons/18-thuc-hanh-4-networking-voi-cilium-va-gateway-api.md +342 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/19-bai-18-jobs-va-cronjobs.md +428 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/20-bai-19-daemonsets.md +522 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/21-bai-20-autoscaling.md +592 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/22-bai-21-dynamic-resource-allocation-dra.md +224 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/05-module-5-workload-management/lessons/23-thuc-hanh-5-workload-management.md +336 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/24-bai-23-authentication-va-authorization.md +213 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/25-bai-24-validating-admission-policy.md +297 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/26-bai-25-security-best-practices-2026.md +261 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/27-bai-26-security-tools.md +255 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/06-module-6-security/lessons/28-thuc-hanh-6-kubernetes-security.md +323 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/29-bai-28-observability-stack-2026.md +322 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/30-bai-29-prometheus-va-grafana.md +463 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/31-bai-30-loki-tempo-va-distributed-tracing.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/32-bai-31-debugging-va-troubleshooting.md +259 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/07-module-7-observability-va-monitoring/lessons/33-thuc-hanh-7-observability-va-logging.md +410 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/34-bai-33-helm-4.md +285 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/35-bai-34-operators-va-custom-resources.md +286 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/36-bai-35-service-mesh-2026.md +212 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/37-bai-36-gitops-voi-argocd-va-flux.md +284 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/08-module-8-helm-operators-va-gitops/lessons/38-thuc-hanh-8-helm-operators-gitops.md +336 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/39-bai-38-production-cluster-setup.md +298 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/40-bai-39-infrastructure-migration-2026-cgroup-v2-containerd-2.md +229 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/41-bai-40-node-management.md +213 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/42-bai-41-resource-management.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/43-bai-42-cluster-api.md +264 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/09-module-9-cluster-management/lessons/44-thuc-hanh-9-cluster-management.md +350 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/45-bai-44-managed-kubernetes-services-2026.md +228 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/46-bai-45-cost-optimization.md +233 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/47-bai-46-best-practices-production-2026.md +316 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/48-thuc-hanh-10-cloud-platforms.md +376 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/chapters/10-module-10-cloud-va-production/lessons/49-bai-48-kubernetes-cho-ai-ml.md +266 -0
- package/content/series/devsecops/kubernetes-tu-co-ban-den-nang-cao/index.md +121 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/02-bai-1-gioi-thieu-va-cai-dat-nginx.md +389 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/03-bai-2-cau-hinh-co-ban-nginx.md +875 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/01-phan-1-co-ban/lessons/04-bai-3-logging-va-monitoring-nginx.md +635 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/05-bai-4-reverse-proxy.md +955 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/06-bai-5-load-balancing.md +1290 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/02-phan-2-reverse-proxy-load-balancing/lessons/07-bai-6-nginx-caching.md +1296 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/08-bai-7-ssl-tls-va-https-trong-nginx.md +1001 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/09-bai-8-performance-tuning-trong-ngi.md +1315 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/10-bai-9-security-trong-nginx.md +1328 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/03-phan-3-security-performance/lessons/11-bai-10-rewrite-va-redirects-trong-nginx.md +1070 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/12-bai-11-nginx-voi-application-stack-tr0.md +1228 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/13-bai-12-monitoring-va-logging-trong-nginx.md +1097 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/04-phan-4-app-stack-monitoring/lessons/14-bai-13-high-availability-va-load-balancing-advanced-trong-nginx.md +1285 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/15-bai-14-microservices-va-service-mesh-trong-nginx.md +1405 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/chapters/05-phan-5-production-advanced/lessons/16-bai-15-production-best-practices-va-advanced-topics-trong-nginx.md +1454 -0
- package/content/series/devsecops/nginx-tu-co-ban-den-nang-cao/index.md +282 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/01-bai-1-performance-testing-fundamentals.md +215 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/02-bai-2-sre-practices-slo-sli-sla.md +256 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/03-bai-3-shift-left-performance-testing-ci-cd.md +250 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/04-bai-4-k6-load-testing-framework.md +283 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/01-phan-1-nen-tang-performance-testing/lessons/05-bai-5-gatling-va-artillery-so-sanh.md +272 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/06-bai-6-api-performance-testing.md +305 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/07-bai-7-database-performance-testing.md +221 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/08-bai-8-cloud-native-performance-testing.md +233 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/09-bai-9-chaos-engineering-load-testing.md +235 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/02-phan-2-performance-testing-nang-cao/lessons/10-bai-10-observability-ai-performance.md +234 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/11-bai-11-pentest-fundamentals.md +168 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/12-bai-12-ptes-penetration-testing-execution-standard.md +297 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/13-bai-13-owasp-top-10-2025.md +351 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/14-bai-14-reconnaissance-scanning-nmap-amass-nuclei.md +356 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/03-phan-3-pentest-foundations/lessons/15-bai-15-web-application-testing-burp-suite-owasp-zap.md +380 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/16-bai-16-exploitation-frameworks-metasploit.md +337 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/17-bai-17-cloud-pentesting-aws-azure-gcp.md +284 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/18-bai-18-container-kubernetes-security-testing.md +340 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/19-bai-19-api-security-testing-owasp-api-top-10.md +349 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/04-phan-4-pentest-nang-cao/lessons/20-bai-20-ai-powered-pentesting-2026.md +391 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/21-bai-21-red-team-adversary-simulation.md +274 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/22-bai-22-blue-team-detection-engineering.md +313 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/23-bai-23-purple-team-collaborative-security.md +250 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/24-bai-24-bug-bounty-methodologies.md +263 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/05-phan-5-red-blue-purple-team/lessons/25-bai-25-compliance-frameworks.md +266 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/26-bai-26-cvss-v4-scoring.md +255 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/27-bai-27-performance-test-report.md +301 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/28-bai-28-pentest-report-technical-executive.md +364 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/29-bai-29-automated-reporting-remediation-tracking.md +382 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/chapters/06-phan-6-bao-cao-va-quy-trinh/lessons/30-bai-30-capstone-project-end-to-end.md +705 -0
- package/content/series/devsecops/performance-testing-va-pentest-chuan-doanh-nghiep-2026/index.md +474 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/02-bai-1-tong-quan-ve-postgresql-high-availability.md +230 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/03-bai-2-streaming-replication-trong-postgresql.md +295 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/01-phan-1-tong-quan-nen-tang/lessons/04-bai-3-gioi-thieu-patroni-va-etcd.md +196 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/05-bai-4-chuan-bi-ha-tang.md +496 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/06-bai-5-cai-dat-postgresql.md +326 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/07-bai-6-cai-dat-va-cau-hinh-etcd-cluster.md +404 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/08-bai-7-cai-dat-patroni.md +604 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/09-bai-8-cau-hinh-patroni-chi-tiet.md +547 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/02-phan-2-cai-dat-cau-hinh/lessons/10-bai-9-bootstrap-postgresql-cluster.md +453 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/11-bai-10-quan-ly-replication.md +455 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/12-bai-11-patroni-callbacks.md +792 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/13-bai-12-patroni-rest-api.md +764 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/14-bai-13-automatic-failover.md +507 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/15-bai-14-switchover-co-ke-hoach-planned-switchover.md +685 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/03-phan-3-quan-ly-cluster/lessons/16-bai-15-recovering-failed-nodes.md +566 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/17-bai-16-backup-va-point-in-time-recovery-pitr.md +622 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/18-bai-17-monitoring-patroni-cluster.md +737 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/19-bai-18-performance-tuning.md +625 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/04-phan-4-backup-monitoring-tuning/lessons/20-bai-19-logging-va-troubleshooting.md +569 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/21-bai-20-security-best-practices.md +481 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/22-bai-21-multi-datacenter-setup.md +509 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/23-bai-22-patroni-voi-kubernetes.md +652 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/24-bai-23-patroni-configuration-management.md +346 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/25-bai-24-upgrade-strategies.md +402 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/05-phan-5-security-nang-cao/lessons/26-bai-25-real-world-case-studies.md +483 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/27-bai-26-automation-voi-ansible.md +688 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/28-bai-27-disaster-recovery-drills.md +514 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/29-bai-28-thiet-ke-kien-truc-ha.md +510 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/chapters/06-phan-6-production-case-studies/lessons/30-bai-29-deploy-production-ready-cluster.md +722 -0
- package/content/series/devsecops/postgresql-high-availability-voi-patroni-etcd/index.md +371 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/01-bai-1-gioi-thieu-django.md +121 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/02-bai-2-models-va-django-orm.md +139 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/03-bai-3-views-urls-va-templates.md +139 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/01-phan-1-django-fundamentals/lessons/04-bai-4-class-based-views-va-forms.md +149 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/05-bai-5-drf-serializers-va-views.md +148 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/06-bai-6-viewsets-routers-va-pagination.md +123 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/07-bai-7-advanced-serializers-va-validation.md +137 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/02-phan-2-django-rest-framework/lessons/08-bai-8-versioning-throttling-va-api-docs.md +130 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/09-bai-9-authentication-session-token-va-jwt.md +140 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/10-bai-10-permissions-va-authorization.md +120 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/11-bai-11-social-auth-va-oauth2.md +134 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-security/lessons/12-bai-12-security-best-practices.md +126 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-django-admin-customization.md +116 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-django-channels-va-websockets.md +136 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-celery-signals-va-caching.md +145 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-storage-email-va-notifications.md +115 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/17-bai-17-testing-trong-django.md +136 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/18-bai-18-performance-optimization.md +127 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/19-bai-19-docker-va-cicd-cho-django.md +159 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-deployment-va-production/lessons/20-bai-20-production-deployment-va-monitoring.md +164 -0
- package/content/series/lap-trinh/django-tu-co-ban-den-nang-cao/index.md +324 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/01-bai-1-gioi-thieu-flutter-va-dart.md +104 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/02-bai-2-dart-language-deep-dive.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/03-bai-3-widget-tree-va-basic-widgets.md +115 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/01-phan-1-dart-va-flutter-fundamentals/lessons/04-bai-4-layouts-va-responsive-design.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/05-bai-5-navigation-va-routing.md +117 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/06-bai-6-state-management-voi-riverpod.md +110 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/07-bai-7-bloc-pattern-va-cubit.md +151 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/02-phan-2-navigation-va-state-management/lessons/08-bai-8-forms-validation-va-theming.md +167 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/09-bai-9-http-va-rest-api-integration.md +172 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/10-bai-10-local-storage-va-offline-first.md +131 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/11-bai-11-firebase-integration.md +118 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/03-phan-3-networking-va-data/lessons/12-bai-12-authentication-va-authorization.md +155 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/13-bai-13-animations-va-motion.md +203 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/14-bai-14-custom-painting-va-advanced-widgets.md +177 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/15-bai-15-platform-channels-va-native-integration.md +139 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-ui-va-features/lessons/16-bai-16-push-notifications-va-background-tasks.md +174 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-va-patterns/lessons/17-bai-17-clean-architecture-cho-flutter.md +159 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-va-patterns/lessons/18-bai-18-code-generation-va-freezed.md +130 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/19-bai-19-testing-trong-flutter.md +173 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/20-bai-20-performance-va-debugging.md +116 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/21-bai-21-cicd-va-app-signing.md +173 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/22-bai-22-publish-len-app-store-va-google-play.md +134 -0
- package/content/series/lap-trinh/flutter-dart-tu-co-ban-den-nang-cao/index.md +350 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/01-bai-1-gioi-thieu-go-ngon-ngu-cua-cloud-native.md +397 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/02-bai-2-variables-types-va-control-flow.md +647 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/03-bai-3-functions-interfaces-va-error-handling.md +611 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/01-phan-1-go-fundamentals/lessons/04-bai-4-generics-packages-va-modules.md +586 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/05-bai-5-goroutines-va-channels.md +536 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/06-bai-6-context-sync-va-concurrency-patterns.md +579 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/07-bai-7-http-server-va-json-handling.md +548 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/02-phan-2-concurrency-networking/lessons/08-bai-8-gin-framework-va-rest-api.md +547 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/09-bai-9-gorm-va-database-integration.md +467 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/10-bai-10-migrations-va-repository-pattern.md +519 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/11-bai-11-authentication-jwt-va-oauth2.md +497 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/03-phan-3-database-authentication/lessons/12-bai-12-authorization-security-va-middleware.md +366 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-websockets-va-real-time.md +398 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-grpc-va-protocol-buffers.md +524 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-message-queues-va-event-driven.md +506 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-caching-file-upload-va-performance.md +393 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/17-bai-17-microservices-architecture-voi-go.md +365 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/18-bai-18-testing-trong-go.md +442 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/19-bai-19-docker-cicd-va-devops.md +391 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/20-bai-20-production-deployment-va-observability.md +428 -0
- package/content/series/lap-trinh/golang-tu-co-ban-den-nang-cao/index.md +323 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/01-bai-1-gioi-thieu-laravel.md +110 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/02-bai-2-routing-controllers-va-middleware.md +133 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/03-bai-3-blade-templates-va-frontend.md +119 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/01-phan-1-laravel-fundamentals/lessons/04-bai-4-eloquent-orm-va-relationships.md +133 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/05-bai-5-migrations-seeding-va-query-builder.md +127 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/06-bai-6-validation-va-form-requests.md +118 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/07-bai-7-api-resources-va-response.md +116 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/02-phan-2-database-va-validation/lessons/08-bai-8-file-storage-va-media.md +111 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/09-bai-9-authentication-sanctum-va-fortify.md +110 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/10-bai-10-authorization-gates-va-policies.md +120 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/11-bai-11-oauth2-passport-va-socialite.md +111 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-va-authorization/lessons/12-bai-12-security-best-practices.md +99 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-queues-va-jobs.md +120 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-events-listeners-va-broadcasting.md +109 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-notifications-mail-va-scheduler.md +129 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-caching-sessions-va-performance.md +103 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/05-phan-5-modern-full-stack/lessons/17-bai-17-livewire-full-stack-components.md +130 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/05-phan-5-modern-full-stack/lessons/18-bai-18-inertiajs-va-vue-react.md +136 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/19-bai-19-testing-trong-laravel.md +124 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/20-bai-20-clean-architecture-va-packages.md +126 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/21-bai-21-docker-va-cicd.md +138 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-docker-va-production/lessons/22-bai-22-production-deployment-va-monitoring.md +123 -0
- package/content/series/lap-trinh/laravel-tu-co-ban-den-nang-cao/index.md +354 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/01-bai-1-gioi-thieu-nestjs-tai-sao-chon-nestjs.md +162 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/02-bai-2-typescript-essentials-cho-nestjs.md +298 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/03-bai-3-cai-dat-va-khoi-tao-nestjs-project.md +336 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-nestjs/lessons/04-bai-4-controllers-va-routing-trong-nestjs.md +310 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/05-bai-5-providers-va-dependency-injection.md +279 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/06-bai-6-modules-to-chuc-code-theo-feature.md +258 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/07-bai-7-typeorm-va-prisma-ket-noi-database.md +381 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-providers-di-data-layer/lessons/08-bai-8-validation-pipes-va-exception-filters.md +307 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/09-bai-9-authentication-voi-passport-va-jwt.md +343 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/10-bai-10-guards-va-authorization-rbac.md +252 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/11-bai-11-security-best-practices.md +207 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-auth-security/lessons/12-bai-12-session-cookies-va-oauth2.md +244 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-interceptors-middleware-va-request-lifecycle.md +220 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-websockets-va-real-time-communication.md +263 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-graphql-voi-nestjs.md +262 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-upload-caching-va-task-scheduling.md +302 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/17-bai-17-nestjs-microservices.md +228 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/18-bai-18-testing-trong-nestjs.md +310 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/19-bai-19-dockerize-va-ci-cd-cho-nestjs.md +271 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-microservices-testing-production/lessons/20-bai-20-production-deployment-va-monitoring.md +352 -0
- package/content/series/lap-trinh/nestjs-tu-co-ban-den-nang-cao/index.md +323 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/01-bai-1-nodejs-architecture-deep-dive.md +117 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/02-bai-2-event-loop-va-async-patterns.md +148 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/03-bai-3-module-system-va-package-management.md +129 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/01-phan-1-nodejs-internals/lessons/04-bai-4-typescript-va-modern-javascript.md +147 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/05-bai-5-file-system-va-path.md +131 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/06-bai-6-streams-va-buffers.md +153 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/07-bai-7-http-https-va-http2.md +147 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/02-phan-2-core-modules-deep-dive/lessons/08-bai-8-crypto-os-va-process.md +143 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/09-bai-9-worker-threads-va-cpu-intensive.md +131 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/10-bai-10-cluster-module-va-load-balancing.md +135 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/11-bai-11-tcp-udp-va-websockets.md +160 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/03-phan-3-concurrency-va-networking/lessons/12-bai-12-events-timers-va-diagnostics.md +151 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/13-bai-13-xay-dung-http-framework-tu-scratch.md +185 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/14-bai-14-database-drivers-va-connection-pooling.md +153 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/15-bai-15-caching-queues-va-background-jobs.md +146 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/04-phan-4-building-without-frameworks/lessons/16-bai-16-native-addons-va-napi.md +139 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/17-bai-17-testing-nodejs-applications.md +173 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/18-bai-18-performance-profiling-va-optimization.md +122 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/19-bai-19-docker-va-cicd.md +169 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-performance-va-production/lessons/20-bai-20-production-monitoring-va-scaling.md +184 -0
- package/content/series/lap-trinh/nodejs-core-tu-co-ban-den-nang-cao/index.md +321 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/01-bai-1-gioi-thieu-fastapi-framework-python-hien-dai-nhat.md +222 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/02-bai-2-python-essentials-cho-fastapi.md +398 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/03-bai-3-cai-dat-va-khoi-tao-fastapi-project.md +412 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-python-fastapi/lessons/04-bai-4-path-operations-request-va-response.md +485 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/05-bai-5-pydantic-v2-data-validation-va-serialization.md +466 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/06-bai-6-sqlalchemy-2-va-async-database.md +412 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/07-bai-7-alembic-migrations-va-database-seeding.md +417 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/02-phan-2-pydantic-database-orm/lessons/08-bai-8-crud-operations-va-repository-pattern.md +487 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/09-bai-9-authentication-voi-oauth2-va-jwt.md +415 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/10-bai-10-authorization-rbac-va-permissions.md +313 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/11-bai-11-security-best-practices.md +255 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/03-phan-3-authentication-security/lessons/12-bai-12-social-login-va-oauth2-providers.md +338 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/13-bai-13-middleware-events-va-lifespan.md +239 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/14-bai-14-websockets-va-real-time-communication.md +318 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/15-bai-15-background-tasks-celery-va-task-queues.md +331 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-features/lessons/16-bai-16-file-upload-caching-va-async-deep-dive.md +358 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/17-bai-17-clean-architecture-va-project-structure.md +349 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/18-bai-18-testing-trong-fastapi.md +488 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/19-bai-19-dockerize-va-cicd-cho-fastapi.md +464 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/chapters/05-phan-5-architecture-testing-production/lessons/20-bai-20-production-deployment-va-monitoring.md +517 -0
- package/content/series/lap-trinh/python-fastapi-tu-co-ban-den-nang-cao/index.md +308 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/01-bai-1-quarkus-la-gi.md +377 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/02-bai-2-tao-quarkus-project.md +376 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/03-bai-3-quarkus-rest.md +349 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/04-bai-4-postgresql-panache.md +422 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/01-phan-1-nen-tang-quarkus/lessons/05-bai-5-validation-error-handling.md +758 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/06-bai-6-ddd-database-per-service.md +631 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/07-bai-7-product-service.md +469 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/08-bai-8-order-service.md +443 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/02-phan-2-thiet-ke-microservices/lessons/09-bai-9-payment-notification-service.md +542 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/10-bai-10-keycloak-setup.md +571 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/11-bai-11-oidc-authentication.md +592 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/03-phan-3-security-keycloak/lessons/12-bai-12-rbac-admin-client.md +1900 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/13-bai-13-rest-client.md +529 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/14-bai-14-grpc.md +394 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/04-phan-4-inter-service-communication/lessons/15-bai-15-kafka-event-driven.md +402 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/16-bai-16-fault-tolerance.md +472 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/17-bai-17-opentelemetry.md +348 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/05-phan-5-resilience-observability/lessons/18-bai-18-caching-health-gateway.md +387 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/06-phan-6-testing/lessons/19-bai-19-quarkustest-testcontainers.md +414 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/06-phan-6-testing/lessons/20-bai-20-contract-testing-pact.md +678 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/07-phan-7-deployment-production/lessons/21-bai-21-graalvm-native-container.md +419 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/chapters/07-phan-7-deployment-production/lessons/22-bai-22-kubernetes-cicd.md +603 -0
- package/content/series/lap-trinh/quarkus-microservices-tu-co-ban-den-production/index.md +381 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/01-bai-1-gioi-thieu-react.md +169 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/02-bai-2-components-props-va-typescript.md +234 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/03-bai-3-hooks-deep-dive.md +318 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/01-phan-1-react-fundamentals/lessons/04-bai-4-event-handling-forms-va-conditional-rendering.md +243 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/05-bai-5-context-api-va-state-management.md +230 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/06-bai-6-react-patterns-va-performance.md +164 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/02-phan-2-react-advanced-va-state-management/lessons/07-bai-7-styling-va-ui-components.md +200 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/08-bai-8-nextjs-va-app-router.md +204 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/09-bai-9-server-components-va-client-components.md +161 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/10-bai-10-data-fetching-va-caching.md +169 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/03-phan-3-nextjs-fundamentals/lessons/11-bai-11-server-actions-va-mutations.md +196 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/12-bai-12-authentication-voi-nextauthjs.md +203 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/13-bai-13-middleware-api-routes-va-route-handlers.md +214 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/14-bai-14-database-integration-va-prisma.md +226 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/04-phan-4-nextjs-advanced/lessons/15-bai-15-internationalization-va-seo.md +203 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/16-bai-16-file-upload-va-image-optimization.md +195 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/17-bai-17-real-time-va-websockets.md +234 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/05-phan-5-full-stack-features/lessons/18-bai-18-email-payment-va-third-party.md +201 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/19-bai-19-testing-react-va-nextjs.md +182 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/20-bai-20-performance-optimization.md +168 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/21-bai-21-docker-va-cicd.md +197 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/22-bai-22-production-best-practices-va-monitoring.md +236 -0
- package/content/series/lap-trinh/react-nextjs-tu-co-ban-den-nang-cao/index.md +348 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/01-bai-1-gioi-thieu-rust.md +104 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/02-bai-2-variables-types-va-control-flow.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/03-bai-3-ownership-borrowing-va-lifetimes.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/01-phan-1-rust-fundamentals/lessons/04-bai-4-structs-enums-va-pattern-matching.md +191 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/05-bai-5-traits-va-generics.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/06-bai-6-closures-iterators-va-collections.md +126 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/07-bai-7-error-handling-va-modules.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/02-phan-2-advanced-rust/lessons/08-bai-8-smart-pointers-va-concurrency.md +153 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/09-bai-9-async-rust-va-tokio.md +139 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/10-bai-10-axum-framework-va-rest-api.md +154 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/11-bai-11-sqlx-va-database-integration.md +140 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/03-phan-3-async-rust-va-web-development/lessons/12-bai-12-authentication-va-authorization.md +164 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/13-bai-13-websockets-va-real-time.md +147 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/14-bai-14-grpc-voi-tonic.md +134 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/15-bai-15-message-queues-va-background-jobs.md +147 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/04-phan-4-advanced-backend/lessons/16-bai-16-caching-cli-tools-va-macros.md +174 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/05-phan-5-webassembly-va-systems/lessons/17-bai-17-webassembly-voi-rust.md +156 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/05-phan-5-webassembly-va-systems/lessons/18-bai-18-ffi-va-unsafe-rust.md +177 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/19-bai-19-testing-va-benchmarking.md +142 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/20-bai-20-docker-va-cicd-cho-rust.md +153 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/21-bai-21-observability-va-monitoring.md +141 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-cicd-va-production/lessons/22-bai-22-production-deployment-va-performance-tuning.md +157 -0
- package/content/series/lap-trinh/rust-tu-co-ban-den-nang-cao/index.md +350 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/02-bai-1-spring-boot-la-gi.md +263 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/03-bai-2-cai-dat-moi-truong-va-khoi-tao-project.md +472 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/04-bai-3-auto-configuration-ioc-container.md +442 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/01-phan-1-nen-tang-spring-boot/lessons/05-bai-4-dependency-injection-bean-lifecycle.md +430 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/02-bai-5-rest-api-foundations.md +387 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/03-bai-6-dto-validation-exception-handling.md +412 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/04-bai-7-spring-data-jpa-entity-repository.md +399 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/02-phan-2-xay-dung-rest-api/lessons/05-bai-8-quan-he-entity-pagination-specification.md +415 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/02-bai-9-spring-security-fundamentals.md +313 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/03-bai-10-jwt-authentication.md +400 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/04-bai-11-oauth2-openid-connect.md +306 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/03-phan-3-bao-mat-ung-dung/lessons/05-bai-12-method-security-cors-csrf.md +261 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/02-bai-13-transaction-management-caching.md +281 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/03-bai-14-async-scheduling-events.md +301 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/04-bai-15-file-upload-email-websocket.md +312 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/04-phan-4-tinh-nang-nang-cao/lessons/05-bai-16-openapi-hateoas.md +271 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/02-bai-17-unit-testing-junit5-mockito.md +275 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/03-bai-18-integration-testing-testcontainers.md +297 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/04-bai-19-api-testing-mockmvc-webtestclient.md +258 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/05-phan-5-testing-chat-luong-code/lessons/05-bai-20-actuator-micrometer-observability.md +338 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/02-bai-21-docker-containerization.md +240 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/03-bai-22-microservices-service-discovery-api-gateway.md +317 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/04-bai-23-kafka-rabbitmq-event-driven.md +325 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/chapters/06-phan-6-microservices-production/lessons/05-bai-24-cicd-cloud-deployment-production.md +416 -0
- package/content/series/lap-trinh/spring-boot-tu-co-ban-den-nang-cao/index.md +322 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/01-bai-1-vibe-coding-la-gi-ky-nguyen-moi-cua-lap-trinh-voi-ai.md +251 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/02-bai-2-cai-dat-va-cau-hinh-github-copilot-trong-vs-code.md +321 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/03-bai-3-inline-suggestions-va-next-edit-suggestions.md +290 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/01-phan-1-nen-tang-vibe-coding-github-copilot/lessons/04-bai-4-inline-chat-va-smart-actions.md +269 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/05-bai-5-agent-mode-de-ai-tu-viet-code-cho-ban.md +294 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/06-bai-6-plan-agent-lap-ke-hoach-truoc-khi-code.md +244 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/02-phan-2-agent-mode/lessons/07-bai-7-cloud-agent-va-copilot-cli.md +273 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/08-bai-8-nghe-thuat-viet-prompt-cho-code.md +307 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/09-bai-9-context-management-cung-cap-ngu-canh-cho-ai.md +207 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/03-phan-3-prompt-engineering-cho-code/lessons/10-bai-10-prompt-patterns-nang-cao.md +270 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/11-bai-11-custom-instructions-day-ai-theo-coding-style-cua-ban.md +223 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/12-bai-12-custom-agents-va-agent-skills.md +312 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/04-phan-4-customize-va-extend-copilot/lessons/13-bai-13-mcp-servers-ket-noi-ai-voi-the-gioi-ben-ngoai.md +279 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/14-bai-14-vibe-coding-full-stack-app-phan-1-backend.md +500 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/15-bai-15-vibe-coding-full-stack-app-phan-2-frontend.md +429 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/05-phan-5-vibe-coding-thuc-chien/lessons/16-bai-16-vibe-coding-cho-mobile-va-cross-platform.md +366 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/17-bai-17-code-quality-va-review-vibe-coding-co-trach-nhiem.md +301 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/18-bai-18-security-trong-vibe-coding.md +371 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/19-bai-19-technical-debt-va-maintainability.md +301 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/chapters/06-phan-6-vibe-coding-chuyen-nghiep/lessons/20-bai-20-vibe-coding-trong-team-va-production.md +435 -0
- package/content/series/lap-trinh/vibe-coding-voi-github-copilot/index.md +322 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/01-bai-1-gioi-thieu-vuejs.md +154 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/02-bai-2-reactivity-system-va-composition-api.md +195 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/03-bai-3-components-props-va-events.md +209 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/01-phan-1-vuejs-fundamentals/lessons/04-bai-4-directives-rendering-va-template-refs.md +182 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/05-bai-5-vue-router-deep-dive.md +164 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/06-bai-6-state-management-voi-pinia.md +177 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/07-bai-7-composables-va-reusable-logic.md +186 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/02-phan-2-vue-ecosystem/lessons/08-bai-8-forms-validation-va-styling.md +178 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/09-bai-9-nuxt-3-va-file-based-routing.md +187 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/10-bai-10-data-fetching-va-ssr.md +149 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/11-bai-11-nitro-server-engine-va-api-routes.md +189 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/03-phan-3-nuxt-3-fundamentals/lessons/12-bai-12-middleware-plugins-va-modules.md +178 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/13-bai-13-authentication-va-authorization.md +173 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/14-bai-14-database-va-orm-trong-nuxt.md +173 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/15-bai-15-file-upload-images-va-seo.md +158 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/04-phan-4-nuxt-advanced-va-full-stack/lessons/16-bai-16-real-time-websockets-va-i18n.md +176 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/05-phan-5-advanced-patterns/lessons/17-bai-17-animations-va-transitions.md +198 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/05-phan-5-advanced-patterns/lessons/18-bai-18-advanced-patterns-va-custom-module.md +184 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/19-bai-19-testing-vue-va-nuxt.md +207 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/20-bai-20-performance-optimization.md +206 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/21-bai-21-deployment-va-hosting.md +206 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/chapters/06-phan-6-testing-deployment-production/lessons/22-bai-22-production-monitoring-va-best-practices.md +244 -0
- package/content/series/lap-trinh/vuejs-nuxt-tu-co-ban-den-nang-cao/index.md +347 -0
- package/content/showcase/autox.md +141 -0
- package/content/showcase/x-lms.md +118 -0
- package/content/showcase/x-postgres-backup.md +96 -0
- package/content/showcase/xclaw-app.md +66 -0
- package/content/showcase/xclaw.md +80 -0
- package/content/showcase/xdev-asia.md +102 -0
- package/content/showcase/xdev-reader.md +68 -0
- package/data/authors.json +8 -0
- package/data/categories.json +98 -0
- package/data/github-repos.json +44 -0
- package/data/reviews.json +1 -0
- package/data/settings.json +23 -0
- package/data/tags.json +122 -0
- package/dist/content-loader.d.ts +56 -0
- package/dist/content-loader.d.ts.map +1 -0
- package/dist/content-loader.js +331 -0
- package/dist/content-loader.js.map +1 -0
- package/dist/data/hipaa-safeguards.d.ts +28 -0
- package/dist/data/hipaa-safeguards.d.ts.map +1 -0
- package/dist/data/hipaa-safeguards.js +222 -0
- package/dist/data/hipaa-safeguards.js.map +1 -0
- package/dist/data/phi-classifier.d.ts +36 -0
- package/dist/data/phi-classifier.d.ts.map +1 -0
- package/dist/data/phi-classifier.js +115 -0
- package/dist/data/phi-classifier.js.map +1 -0
- package/dist/data/security-configs.d.ts +14 -0
- package/dist/data/security-configs.d.ts.map +1 -0
- package/dist/data/security-configs.js +507 -0
- package/dist/data/security-configs.js.map +1 -0
- package/dist/data/threat-patterns.d.ts +44 -0
- package/dist/data/threat-patterns.d.ts.map +1 -0
- package/dist/data/threat-patterns.js +177 -0
- package/dist/data/threat-patterns.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/index.d.ts +3 -0
- package/dist/prompts/index.d.ts.map +1 -0
- package/dist/prompts/index.js +228 -0
- package/dist/prompts/index.js.map +1 -0
- package/dist/resources/index.d.ts +3 -0
- package/dist/resources/index.d.ts.map +1 -0
- package/dist/resources/index.js +218 -0
- package/dist/resources/index.js.map +1 -0
- package/dist/tools/index.d.ts +3 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +684 -0
- package/dist/tools/index.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1,1881 @@
|
|
|
1
|
+
---
|
|
2
|
+
id: 019e1a40-a124-7001-d001-f0a1b2c30124
|
|
3
|
+
title: 'Bài 24: Capstone — Xây dựng Secure Healthcare Microservices Platform'
|
|
4
|
+
slug: bai-24-capstone-xay-dung-secure-healthcare-platform
|
|
5
|
+
description: >-
|
|
6
|
+
Dự án tổng hợp: xây dựng Healthcare Microservices Platform hoàn chỉnh
|
|
7
|
+
với đầy đủ security controls. Bao gồm Patient Service, Appointment Service,
|
|
8
|
+
Lab Results Service, Prescription Service trên Quarkus, PostgreSQL
|
|
9
|
+
với RLS + encryption, Keycloak IAM, API Gateway, audit logging,
|
|
10
|
+
monitoring, và deployment trên Kubernetes với full HIPAA compliance.
|
|
11
|
+
duration_minutes: 300
|
|
12
|
+
is_free: true
|
|
13
|
+
video_url: null
|
|
14
|
+
sort_order: 24
|
|
15
|
+
section_title: "Phần 6: Nâng cao & Dự án Thực hành"
|
|
16
|
+
course:
|
|
17
|
+
id: 019e1a40-a100-7001-d001-f0a1b2c30001
|
|
18
|
+
title: Bảo mật Dữ liệu Y Tế cho Hệ thống Microservices
|
|
19
|
+
slug: bao-mat-du-lieu-y-te-cho-microservices
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
## 1. Giới thiệu Capstone Project
|
|
23
|
+
|
|
24
|
+
### 1.1. Mục tiêu
|
|
25
|
+
|
|
26
|
+
Trong bài cuối cùng này, chúng ta sẽ **tổng hợp toàn bộ kiến thức từ 23 bài trước** để xây dựng một **Secure Healthcare Microservices Platform** hoàn chỉnh — từ thiết kế kiến trúc, triển khai security controls, đến compliance verification.
|
|
27
|
+
|
|
28
|
+
```
|
|
29
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
30
|
+
│ Capstone: Secure Healthcare Platform │
|
|
31
|
+
│ "Hệ thống Quản lý Y tế An toàn" │
|
|
32
|
+
├─────────────────────────────────────────────────────────────┤
|
|
33
|
+
│ │
|
|
34
|
+
│ Tổng hợp từ 23 bài: │
|
|
35
|
+
│ │
|
|
36
|
+
│ ┌─────────┐ ┌─────────┐ ┌─────────┐ ┌─────────┐ │
|
|
37
|
+
│ │ Bài 1-4 │ │ Bài 5-8 │ │ Bài 9-12│ │Bài 13-16│ │
|
|
38
|
+
│ │ HIPAA │ │Keycloak │ │ PgSQL │ │ Quarkus │ │
|
|
39
|
+
│ │ Threat │ │ IAM │ │ Security│ │ Security│ │
|
|
40
|
+
│ │ Model │ │ MFA │ │ RLS │ │ mTLS │ │
|
|
41
|
+
│ └────┬────┘ └────┬────┘ └────┬────┘ └────┬────┘ │
|
|
42
|
+
│ │ │ │ │ │
|
|
43
|
+
│ └────────────┴────────────┴────────────┘ │
|
|
44
|
+
│ │ │
|
|
45
|
+
│ ┌─────────┐ ┌────────┴────────┐ ┌─────────┐ │
|
|
46
|
+
│ │Bài 17-20│ │ CAPSTONE │ │Bài 21-23│ │
|
|
47
|
+
│ │Compliance│ │ PROJECT │ │Zero Trust│ │
|
|
48
|
+
│ │ Audit │ │ Bài 24 │ │Container │ │
|
|
49
|
+
│ │ DR/BCP │ │ │ │ Pentest │ │
|
|
50
|
+
│ └─────────┘ └─────────────────┘ └─────────┘ │
|
|
51
|
+
│ │
|
|
52
|
+
│ Deliverables: │
|
|
53
|
+
│ ✓ Working microservices with full security │
|
|
54
|
+
│ ✓ HIPAA Technical Safeguards compliance │
|
|
55
|
+
│ ✓ Automated security testing pipeline │
|
|
56
|
+
│ ✓ Deployment on Kubernetes with hardening │
|
|
57
|
+
│ ✓ Security Assessment Report │
|
|
58
|
+
└─────────────────────────────────────────────────────────────┘
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### 1.2. Phạm vi hệ thống
|
|
62
|
+
|
|
63
|
+
Chúng ta sẽ xây dựng **Hệ thống Quản lý Bệnh viện** (Hospital Management System — HMS) với các microservices:
|
|
64
|
+
|
|
65
|
+
| Service | Mô tả | Dữ liệu PHI |
|
|
66
|
+
|:---|:---|:---|
|
|
67
|
+
| **Patient Service** | Quản lý hồ sơ bệnh nhân | Tên, DOB, SSN, địa chỉ, liên lạc |
|
|
68
|
+
| **Encounter Service** | Quản lý lượt khám/nhập viện | Chẩn đoán, lý do khám, bác sĩ điều trị |
|
|
69
|
+
| **Lab Service** | Kết quả xét nghiệm | Kết quả XN máu, nước tiểu, sinh thiết |
|
|
70
|
+
| **Prescription Service** | Đơn thuốc | Thuốc kê, liều lượng, tương tác thuốc |
|
|
71
|
+
| **Notification Service** | Thông báo & nhắc nhở | Lịch tái khám, nhắc uống thuốc |
|
|
72
|
+
| **Audit Service** | Ghi nhận audit trail | Toàn bộ access logs |
|
|
73
|
+
|
|
74
|
+
---
|
|
75
|
+
|
|
76
|
+
## 2. Kiến trúc tổng thể
|
|
77
|
+
|
|
78
|
+
### 2.1. System Architecture
|
|
79
|
+
|
|
80
|
+
```
|
|
81
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
82
|
+
│ INTERNET / EXTERNAL │
|
|
83
|
+
└─────────────────────┬───────────────────────────────────────────┘
|
|
84
|
+
│ HTTPS (TLS 1.3)
|
|
85
|
+
▼
|
|
86
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
87
|
+
│ DMZ / Edge Layer │
|
|
88
|
+
│ ┌──────────────────────────────────────────────────────────┐ │
|
|
89
|
+
│ │ API Gateway (Kong) │ │
|
|
90
|
+
│ │ • Rate limiting (100 req/min per client) │ │
|
|
91
|
+
│ │ • WAF rules (OWASP CRS) │ │
|
|
92
|
+
│ │ • Request validation (JSON Schema) │ │
|
|
93
|
+
│ │ • JWT verification (delegate to Keycloak) │ │
|
|
94
|
+
│ │ • IP allowlisting for admin APIs │ │
|
|
95
|
+
│ └──────────────────────┬───────────────────────────────────┘ │
|
|
96
|
+
└─────────────────────────┼───────────────────────────────────────┘
|
|
97
|
+
│ mTLS
|
|
98
|
+
┌─────────────────────────┼───────────────────────────────────────┐
|
|
99
|
+
│ APPLICATION LAYER (Kubernetes) │
|
|
100
|
+
│ │ │
|
|
101
|
+
│ ┌───────────┐ ┌───────┴─────┐ ┌───────────┐ ┌───────────┐ │
|
|
102
|
+
│ │ Patient │ │ Encounter │ │ Lab │ │Prescription│ │
|
|
103
|
+
│ │ Service │ │ Service │ │ Service │ │ Service │ │
|
|
104
|
+
│ │ (Quarkus) │ │ (Quarkus) │ │ (Quarkus) │ │ (Quarkus) │ │
|
|
105
|
+
│ │ │ │ │ │ │ │ │ │
|
|
106
|
+
│ │ • OIDC │ │ • OIDC │ │ • OIDC │ │ • OIDC │ │
|
|
107
|
+
│ │ • RBAC │ │ • ABAC │ │ • RBAC │ │ • MFA check│ │
|
|
108
|
+
│ │ • Encrypt │ │ • Encrypt │ │ • Encrypt │ │ • Encrypt │ │
|
|
109
|
+
│ │ • Audit │ │ • Audit │ │ • Audit │ │ • Audit │ │
|
|
110
|
+
│ └─────┬─────┘ └──────┬──────┘ └─────┬─────┘ └─────┬─────┘ │
|
|
111
|
+
│ │ │ │ │ │
|
|
112
|
+
│ ┌─────┴───────────────┴───────────────┴───────────────┴─────┐ │
|
|
113
|
+
│ │ Service Mesh (Istio) │ │
|
|
114
|
+
│ │ mTLS everywhere • Network Policies • Tracing │ │
|
|
115
|
+
│ └───────────────────────┬───────────────────────────────────┘ │
|
|
116
|
+
│ │ │
|
|
117
|
+
│ ┌───────────┐ ┌───────┴─────┐ ┌───────────┐ │
|
|
118
|
+
│ │Notification│ │ Audit │ │ Keycloak │ │
|
|
119
|
+
│ │ Service │ │ Service │ │ IAM │ │
|
|
120
|
+
│ └───────────┘ └─────────────┘ └───────────┘ │
|
|
121
|
+
└─────────────────────────┼───────────────────────────────────────┘
|
|
122
|
+
│ SSL + mTLS
|
|
123
|
+
┌─────────────────────────┼───────────────────────────────────────┐
|
|
124
|
+
│ DATA LAYER │
|
|
125
|
+
│ │ │
|
|
126
|
+
│ ┌────────────┐ ┌──────┴──────┐ ┌────────────┐ │
|
|
127
|
+
│ │ PostgreSQL │ │ Kafka │ │ Vault │ │
|
|
128
|
+
│ │ (Primary) │ │ (Events) │ │ (KMS) │ │
|
|
129
|
+
│ │ │ │ │ │ │ │
|
|
130
|
+
│ │ • RLS │ │ • Encrypted │ │ • Transit │ │
|
|
131
|
+
│ │ • pgcrypto │ │ topics │ │ • PKI │ │
|
|
132
|
+
│ │ • pgAudit │ │ • Schema │ │ • Auto │ │
|
|
133
|
+
│ │ • SSL │ │ Registry │ │ unseal │ │
|
|
134
|
+
│ │ • Backups │ │ │ │ │ │
|
|
135
|
+
│ └────────────┘ └─────────────┘ └────────────┘ │
|
|
136
|
+
│ │
|
|
137
|
+
│ ┌────────────┐ ┌─────────────┐ │
|
|
138
|
+
│ │ PostgreSQL │ │Elasticsearch│ │
|
|
139
|
+
│ │ (Replica) │ │ (Audit Logs)│ │
|
|
140
|
+
│ └────────────┘ └─────────────┘ │
|
|
141
|
+
└──────────────────────────────────────────────────────────────────┘
|
|
142
|
+
```
|
|
143
|
+
|
|
144
|
+
### 2.2. Project Structure
|
|
145
|
+
|
|
146
|
+
```
|
|
147
|
+
healthcare-platform/
|
|
148
|
+
├── docker-compose.yml # Local development
|
|
149
|
+
├── docker-compose.security.yml # Security testing
|
|
150
|
+
├── pom.xml # Parent POM
|
|
151
|
+
│
|
|
152
|
+
├── infrastructure/
|
|
153
|
+
│ ├── keycloak/
|
|
154
|
+
│ │ ├── hospital-realm.json # Realm configuration
|
|
155
|
+
│ │ └── themes/ # Custom login theme
|
|
156
|
+
│ ├── postgresql/
|
|
157
|
+
│ │ ├── init.sql # Database initialization
|
|
158
|
+
│ │ ├── rls-policies.sql # Row-Level Security
|
|
159
|
+
│ │ ├── audit-setup.sql # pgAudit configuration
|
|
160
|
+
│ │ └── encryption.sql # Column encryption functions
|
|
161
|
+
│ ├── kong/
|
|
162
|
+
│ │ └── kong.yml # API Gateway config
|
|
163
|
+
│ ├── vault/
|
|
164
|
+
│ │ └── policies/ # Vault policies
|
|
165
|
+
│ └── kubernetes/
|
|
166
|
+
│ ├── base/ # Kustomize base
|
|
167
|
+
│ ├── overlays/
|
|
168
|
+
│ │ ├── dev/
|
|
169
|
+
│ │ ├── staging/
|
|
170
|
+
│ │ └── production/
|
|
171
|
+
│ └── security/
|
|
172
|
+
│ ├── network-policies.yaml
|
|
173
|
+
│ ├── pod-security.yaml
|
|
174
|
+
│ └── falco-rules.yaml
|
|
175
|
+
│
|
|
176
|
+
├── services/
|
|
177
|
+
│ ├── patient-service/
|
|
178
|
+
│ │ ├── pom.xml
|
|
179
|
+
│ │ └── src/
|
|
180
|
+
│ ├── encounter-service/
|
|
181
|
+
│ ├── lab-service/
|
|
182
|
+
│ ├── prescription-service/
|
|
183
|
+
│ ├── notification-service/
|
|
184
|
+
│ └── audit-service/
|
|
185
|
+
│
|
|
186
|
+
├── shared/
|
|
187
|
+
│ ├── security-lib/ # Shared security utilities
|
|
188
|
+
│ │ ├── encryption/
|
|
189
|
+
│ │ ├── audit/
|
|
190
|
+
│ │ └── validation/
|
|
191
|
+
│ └── test-lib/ # Shared test utilities
|
|
192
|
+
│ ├── security-tests/
|
|
193
|
+
│ └── test-data/ # Synthetic healthcare data
|
|
194
|
+
│
|
|
195
|
+
├── security/
|
|
196
|
+
│ ├── .semgrep/ # SAST rules
|
|
197
|
+
│ ├── zap/ # DAST configuration
|
|
198
|
+
│ ├── nuclei/ # Nuclei templates
|
|
199
|
+
│ └── compliance/ # HIPAA compliance checks
|
|
200
|
+
│
|
|
201
|
+
└── .github/
|
|
202
|
+
└── workflows/
|
|
203
|
+
├── ci.yml # Build + Security scans
|
|
204
|
+
└── security-audit.yml # Scheduled audit
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
## 3. Bước 1: Cấu hình Keycloak — IAM
|
|
210
|
+
|
|
211
|
+
### 3.1. Hospital Realm Configuration
|
|
212
|
+
|
|
213
|
+
```json
|
|
214
|
+
{
|
|
215
|
+
"realm": "hospital",
|
|
216
|
+
"enabled": true,
|
|
217
|
+
"sslRequired": "all",
|
|
218
|
+
"registrationAllowed": false,
|
|
219
|
+
"bruteForceProtected": true,
|
|
220
|
+
"permanentLockout": false,
|
|
221
|
+
"maxFailureWaitSeconds": 900,
|
|
222
|
+
"failureFactor": 5,
|
|
223
|
+
"passwordPolicy": "length(12) and upperCase(1) and lowerCase(1) and digits(1) and specialChars(1) and notUsername and passwordHistory(6) and forceExpiredPasswordChange(90)",
|
|
224
|
+
"ssoSessionIdleTimeout": 900,
|
|
225
|
+
"ssoSessionMaxLifespan": 28800,
|
|
226
|
+
"accessTokenLifespan": 300,
|
|
227
|
+
"refreshTokenMaxReuse": 0,
|
|
228
|
+
|
|
229
|
+
"roles": {
|
|
230
|
+
"realm": [
|
|
231
|
+
{
|
|
232
|
+
"name": "chief-physician",
|
|
233
|
+
"description": "Bác sĩ trưởng khoa",
|
|
234
|
+
"composite": true,
|
|
235
|
+
"composites": {
|
|
236
|
+
"realm": ["physician", "view-department-records"]
|
|
237
|
+
}
|
|
238
|
+
},
|
|
239
|
+
{
|
|
240
|
+
"name": "physician",
|
|
241
|
+
"description": "Bác sĩ điều trị",
|
|
242
|
+
"composite": true,
|
|
243
|
+
"composites": {
|
|
244
|
+
"realm": ["view-assigned-patients", "create-encounter",
|
|
245
|
+
"create-prescription", "view-lab-results"]
|
|
246
|
+
}
|
|
247
|
+
},
|
|
248
|
+
{
|
|
249
|
+
"name": "head-nurse",
|
|
250
|
+
"description": "Y tá trưởng",
|
|
251
|
+
"composite": true,
|
|
252
|
+
"composites": {
|
|
253
|
+
"realm": ["nurse", "manage-ward-schedule"]
|
|
254
|
+
}
|
|
255
|
+
},
|
|
256
|
+
{
|
|
257
|
+
"name": "nurse",
|
|
258
|
+
"description": "Y tá",
|
|
259
|
+
"composite": false
|
|
260
|
+
},
|
|
261
|
+
{
|
|
262
|
+
"name": "lab-technician",
|
|
263
|
+
"description": "Kỹ thuật viên xét nghiệm",
|
|
264
|
+
"composite": false
|
|
265
|
+
},
|
|
266
|
+
{
|
|
267
|
+
"name": "pharmacist",
|
|
268
|
+
"description": "Dược sĩ",
|
|
269
|
+
"composite": false
|
|
270
|
+
},
|
|
271
|
+
{
|
|
272
|
+
"name": "patient",
|
|
273
|
+
"description": "Bệnh nhân",
|
|
274
|
+
"composite": false
|
|
275
|
+
},
|
|
276
|
+
{
|
|
277
|
+
"name": "admin",
|
|
278
|
+
"description": "Quản trị hệ thống",
|
|
279
|
+
"composite": false
|
|
280
|
+
}
|
|
281
|
+
]
|
|
282
|
+
},
|
|
283
|
+
|
|
284
|
+
"users": [
|
|
285
|
+
{
|
|
286
|
+
"username": "dr.nguyen",
|
|
287
|
+
"email": "dr.nguyen@hospital.local",
|
|
288
|
+
"firstName": "Nguyễn",
|
|
289
|
+
"lastName": "Văn A",
|
|
290
|
+
"enabled": true,
|
|
291
|
+
"requiredActions": ["CONFIGURE_TOTP"],
|
|
292
|
+
"attributes": {
|
|
293
|
+
"department": ["cardiology"],
|
|
294
|
+
"medical_license": ["BS-12345"],
|
|
295
|
+
"employee_id": ["EMP-001"]
|
|
296
|
+
},
|
|
297
|
+
"realmRoles": ["physician"]
|
|
298
|
+
},
|
|
299
|
+
{
|
|
300
|
+
"username": "yta.tran",
|
|
301
|
+
"email": "yta.tran@hospital.local",
|
|
302
|
+
"firstName": "Trần",
|
|
303
|
+
"lastName": "Thị B",
|
|
304
|
+
"enabled": true,
|
|
305
|
+
"attributes": {
|
|
306
|
+
"department": ["cardiology"],
|
|
307
|
+
"ward": ["ward-3"],
|
|
308
|
+
"employee_id": ["EMP-042"]
|
|
309
|
+
},
|
|
310
|
+
"realmRoles": ["nurse"]
|
|
311
|
+
},
|
|
312
|
+
{
|
|
313
|
+
"username": "patient.le",
|
|
314
|
+
"email": "patient.le@gmail.com",
|
|
315
|
+
"firstName": "Lê",
|
|
316
|
+
"lastName": "Văn C",
|
|
317
|
+
"enabled": true,
|
|
318
|
+
"attributes": {
|
|
319
|
+
"patient_id": ["PAT-001"],
|
|
320
|
+
"insurance_id": ["INS-BH-123456"]
|
|
321
|
+
},
|
|
322
|
+
"realmRoles": ["patient"]
|
|
323
|
+
}
|
|
324
|
+
],
|
|
325
|
+
|
|
326
|
+
"clients": [
|
|
327
|
+
{
|
|
328
|
+
"clientId": "patient-service",
|
|
329
|
+
"name": "Patient Microservice",
|
|
330
|
+
"enabled": true,
|
|
331
|
+
"clientAuthenticatorType": "client-secret",
|
|
332
|
+
"serviceAccountsEnabled": true,
|
|
333
|
+
"authorizationServicesEnabled": true,
|
|
334
|
+
"directAccessGrantsEnabled": false,
|
|
335
|
+
"publicClient": false,
|
|
336
|
+
"protocol": "openid-connect",
|
|
337
|
+
"defaultClientScopes": ["openid", "profile", "healthcare"],
|
|
338
|
+
"attributes": {
|
|
339
|
+
"access.token.lifespan": "300"
|
|
340
|
+
}
|
|
341
|
+
},
|
|
342
|
+
{
|
|
343
|
+
"clientId": "patient-portal",
|
|
344
|
+
"name": "Patient Portal SPA",
|
|
345
|
+
"enabled": true,
|
|
346
|
+
"publicClient": true,
|
|
347
|
+
"directAccessGrantsEnabled": false,
|
|
348
|
+
"standardFlowEnabled": true,
|
|
349
|
+
"redirectUris": ["https://portal.hospital.local/*"],
|
|
350
|
+
"webOrigins": ["https://portal.hospital.local"],
|
|
351
|
+
"defaultClientScopes": ["openid", "profile"],
|
|
352
|
+
"attributes": {
|
|
353
|
+
"pkce.code.challenge.method": "S256",
|
|
354
|
+
"access.token.lifespan": "300"
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
],
|
|
358
|
+
|
|
359
|
+
"clientScopes": [
|
|
360
|
+
{
|
|
361
|
+
"name": "healthcare",
|
|
362
|
+
"protocol": "openid-connect",
|
|
363
|
+
"protocolMappers": [
|
|
364
|
+
{
|
|
365
|
+
"name": "department-mapper",
|
|
366
|
+
"protocol": "openid-connect",
|
|
367
|
+
"protocolMapper": "oidc-usermodel-attribute-mapper",
|
|
368
|
+
"config": {
|
|
369
|
+
"user.attribute": "department",
|
|
370
|
+
"claim.name": "department",
|
|
371
|
+
"access.token.claim": "true",
|
|
372
|
+
"id.token.claim": "true"
|
|
373
|
+
}
|
|
374
|
+
},
|
|
375
|
+
{
|
|
376
|
+
"name": "employee-id-mapper",
|
|
377
|
+
"protocol": "openid-connect",
|
|
378
|
+
"protocolMapper": "oidc-usermodel-attribute-mapper",
|
|
379
|
+
"config": {
|
|
380
|
+
"user.attribute": "employee_id",
|
|
381
|
+
"claim.name": "employee_id",
|
|
382
|
+
"access.token.claim": "true"
|
|
383
|
+
}
|
|
384
|
+
},
|
|
385
|
+
{
|
|
386
|
+
"name": "patient-id-mapper",
|
|
387
|
+
"protocol": "openid-connect",
|
|
388
|
+
"protocolMapper": "oidc-usermodel-attribute-mapper",
|
|
389
|
+
"config": {
|
|
390
|
+
"user.attribute": "patient_id",
|
|
391
|
+
"claim.name": "patient_id",
|
|
392
|
+
"access.token.claim": "true"
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
]
|
|
396
|
+
}
|
|
397
|
+
],
|
|
398
|
+
|
|
399
|
+
"authenticationFlows": [
|
|
400
|
+
{
|
|
401
|
+
"alias": "healthcare-browser-flow",
|
|
402
|
+
"description": "Browser flow with MFA for healthcare",
|
|
403
|
+
"providerId": "basic-flow",
|
|
404
|
+
"topLevel": true,
|
|
405
|
+
"builtIn": false,
|
|
406
|
+
"authenticationExecutions": [
|
|
407
|
+
{
|
|
408
|
+
"authenticator": "auth-cookie",
|
|
409
|
+
"requirement": "ALTERNATIVE"
|
|
410
|
+
},
|
|
411
|
+
{
|
|
412
|
+
"authenticator": "auth-username-password-form",
|
|
413
|
+
"requirement": "REQUIRED"
|
|
414
|
+
},
|
|
415
|
+
{
|
|
416
|
+
"authenticator": "auth-otp-form",
|
|
417
|
+
"requirement": "CONDITIONAL",
|
|
418
|
+
"authenticatorConfig": {
|
|
419
|
+
"alias": "healthcare-otp-config"
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
]
|
|
423
|
+
}
|
|
424
|
+
]
|
|
425
|
+
}
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
---
|
|
429
|
+
|
|
430
|
+
## 4. Bước 2: PostgreSQL Security Setup
|
|
431
|
+
|
|
432
|
+
### 4.1. Database Initialization với Security
|
|
433
|
+
|
|
434
|
+
```sql
|
|
435
|
+
-- infrastructure/postgresql/init.sql
|
|
436
|
+
|
|
437
|
+
-- ================================================================
|
|
438
|
+
-- 1. Create application roles (least privilege)
|
|
439
|
+
-- ================================================================
|
|
440
|
+
|
|
441
|
+
-- Service accounts (one per microservice)
|
|
442
|
+
CREATE ROLE patient_service_role LOGIN PASSWORD NULL; -- cert auth only
|
|
443
|
+
CREATE ROLE encounter_service_role LOGIN PASSWORD NULL;
|
|
444
|
+
CREATE ROLE lab_service_role LOGIN PASSWORD NULL;
|
|
445
|
+
CREATE ROLE prescription_service_role LOGIN PASSWORD NULL;
|
|
446
|
+
CREATE ROLE audit_service_role LOGIN PASSWORD NULL;
|
|
447
|
+
|
|
448
|
+
-- Read-only role for reporting
|
|
449
|
+
CREATE ROLE reporting_role LOGIN PASSWORD NULL;
|
|
450
|
+
|
|
451
|
+
-- ================================================================
|
|
452
|
+
-- 2. Create schemas with isolation
|
|
453
|
+
-- ================================================================
|
|
454
|
+
|
|
455
|
+
CREATE SCHEMA IF NOT EXISTS patient_data;
|
|
456
|
+
CREATE SCHEMA IF NOT EXISTS encounter_data;
|
|
457
|
+
CREATE SCHEMA IF NOT EXISTS lab_data;
|
|
458
|
+
CREATE SCHEMA IF NOT EXISTS prescription_data;
|
|
459
|
+
CREATE SCHEMA IF NOT EXISTS audit_data;
|
|
460
|
+
|
|
461
|
+
-- Grant schema access to respective services
|
|
462
|
+
GRANT USAGE ON SCHEMA patient_data TO patient_service_role;
|
|
463
|
+
GRANT USAGE ON SCHEMA encounter_data TO encounter_service_role;
|
|
464
|
+
GRANT USAGE ON SCHEMA lab_data TO lab_service_role;
|
|
465
|
+
GRANT USAGE ON SCHEMA prescription_data TO prescription_service_role;
|
|
466
|
+
GRANT USAGE ON SCHEMA audit_data TO audit_service_role;
|
|
467
|
+
|
|
468
|
+
-- ================================================================
|
|
469
|
+
-- 3. Install security extensions
|
|
470
|
+
-- ================================================================
|
|
471
|
+
|
|
472
|
+
CREATE EXTENSION IF NOT EXISTS pgcrypto;
|
|
473
|
+
CREATE EXTENSION IF NOT EXISTS pgaudit;
|
|
474
|
+
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
|
|
475
|
+
|
|
476
|
+
-- ================================================================
|
|
477
|
+
-- 4. Encryption helper functions
|
|
478
|
+
-- ================================================================
|
|
479
|
+
|
|
480
|
+
-- Envelope encryption: encrypt data with DEK, DEK encrypted with KEK
|
|
481
|
+
CREATE OR REPLACE FUNCTION patient_data.encrypt_phi(
|
|
482
|
+
plaintext TEXT,
|
|
483
|
+
context TEXT DEFAULT 'patient_phi'
|
|
484
|
+
) RETURNS JSONB AS $$
|
|
485
|
+
DECLARE
|
|
486
|
+
dek BYTEA;
|
|
487
|
+
encrypted_data BYTEA;
|
|
488
|
+
encrypted_dek BYTEA;
|
|
489
|
+
kek BYTEA;
|
|
490
|
+
BEGIN
|
|
491
|
+
-- Generate random DEK (Data Encryption Key)
|
|
492
|
+
dek := gen_random_bytes(32);
|
|
493
|
+
|
|
494
|
+
-- Encrypt data with DEK (AES-256-GCM via pgcrypto)
|
|
495
|
+
encrypted_data := encrypt_iv(
|
|
496
|
+
convert_to(plaintext, 'UTF8'),
|
|
497
|
+
dek,
|
|
498
|
+
gen_random_bytes(16), -- IV
|
|
499
|
+
'aes-cbc/pad:pkcs'
|
|
500
|
+
);
|
|
501
|
+
|
|
502
|
+
-- In production: DEK encrypted by Vault Transit engine
|
|
503
|
+
-- For demo: encrypt DEK with master key from env
|
|
504
|
+
kek := decode(current_setting('app.master_key', true), 'hex');
|
|
505
|
+
encrypted_dek := encrypt(dek, kek, 'aes');
|
|
506
|
+
|
|
507
|
+
RETURN jsonb_build_object(
|
|
508
|
+
'v', 1,
|
|
509
|
+
'ctx', context,
|
|
510
|
+
'dek', encode(encrypted_dek, 'base64'),
|
|
511
|
+
'data', encode(encrypted_data, 'base64'),
|
|
512
|
+
'ts', extract(epoch from now())
|
|
513
|
+
);
|
|
514
|
+
END;
|
|
515
|
+
$$ LANGUAGE plpgsql SECURITY DEFINER;
|
|
516
|
+
|
|
517
|
+
-- ================================================================
|
|
518
|
+
-- 5. Create tables with security
|
|
519
|
+
-- ================================================================
|
|
520
|
+
|
|
521
|
+
CREATE TABLE patient_data.patients (
|
|
522
|
+
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
523
|
+
mrn VARCHAR(20) NOT NULL UNIQUE, -- Medical Record Number
|
|
524
|
+
|
|
525
|
+
-- PHI fields — encrypted at column level
|
|
526
|
+
full_name_encrypted JSONB, -- Encrypted via encrypt_phi()
|
|
527
|
+
date_of_birth_encrypted JSONB,
|
|
528
|
+
ssn_encrypted JSONB, -- Social Security Number
|
|
529
|
+
phone_encrypted JSONB,
|
|
530
|
+
address_encrypted JSONB,
|
|
531
|
+
|
|
532
|
+
-- Non-PHI fields — stored in plaintext
|
|
533
|
+
gender VARCHAR(10),
|
|
534
|
+
blood_type VARCHAR(5),
|
|
535
|
+
department_id VARCHAR(50) NOT NULL, -- For RLS
|
|
536
|
+
primary_physician_id VARCHAR(50), -- For RLS
|
|
537
|
+
|
|
538
|
+
-- Metadata
|
|
539
|
+
tenant_id UUID NOT NULL, -- Hospital/tenant
|
|
540
|
+
created_at TIMESTAMPTZ DEFAULT NOW(),
|
|
541
|
+
updated_at TIMESTAMPTZ DEFAULT NOW(),
|
|
542
|
+
created_by VARCHAR(100) NOT NULL,
|
|
543
|
+
is_active BOOLEAN DEFAULT TRUE
|
|
544
|
+
);
|
|
545
|
+
|
|
546
|
+
CREATE TABLE encounter_data.encounters (
|
|
547
|
+
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
548
|
+
patient_id UUID NOT NULL,
|
|
549
|
+
encounter_type VARCHAR(20) NOT NULL, -- INPATIENT, OUTPATIENT, EMERGENCY
|
|
550
|
+
|
|
551
|
+
-- PHI fields — encrypted
|
|
552
|
+
chief_complaint_encrypted JSONB,
|
|
553
|
+
diagnosis_encrypted JSONB,
|
|
554
|
+
clinical_notes_encrypted JSONB,
|
|
555
|
+
|
|
556
|
+
-- Non-PHI
|
|
557
|
+
department_id VARCHAR(50) NOT NULL,
|
|
558
|
+
attending_physician_id VARCHAR(50) NOT NULL,
|
|
559
|
+
status VARCHAR(20) DEFAULT 'ACTIVE',
|
|
560
|
+
|
|
561
|
+
-- Metadata
|
|
562
|
+
tenant_id UUID NOT NULL,
|
|
563
|
+
encounter_date TIMESTAMPTZ DEFAULT NOW(),
|
|
564
|
+
discharge_date TIMESTAMPTZ,
|
|
565
|
+
created_by VARCHAR(100) NOT NULL,
|
|
566
|
+
created_at TIMESTAMPTZ DEFAULT NOW()
|
|
567
|
+
);
|
|
568
|
+
|
|
569
|
+
CREATE TABLE lab_data.lab_results (
|
|
570
|
+
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
571
|
+
patient_id UUID NOT NULL,
|
|
572
|
+
encounter_id UUID,
|
|
573
|
+
|
|
574
|
+
-- PHI fields — encrypted
|
|
575
|
+
test_results_encrypted JSONB,
|
|
576
|
+
interpretation_encrypted JSONB,
|
|
577
|
+
|
|
578
|
+
-- Non-PHI
|
|
579
|
+
test_type VARCHAR(100) NOT NULL,
|
|
580
|
+
status VARCHAR(20) DEFAULT 'PENDING',
|
|
581
|
+
ordering_physician_id VARCHAR(50) NOT NULL,
|
|
582
|
+
performing_technician_id VARCHAR(50),
|
|
583
|
+
department_id VARCHAR(50) NOT NULL,
|
|
584
|
+
|
|
585
|
+
-- Metadata
|
|
586
|
+
tenant_id UUID NOT NULL,
|
|
587
|
+
ordered_at TIMESTAMPTZ DEFAULT NOW(),
|
|
588
|
+
resulted_at TIMESTAMPTZ,
|
|
589
|
+
created_by VARCHAR(100) NOT NULL
|
|
590
|
+
);
|
|
591
|
+
|
|
592
|
+
CREATE TABLE prescription_data.prescriptions (
|
|
593
|
+
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
594
|
+
patient_id UUID NOT NULL,
|
|
595
|
+
encounter_id UUID,
|
|
596
|
+
|
|
597
|
+
-- PHI fields — encrypted
|
|
598
|
+
medications_encrypted JSONB, -- Drug names, dosages
|
|
599
|
+
instructions_encrypted JSONB,
|
|
600
|
+
|
|
601
|
+
-- Non-PHI
|
|
602
|
+
status VARCHAR(20) DEFAULT 'ACTIVE',
|
|
603
|
+
prescribing_physician_id VARCHAR(50) NOT NULL,
|
|
604
|
+
dispensing_pharmacist_id VARCHAR(50),
|
|
605
|
+
department_id VARCHAR(50) NOT NULL,
|
|
606
|
+
|
|
607
|
+
-- Digital signature for non-repudiation
|
|
608
|
+
physician_signature JSONB, -- {algorithm, signature, cert_thumbprint}
|
|
609
|
+
|
|
610
|
+
-- Metadata
|
|
611
|
+
tenant_id UUID NOT NULL,
|
|
612
|
+
prescribed_at TIMESTAMPTZ DEFAULT NOW(),
|
|
613
|
+
dispensed_at TIMESTAMPTZ,
|
|
614
|
+
created_by VARCHAR(100) NOT NULL
|
|
615
|
+
);
|
|
616
|
+
|
|
617
|
+
-- ================================================================
|
|
618
|
+
-- 6. Row-Level Security Policies
|
|
619
|
+
-- ================================================================
|
|
620
|
+
|
|
621
|
+
ALTER TABLE patient_data.patients ENABLE ROW LEVEL SECURITY;
|
|
622
|
+
ALTER TABLE encounter_data.encounters ENABLE ROW LEVEL SECURITY;
|
|
623
|
+
ALTER TABLE lab_data.lab_results ENABLE ROW LEVEL SECURITY;
|
|
624
|
+
ALTER TABLE prescription_data.prescriptions ENABLE ROW LEVEL SECURITY;
|
|
625
|
+
|
|
626
|
+
-- Patient Service: can only access patients in its department scope
|
|
627
|
+
CREATE POLICY patient_department_isolation ON patient_data.patients
|
|
628
|
+
FOR ALL
|
|
629
|
+
TO patient_service_role
|
|
630
|
+
USING (
|
|
631
|
+
department_id = current_setting('app.current_department', true)
|
|
632
|
+
OR current_setting('app.current_role', true) = 'admin'
|
|
633
|
+
OR (
|
|
634
|
+
-- Bác sĩ chỉ thấy bệnh nhân của mình
|
|
635
|
+
current_setting('app.current_role', true) = 'physician'
|
|
636
|
+
AND primary_physician_id = current_setting('app.current_user_id', true)
|
|
637
|
+
)
|
|
638
|
+
OR (
|
|
639
|
+
-- Bệnh nhân chỉ thấy hồ sơ của chính mình
|
|
640
|
+
current_setting('app.current_role', true) = 'patient'
|
|
641
|
+
AND id::text = current_setting('app.current_patient_id', true)
|
|
642
|
+
)
|
|
643
|
+
);
|
|
644
|
+
|
|
645
|
+
-- Multi-tenant isolation
|
|
646
|
+
CREATE POLICY patient_tenant_isolation ON patient_data.patients
|
|
647
|
+
FOR ALL
|
|
648
|
+
TO patient_service_role
|
|
649
|
+
USING (tenant_id::text = current_setting('app.current_tenant_id', true));
|
|
650
|
+
|
|
651
|
+
-- Encounter: physician sees own patients' encounters
|
|
652
|
+
CREATE POLICY encounter_physician_policy ON encounter_data.encounters
|
|
653
|
+
FOR ALL
|
|
654
|
+
TO encounter_service_role
|
|
655
|
+
USING (
|
|
656
|
+
attending_physician_id = current_setting('app.current_user_id', true)
|
|
657
|
+
OR department_id = current_setting('app.current_department', true)
|
|
658
|
+
OR current_setting('app.current_role', true) IN ('admin', 'chief-physician')
|
|
659
|
+
);
|
|
660
|
+
|
|
661
|
+
-- Lab Results: accessible by ordering physician, lab tech, assigned nurse
|
|
662
|
+
CREATE POLICY lab_result_policy ON lab_data.lab_results
|
|
663
|
+
FOR ALL
|
|
664
|
+
TO lab_service_role
|
|
665
|
+
USING (
|
|
666
|
+
ordering_physician_id = current_setting('app.current_user_id', true)
|
|
667
|
+
OR performing_technician_id = current_setting('app.current_user_id', true)
|
|
668
|
+
OR department_id = current_setting('app.current_department', true)
|
|
669
|
+
);
|
|
670
|
+
|
|
671
|
+
-- ================================================================
|
|
672
|
+
-- 7. pgAudit Configuration
|
|
673
|
+
-- ================================================================
|
|
674
|
+
|
|
675
|
+
ALTER SYSTEM SET pgaudit.log = 'read, write, ddl';
|
|
676
|
+
ALTER SYSTEM SET pgaudit.log_relation = 'on';
|
|
677
|
+
ALTER SYSTEM SET pgaudit.log_parameter = 'on';
|
|
678
|
+
ALTER SYSTEM SET pgaudit.log_catalog = 'off';
|
|
679
|
+
|
|
680
|
+
-- Object-level audit for PHI tables
|
|
681
|
+
SELECT pgaudit.set_config('log', 'all', true);
|
|
682
|
+
|
|
683
|
+
-- ================================================================
|
|
684
|
+
-- 8. Audit trail table (immutable — no UPDATE/DELETE)
|
|
685
|
+
-- ================================================================
|
|
686
|
+
|
|
687
|
+
CREATE TABLE audit_data.access_log (
|
|
688
|
+
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
689
|
+
timestamp TIMESTAMPTZ NOT NULL DEFAULT NOW(),
|
|
690
|
+
user_id VARCHAR(100) NOT NULL,
|
|
691
|
+
user_role VARCHAR(50) NOT NULL,
|
|
692
|
+
action VARCHAR(20) NOT NULL, -- READ, CREATE, UPDATE, DELETE
|
|
693
|
+
resource_type VARCHAR(50) NOT NULL, -- Patient, Encounter, LabResult
|
|
694
|
+
resource_id UUID,
|
|
695
|
+
department VARCHAR(50),
|
|
696
|
+
tenant_id UUID NOT NULL,
|
|
697
|
+
ip_address INET,
|
|
698
|
+
user_agent TEXT,
|
|
699
|
+
request_id UUID, -- Correlation ID
|
|
700
|
+
details JSONB,
|
|
701
|
+
result VARCHAR(20) NOT NULL -- SUCCESS, DENIED, ERROR
|
|
702
|
+
);
|
|
703
|
+
|
|
704
|
+
-- Prevent modification of audit logs
|
|
705
|
+
REVOKE UPDATE, DELETE ON audit_data.access_log FROM PUBLIC;
|
|
706
|
+
GRANT INSERT, SELECT ON audit_data.access_log TO audit_service_role;
|
|
707
|
+
```
|
|
708
|
+
|
|
709
|
+
---
|
|
710
|
+
|
|
711
|
+
## 5. Bước 3: Patient Service — Quarkus Security
|
|
712
|
+
|
|
713
|
+
### 5.1. Application Configuration
|
|
714
|
+
|
|
715
|
+
```properties
|
|
716
|
+
# application.properties — Patient Service
|
|
717
|
+
|
|
718
|
+
# === OIDC Configuration ===
|
|
719
|
+
quarkus.oidc.auth-server-url=https://keycloak.hospital.local/realms/hospital
|
|
720
|
+
quarkus.oidc.client-id=patient-service
|
|
721
|
+
quarkus.oidc.credentials.secret=${OIDC_CLIENT_SECRET}
|
|
722
|
+
quarkus.oidc.token.issuer=https://keycloak.hospital.local/realms/hospital
|
|
723
|
+
quarkus.oidc.token.audience=patient-service
|
|
724
|
+
|
|
725
|
+
# Token verification
|
|
726
|
+
quarkus.oidc.token.customizer-name=healthcare-token-customizer
|
|
727
|
+
|
|
728
|
+
# === Database with SSL ===
|
|
729
|
+
quarkus.datasource.db-kind=postgresql
|
|
730
|
+
quarkus.datasource.jdbc.url=jdbc:postgresql://pg-primary:5432/healthcare?ssl=true&sslmode=verify-full&sslrootcert=/certs/ca.crt&sslcert=/certs/client.crt&sslkey=/certs/client.key
|
|
731
|
+
quarkus.datasource.username=patient_service_role
|
|
732
|
+
# No password — using certificate authentication
|
|
733
|
+
|
|
734
|
+
# Connection pool security
|
|
735
|
+
quarkus.datasource.jdbc.max-size=20
|
|
736
|
+
quarkus.datasource.jdbc.min-size=2
|
|
737
|
+
quarkus.datasource.jdbc.idle-removal-interval=PT5M
|
|
738
|
+
quarkus.datasource.jdbc.max-lifetime=PT30M
|
|
739
|
+
|
|
740
|
+
# === Security Headers ===
|
|
741
|
+
quarkus.http.header."X-Content-Type-Options".value=nosniff
|
|
742
|
+
quarkus.http.header."X-Frame-Options".value=DENY
|
|
743
|
+
quarkus.http.header."X-XSS-Protection".value=1; mode=block
|
|
744
|
+
quarkus.http.header."Strict-Transport-Security".value=max-age=31536000; includeSubDomains
|
|
745
|
+
quarkus.http.header."Content-Security-Policy".value=default-src 'self'
|
|
746
|
+
quarkus.http.header."Cache-Control".value=no-store, no-cache, must-revalidate
|
|
747
|
+
quarkus.http.header."Pragma".value=no-cache
|
|
748
|
+
|
|
749
|
+
# Remove technology fingerprints
|
|
750
|
+
quarkus.http.header."Server".value=
|
|
751
|
+
quarkus.http.header."X-Powered-By".value=
|
|
752
|
+
|
|
753
|
+
# === TLS ===
|
|
754
|
+
quarkus.http.ssl.certificate.files=/certs/tls.crt
|
|
755
|
+
quarkus.http.ssl.certificate.key-files=/certs/tls.key
|
|
756
|
+
quarkus.http.insecure-requests=disabled
|
|
757
|
+
|
|
758
|
+
# === Vault Integration ===
|
|
759
|
+
quarkus.vault.url=https://vault.hospital.local
|
|
760
|
+
quarkus.vault.authentication.kubernetes.role=patient-service
|
|
761
|
+
quarkus.vault.transit.key.healthcare-phi=patient-phi-key
|
|
762
|
+
|
|
763
|
+
# === Audit ===
|
|
764
|
+
quarkus.log.handler.kafka.enabled=true
|
|
765
|
+
quarkus.log.handler.kafka.topic=healthcare-audit-events
|
|
766
|
+
quarkus.log.handler.kafka.bootstrap-servers=kafka:9093
|
|
767
|
+
```
|
|
768
|
+
|
|
769
|
+
### 5.2. Security Filter — JWT to PostgreSQL Session
|
|
770
|
+
|
|
771
|
+
```java
|
|
772
|
+
// RLSContextFilter.java — Propagate JWT claims to PostgreSQL session variables
|
|
773
|
+
|
|
774
|
+
@Provider
|
|
775
|
+
@Priority(Priorities.AUTHORIZATION + 1)
|
|
776
|
+
@RequestScoped
|
|
777
|
+
public class RLSContextFilter implements ContainerRequestFilter {
|
|
778
|
+
|
|
779
|
+
@Inject
|
|
780
|
+
SecurityIdentity securityIdentity;
|
|
781
|
+
|
|
782
|
+
@Inject
|
|
783
|
+
AgroalDataSource dataSource;
|
|
784
|
+
|
|
785
|
+
@Inject
|
|
786
|
+
AuditService auditService;
|
|
787
|
+
|
|
788
|
+
@Override
|
|
789
|
+
public void filter(ContainerRequestContext requestContext) {
|
|
790
|
+
if (securityIdentity.isAnonymous()) {
|
|
791
|
+
return;
|
|
792
|
+
}
|
|
793
|
+
|
|
794
|
+
JsonWebToken jwt = (JsonWebToken) securityIdentity.getPrincipal();
|
|
795
|
+
|
|
796
|
+
try (Connection conn = dataSource.getConnection()) {
|
|
797
|
+
// Set PostgreSQL session variables from JWT claims
|
|
798
|
+
// These are used by RLS policies
|
|
799
|
+
setSessionVariable(conn, "app.current_user_id",
|
|
800
|
+
jwt.getClaim("employee_id") != null ?
|
|
801
|
+
jwt.getClaim("employee_id").toString() :
|
|
802
|
+
jwt.getClaim("patient_id").toString());
|
|
803
|
+
|
|
804
|
+
setSessionVariable(conn, "app.current_role",
|
|
805
|
+
getPrimaryRole(securityIdentity));
|
|
806
|
+
|
|
807
|
+
setSessionVariable(conn, "app.current_department",
|
|
808
|
+
jwt.getClaim("department") != null ?
|
|
809
|
+
jwt.getClaim("department").toString() : "");
|
|
810
|
+
|
|
811
|
+
setSessionVariable(conn, "app.current_tenant_id",
|
|
812
|
+
jwt.getClaim("tenant_id") != null ?
|
|
813
|
+
jwt.getClaim("tenant_id").toString() : "");
|
|
814
|
+
|
|
815
|
+
if (jwt.getClaim("patient_id") != null) {
|
|
816
|
+
setSessionVariable(conn, "app.current_patient_id",
|
|
817
|
+
jwt.getClaim("patient_id").toString());
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
} catch (SQLException e) {
|
|
821
|
+
Log.error("Failed to set RLS context", e);
|
|
822
|
+
requestContext.abortWith(
|
|
823
|
+
Response.status(Response.Status.INTERNAL_SERVER_ERROR)
|
|
824
|
+
.entity(Map.of("error", "Security context initialization failed"))
|
|
825
|
+
.build());
|
|
826
|
+
}
|
|
827
|
+
}
|
|
828
|
+
|
|
829
|
+
private void setSessionVariable(Connection conn, String name, String value)
|
|
830
|
+
throws SQLException {
|
|
831
|
+
// Use parameterized SET to prevent SQL injection
|
|
832
|
+
try (var stmt = conn.prepareStatement(
|
|
833
|
+
"SELECT set_config(?, ?, true)")) {
|
|
834
|
+
stmt.setString(1, name);
|
|
835
|
+
stmt.setString(2, value);
|
|
836
|
+
stmt.execute();
|
|
837
|
+
}
|
|
838
|
+
}
|
|
839
|
+
|
|
840
|
+
private String getPrimaryRole(SecurityIdentity identity) {
|
|
841
|
+
Set<String> roles = identity.getRoles();
|
|
842
|
+
// Priority order for healthcare roles
|
|
843
|
+
List<String> priority = List.of(
|
|
844
|
+
"admin", "chief-physician", "physician", "head-nurse",
|
|
845
|
+
"nurse", "lab-technician", "pharmacist", "patient"
|
|
846
|
+
);
|
|
847
|
+
return priority.stream()
|
|
848
|
+
.filter(roles::contains)
|
|
849
|
+
.findFirst()
|
|
850
|
+
.orElse("unknown");
|
|
851
|
+
}
|
|
852
|
+
}
|
|
853
|
+
```
|
|
854
|
+
|
|
855
|
+
### 5.3. Patient Resource với Security
|
|
856
|
+
|
|
857
|
+
```java
|
|
858
|
+
// PatientResource.java
|
|
859
|
+
|
|
860
|
+
@Path("/api/v1/patients")
|
|
861
|
+
@Produces(MediaType.APPLICATION_JSON)
|
|
862
|
+
@Consumes(MediaType.APPLICATION_JSON)
|
|
863
|
+
@Authenticated
|
|
864
|
+
public class PatientResource {
|
|
865
|
+
|
|
866
|
+
@Inject
|
|
867
|
+
PatientService patientService;
|
|
868
|
+
|
|
869
|
+
@Inject
|
|
870
|
+
AuditService auditService;
|
|
871
|
+
|
|
872
|
+
@Inject
|
|
873
|
+
SecurityIdentity securityIdentity;
|
|
874
|
+
|
|
875
|
+
@Inject
|
|
876
|
+
EncryptionService encryptionService;
|
|
877
|
+
|
|
878
|
+
/**
|
|
879
|
+
* Get patient by ID — with audit logging and field-level decryption
|
|
880
|
+
*/
|
|
881
|
+
@GET
|
|
882
|
+
@Path("/{patientId}")
|
|
883
|
+
@RolesAllowed({"physician", "chief-physician", "nurse", "patient", "admin"})
|
|
884
|
+
public Response getPatient(
|
|
885
|
+
@PathParam("patientId") UUID patientId,
|
|
886
|
+
@HeaderParam("X-Request-ID") String requestId) {
|
|
887
|
+
|
|
888
|
+
// Audit: record access attempt
|
|
889
|
+
String userId = getUserId();
|
|
890
|
+
auditService.logAccess(AuditEvent.builder()
|
|
891
|
+
.action("READ")
|
|
892
|
+
.resourceType("Patient")
|
|
893
|
+
.resourceId(patientId)
|
|
894
|
+
.userId(userId)
|
|
895
|
+
.requestId(requestId)
|
|
896
|
+
.build());
|
|
897
|
+
|
|
898
|
+
// Fetch patient — RLS automatically filters based on JWT claims
|
|
899
|
+
Optional<Patient> patient = patientService.findById(patientId);
|
|
900
|
+
|
|
901
|
+
if (patient.isEmpty()) {
|
|
902
|
+
// Don't reveal whether patient exists — return same error
|
|
903
|
+
auditService.logAccess(AuditEvent.builder()
|
|
904
|
+
.action("READ")
|
|
905
|
+
.resourceType("Patient")
|
|
906
|
+
.resourceId(patientId)
|
|
907
|
+
.userId(userId)
|
|
908
|
+
.result("DENIED")
|
|
909
|
+
.details("Patient not found or access denied by RLS")
|
|
910
|
+
.build());
|
|
911
|
+
|
|
912
|
+
return Response.status(Response.Status.NOT_FOUND)
|
|
913
|
+
.entity(Map.of("error", "Patient not found"))
|
|
914
|
+
.build();
|
|
915
|
+
}
|
|
916
|
+
|
|
917
|
+
// Decrypt PHI fields for response
|
|
918
|
+
PatientDTO dto = mapToDTO(patient.get());
|
|
919
|
+
|
|
920
|
+
// Audit: successful access
|
|
921
|
+
auditService.logAccess(AuditEvent.builder()
|
|
922
|
+
.action("READ")
|
|
923
|
+
.resourceType("Patient")
|
|
924
|
+
.resourceId(patientId)
|
|
925
|
+
.userId(userId)
|
|
926
|
+
.result("SUCCESS")
|
|
927
|
+
.build());
|
|
928
|
+
|
|
929
|
+
return Response.ok(dto).build();
|
|
930
|
+
}
|
|
931
|
+
|
|
932
|
+
/**
|
|
933
|
+
* Create patient — physicians and admin only, with MFA verification
|
|
934
|
+
*/
|
|
935
|
+
@POST
|
|
936
|
+
@RolesAllowed({"physician", "chief-physician", "admin"})
|
|
937
|
+
public Response createPatient(
|
|
938
|
+
@Valid CreatePatientRequest request,
|
|
939
|
+
@HeaderParam("X-Request-ID") String requestId) {
|
|
940
|
+
|
|
941
|
+
// Verify MFA was used for this session (check 'amr' claim)
|
|
942
|
+
verifyMFA();
|
|
943
|
+
|
|
944
|
+
// Validate and sanitize input
|
|
945
|
+
sanitizeInput(request);
|
|
946
|
+
|
|
947
|
+
// Encrypt PHI fields before persistence
|
|
948
|
+
Patient patient = new Patient();
|
|
949
|
+
patient.setMrn(generateMRN());
|
|
950
|
+
patient.setFullNameEncrypted(
|
|
951
|
+
encryptionService.encryptPHI(request.getFullName(), "patient_name"));
|
|
952
|
+
patient.setDateOfBirthEncrypted(
|
|
953
|
+
encryptionService.encryptPHI(request.getDateOfBirth().toString(), "dob"));
|
|
954
|
+
patient.setSsnEncrypted(
|
|
955
|
+
encryptionService.encryptPHI(request.getSsn(), "ssn"));
|
|
956
|
+
patient.setPhoneEncrypted(
|
|
957
|
+
encryptionService.encryptPHI(request.getPhone(), "phone"));
|
|
958
|
+
patient.setAddressEncrypted(
|
|
959
|
+
encryptionService.encryptPHI(request.getAddress(), "address"));
|
|
960
|
+
|
|
961
|
+
// Non-PHI fields
|
|
962
|
+
patient.setGender(request.getGender());
|
|
963
|
+
patient.setBloodType(request.getBloodType());
|
|
964
|
+
patient.setDepartmentId(getDepartmentFromJWT());
|
|
965
|
+
patient.setPrimaryPhysicianId(getUserId());
|
|
966
|
+
patient.setTenantId(getTenantFromJWT());
|
|
967
|
+
patient.setCreatedBy(getUserId());
|
|
968
|
+
|
|
969
|
+
Patient created = patientService.create(patient);
|
|
970
|
+
|
|
971
|
+
// Audit
|
|
972
|
+
auditService.logAccess(AuditEvent.builder()
|
|
973
|
+
.action("CREATE")
|
|
974
|
+
.resourceType("Patient")
|
|
975
|
+
.resourceId(created.getId())
|
|
976
|
+
.userId(getUserId())
|
|
977
|
+
.result("SUCCESS")
|
|
978
|
+
.details("New patient registered: " + created.getMrn())
|
|
979
|
+
.build());
|
|
980
|
+
|
|
981
|
+
return Response.status(Response.Status.CREATED)
|
|
982
|
+
.entity(mapToDTO(created))
|
|
983
|
+
.build();
|
|
984
|
+
}
|
|
985
|
+
|
|
986
|
+
/**
|
|
987
|
+
* Search patients — results filtered by RLS
|
|
988
|
+
*/
|
|
989
|
+
@GET
|
|
990
|
+
@Path("/search")
|
|
991
|
+
@RolesAllowed({"physician", "chief-physician", "nurse", "admin"})
|
|
992
|
+
public Response searchPatients(
|
|
993
|
+
@QueryParam("name") String name,
|
|
994
|
+
@QueryParam("mrn") String mrn,
|
|
995
|
+
@QueryParam("page") @DefaultValue("0") int page,
|
|
996
|
+
@QueryParam("size") @DefaultValue("20") int size) {
|
|
997
|
+
|
|
998
|
+
// Limit page size to prevent data exfiltration
|
|
999
|
+
size = Math.min(size, 50);
|
|
1000
|
+
|
|
1001
|
+
// Search — RLS ensures only authorized patients are returned
|
|
1002
|
+
Page<PatientDTO> results;
|
|
1003
|
+
if (mrn != null && !mrn.isBlank()) {
|
|
1004
|
+
results = patientService.findByMrn(mrn.trim(), page, size);
|
|
1005
|
+
} else if (name != null && !name.isBlank()) {
|
|
1006
|
+
// Search on encrypted fields requires special handling
|
|
1007
|
+
results = patientService.searchByName(name.trim(), page, size);
|
|
1008
|
+
} else {
|
|
1009
|
+
results = patientService.findAll(page, size);
|
|
1010
|
+
}
|
|
1011
|
+
|
|
1012
|
+
// Audit bulk access
|
|
1013
|
+
auditService.logAccess(AuditEvent.builder()
|
|
1014
|
+
.action("SEARCH")
|
|
1015
|
+
.resourceType("Patient")
|
|
1016
|
+
.userId(getUserId())
|
|
1017
|
+
.result("SUCCESS")
|
|
1018
|
+
.details("Search returned " + results.getTotalElements() + " results")
|
|
1019
|
+
.build());
|
|
1020
|
+
|
|
1021
|
+
return Response.ok(results).build();
|
|
1022
|
+
}
|
|
1023
|
+
|
|
1024
|
+
// ================================================================
|
|
1025
|
+
// Emergency Access (Break-the-Glass)
|
|
1026
|
+
// ================================================================
|
|
1027
|
+
|
|
1028
|
+
/**
|
|
1029
|
+
* Emergency access to any patient — bypasses department restriction
|
|
1030
|
+
* Requires explicit reason and triggers immediate alert
|
|
1031
|
+
*/
|
|
1032
|
+
@GET
|
|
1033
|
+
@Path("/{patientId}/emergency-access")
|
|
1034
|
+
@RolesAllowed({"physician", "chief-physician", "nurse"})
|
|
1035
|
+
public Response emergencyAccess(
|
|
1036
|
+
@PathParam("patientId") UUID patientId,
|
|
1037
|
+
@QueryParam("reason") @NotBlank String reason,
|
|
1038
|
+
@HeaderParam("X-Request-ID") String requestId) {
|
|
1039
|
+
|
|
1040
|
+
// Log CRITICAL audit event
|
|
1041
|
+
auditService.logEmergencyAccess(AuditEvent.builder()
|
|
1042
|
+
.action("EMERGENCY_ACCESS")
|
|
1043
|
+
.resourceType("Patient")
|
|
1044
|
+
.resourceId(patientId)
|
|
1045
|
+
.userId(getUserId())
|
|
1046
|
+
.result("GRANTED")
|
|
1047
|
+
.details("Emergency reason: " + reason)
|
|
1048
|
+
.build());
|
|
1049
|
+
|
|
1050
|
+
// Trigger immediate alert to security team
|
|
1051
|
+
auditService.triggerSecurityAlert(
|
|
1052
|
+
"EMERGENCY_ACCESS",
|
|
1053
|
+
"User " + getUserId() + " invoked emergency access for patient "
|
|
1054
|
+
+ patientId + ". Reason: " + reason
|
|
1055
|
+
);
|
|
1056
|
+
|
|
1057
|
+
// Fetch with elevated privileges (bypass RLS via superuser context)
|
|
1058
|
+
Optional<Patient> patient = patientService.findByIdElevated(patientId);
|
|
1059
|
+
|
|
1060
|
+
return patient.map(p -> Response.ok(mapToDTO(p)).build())
|
|
1061
|
+
.orElse(Response.status(404).build());
|
|
1062
|
+
}
|
|
1063
|
+
|
|
1064
|
+
private void verifyMFA() {
|
|
1065
|
+
JsonWebToken jwt = (JsonWebToken) securityIdentity.getPrincipal();
|
|
1066
|
+
List<String> amr = jwt.getClaim("amr");
|
|
1067
|
+
if (amr == null || !amr.contains("mfa")) {
|
|
1068
|
+
throw new ForbiddenException("MFA required for this operation");
|
|
1069
|
+
}
|
|
1070
|
+
}
|
|
1071
|
+
|
|
1072
|
+
private void sanitizeInput(CreatePatientRequest request) {
|
|
1073
|
+
// Input validation is handled by @Valid + Bean Validation
|
|
1074
|
+
// Additional sanitization for XSS prevention
|
|
1075
|
+
request.setFullName(HtmlUtils.sanitize(request.getFullName()));
|
|
1076
|
+
request.setAddress(HtmlUtils.sanitize(request.getAddress()));
|
|
1077
|
+
}
|
|
1078
|
+
}
|
|
1079
|
+
```
|
|
1080
|
+
|
|
1081
|
+
### 5.4. Encryption Service
|
|
1082
|
+
|
|
1083
|
+
```java
|
|
1084
|
+
// EncryptionService.java — Vault-backed PHI encryption
|
|
1085
|
+
|
|
1086
|
+
@ApplicationScoped
|
|
1087
|
+
public class EncryptionService {
|
|
1088
|
+
|
|
1089
|
+
@Inject
|
|
1090
|
+
VaultTransitSecretEngine vaultTransit;
|
|
1091
|
+
|
|
1092
|
+
private static final String TRANSIT_KEY = "healthcare-phi";
|
|
1093
|
+
|
|
1094
|
+
/**
|
|
1095
|
+
* Encrypt PHI field using Vault Transit engine (envelope encryption)
|
|
1096
|
+
*/
|
|
1097
|
+
public JsonObject encryptPHI(String plaintext, String context) {
|
|
1098
|
+
if (plaintext == null || plaintext.isBlank()) {
|
|
1099
|
+
return null;
|
|
1100
|
+
}
|
|
1101
|
+
|
|
1102
|
+
// Vault Transit: server-side encryption, key never leaves Vault
|
|
1103
|
+
String ciphertext = vaultTransit.encrypt(
|
|
1104
|
+
TRANSIT_KEY,
|
|
1105
|
+
plaintext,
|
|
1106
|
+
VaultTransitContext.builder()
|
|
1107
|
+
.context(context)
|
|
1108
|
+
.build()
|
|
1109
|
+
);
|
|
1110
|
+
|
|
1111
|
+
return Json.createObjectBuilder()
|
|
1112
|
+
.add("v", 1)
|
|
1113
|
+
.add("engine", "vault-transit")
|
|
1114
|
+
.add("key", TRANSIT_KEY)
|
|
1115
|
+
.add("ctx", context)
|
|
1116
|
+
.add("ciphertext", ciphertext)
|
|
1117
|
+
.add("encrypted_at", Instant.now().toString())
|
|
1118
|
+
.build();
|
|
1119
|
+
}
|
|
1120
|
+
|
|
1121
|
+
/**
|
|
1122
|
+
* Decrypt PHI field
|
|
1123
|
+
*/
|
|
1124
|
+
public String decryptPHI(JsonObject encrypted) {
|
|
1125
|
+
if (encrypted == null) {
|
|
1126
|
+
return null;
|
|
1127
|
+
}
|
|
1128
|
+
|
|
1129
|
+
String ciphertext = encrypted.getString("ciphertext");
|
|
1130
|
+
String context = encrypted.getString("ctx");
|
|
1131
|
+
|
|
1132
|
+
return vaultTransit.decrypt(
|
|
1133
|
+
TRANSIT_KEY,
|
|
1134
|
+
ciphertext,
|
|
1135
|
+
VaultTransitContext.builder()
|
|
1136
|
+
.context(context)
|
|
1137
|
+
.build()
|
|
1138
|
+
).asString();
|
|
1139
|
+
}
|
|
1140
|
+
}
|
|
1141
|
+
```
|
|
1142
|
+
|
|
1143
|
+
---
|
|
1144
|
+
|
|
1145
|
+
## 6. Bước 4: Audit Service
|
|
1146
|
+
|
|
1147
|
+
### 6.1. Centralized Audit Service
|
|
1148
|
+
|
|
1149
|
+
```java
|
|
1150
|
+
// AuditService.java — Immutable audit trail
|
|
1151
|
+
|
|
1152
|
+
@ApplicationScoped
|
|
1153
|
+
public class AuditService {
|
|
1154
|
+
|
|
1155
|
+
@Inject
|
|
1156
|
+
AuditRepository auditRepository;
|
|
1157
|
+
|
|
1158
|
+
@Inject
|
|
1159
|
+
@Channel("audit-events")
|
|
1160
|
+
Emitter<AuditEvent> auditEmitter;
|
|
1161
|
+
|
|
1162
|
+
@Inject
|
|
1163
|
+
SecurityIdentity securityIdentity;
|
|
1164
|
+
|
|
1165
|
+
@Inject
|
|
1166
|
+
@ConfigProperty(name = "app.security.alert.enabled", defaultValue = "true")
|
|
1167
|
+
boolean alertEnabled;
|
|
1168
|
+
|
|
1169
|
+
/**
|
|
1170
|
+
* Log access event — immutable, append-only
|
|
1171
|
+
*/
|
|
1172
|
+
public void logAccess(AuditEvent event) {
|
|
1173
|
+
// Enrich event with context
|
|
1174
|
+
event.setTimestamp(Instant.now());
|
|
1175
|
+
event.setIpAddress(getClientIP());
|
|
1176
|
+
event.setUserAgent(getUserAgent());
|
|
1177
|
+
|
|
1178
|
+
if (event.getDepartment() == null && !securityIdentity.isAnonymous()) {
|
|
1179
|
+
JsonWebToken jwt = (JsonWebToken) securityIdentity.getPrincipal();
|
|
1180
|
+
event.setDepartment(jwt.getClaim("department"));
|
|
1181
|
+
event.setTenantId(jwt.getClaim("tenant_id"));
|
|
1182
|
+
}
|
|
1183
|
+
|
|
1184
|
+
// 1. Persist to PostgreSQL (audit_data.access_log)
|
|
1185
|
+
auditRepository.insert(event);
|
|
1186
|
+
|
|
1187
|
+
// 2. Emit to Kafka for ELK/SIEM consumption
|
|
1188
|
+
auditEmitter.send(event);
|
|
1189
|
+
|
|
1190
|
+
// 3. Check for suspicious patterns
|
|
1191
|
+
detectSuspiciousActivity(event);
|
|
1192
|
+
}
|
|
1193
|
+
|
|
1194
|
+
/**
|
|
1195
|
+
* Emergency access — elevated severity
|
|
1196
|
+
*/
|
|
1197
|
+
public void logEmergencyAccess(AuditEvent event) {
|
|
1198
|
+
event.setSeverity("CRITICAL");
|
|
1199
|
+
event.setEmergencyAccess(true);
|
|
1200
|
+
logAccess(event);
|
|
1201
|
+
}
|
|
1202
|
+
|
|
1203
|
+
/**
|
|
1204
|
+
* Trigger security alert (email + Slack + PagerDuty)
|
|
1205
|
+
*/
|
|
1206
|
+
public void triggerSecurityAlert(String type, String message) {
|
|
1207
|
+
if (!alertEnabled) return;
|
|
1208
|
+
|
|
1209
|
+
SecurityAlert alert = SecurityAlert.builder()
|
|
1210
|
+
.type(type)
|
|
1211
|
+
.message(message)
|
|
1212
|
+
.timestamp(Instant.now())
|
|
1213
|
+
.severity("HIGH")
|
|
1214
|
+
.build();
|
|
1215
|
+
|
|
1216
|
+
// Send to security monitoring channel
|
|
1217
|
+
auditEmitter.send(Message.of(alert)
|
|
1218
|
+
.withMetadata(OutgoingKafkaRecordMetadata.builder()
|
|
1219
|
+
.withTopic("security-alerts")
|
|
1220
|
+
.withKey(type)
|
|
1221
|
+
.build()));
|
|
1222
|
+
}
|
|
1223
|
+
|
|
1224
|
+
/**
|
|
1225
|
+
* Detect suspicious access patterns
|
|
1226
|
+
*/
|
|
1227
|
+
private void detectSuspiciousActivity(AuditEvent event) {
|
|
1228
|
+
String userId = event.getUserId();
|
|
1229
|
+
|
|
1230
|
+
// Pattern 1: High-volume patient record access (data exfiltration)
|
|
1231
|
+
long recentAccesses = auditRepository.countRecentAccesses(
|
|
1232
|
+
userId, "Patient", Duration.ofMinutes(5));
|
|
1233
|
+
if (recentAccesses > 50) {
|
|
1234
|
+
triggerSecurityAlert("HIGH_VOLUME_ACCESS",
|
|
1235
|
+
"User " + userId + " accessed " + recentAccesses +
|
|
1236
|
+
" patient records in 5 minutes. Possible data exfiltration.");
|
|
1237
|
+
}
|
|
1238
|
+
|
|
1239
|
+
// Pattern 2: Access denied followed by emergency access
|
|
1240
|
+
if ("EMERGENCY_ACCESS".equals(event.getAction())) {
|
|
1241
|
+
long recentDenials = auditRepository.countRecentDenials(
|
|
1242
|
+
userId, Duration.ofMinutes(10));
|
|
1243
|
+
if (recentDenials > 0) {
|
|
1244
|
+
triggerSecurityAlert("EMERGENCY_AFTER_DENIAL",
|
|
1245
|
+
"User " + userId + " used emergency access after " +
|
|
1246
|
+
recentDenials + " access denials. Requires review.");
|
|
1247
|
+
}
|
|
1248
|
+
}
|
|
1249
|
+
|
|
1250
|
+
// Pattern 3: After-hours access to sensitive records
|
|
1251
|
+
LocalTime now = LocalTime.now(ZoneId.of("Asia/Ho_Chi_Minh"));
|
|
1252
|
+
if ((now.isBefore(LocalTime.of(6, 0)) || now.isAfter(LocalTime.of(22, 0)))
|
|
1253
|
+
&& "READ".equals(event.getAction())
|
|
1254
|
+
&& Set.of("Patient", "LabResult", "Prescription")
|
|
1255
|
+
.contains(event.getResourceType())) {
|
|
1256
|
+
triggerSecurityAlert("AFTER_HOURS_ACCESS",
|
|
1257
|
+
"User " + userId + " accessed " + event.getResourceType() +
|
|
1258
|
+
" at " + now + ". After-hours access requires review.");
|
|
1259
|
+
}
|
|
1260
|
+
}
|
|
1261
|
+
}
|
|
1262
|
+
```
|
|
1263
|
+
|
|
1264
|
+
---
|
|
1265
|
+
|
|
1266
|
+
## 7. Bước 5: Kubernetes Deployment
|
|
1267
|
+
|
|
1268
|
+
### 7.1. Secure Deployment Manifests
|
|
1269
|
+
|
|
1270
|
+
```yaml
|
|
1271
|
+
# kubernetes/base/patient-service/deployment.yaml
|
|
1272
|
+
apiVersion: apps/v1
|
|
1273
|
+
kind: Deployment
|
|
1274
|
+
metadata:
|
|
1275
|
+
name: patient-service
|
|
1276
|
+
namespace: healthcare
|
|
1277
|
+
labels:
|
|
1278
|
+
app: patient-service
|
|
1279
|
+
compliance: hipaa
|
|
1280
|
+
spec:
|
|
1281
|
+
replicas: 3
|
|
1282
|
+
selector:
|
|
1283
|
+
matchLabels:
|
|
1284
|
+
app: patient-service
|
|
1285
|
+
template:
|
|
1286
|
+
metadata:
|
|
1287
|
+
labels:
|
|
1288
|
+
app: patient-service
|
|
1289
|
+
security.istio.io/tlsMode: istio
|
|
1290
|
+
annotations:
|
|
1291
|
+
sidecar.istio.io/inject: "true"
|
|
1292
|
+
vault.hashicorp.com/agent-inject: "true"
|
|
1293
|
+
vault.hashicorp.com/role: "patient-service"
|
|
1294
|
+
vault.hashicorp.com/agent-inject-secret-db-certs: "pki/issue/patient-service"
|
|
1295
|
+
spec:
|
|
1296
|
+
serviceAccountName: patient-service-sa
|
|
1297
|
+
automountServiceAccountToken: false
|
|
1298
|
+
|
|
1299
|
+
securityContext:
|
|
1300
|
+
runAsNonRoot: true
|
|
1301
|
+
runAsUser: 1000
|
|
1302
|
+
runAsGroup: 1000
|
|
1303
|
+
fsGroup: 1000
|
|
1304
|
+
seccompProfile:
|
|
1305
|
+
type: RuntimeDefault
|
|
1306
|
+
|
|
1307
|
+
containers:
|
|
1308
|
+
- name: patient-service
|
|
1309
|
+
image: registry.hospital.local/patient-service:1.0.0
|
|
1310
|
+
|
|
1311
|
+
securityContext:
|
|
1312
|
+
allowPrivilegeEscalation: false
|
|
1313
|
+
readOnlyRootFilesystem: true
|
|
1314
|
+
capabilities:
|
|
1315
|
+
drop: ["ALL"]
|
|
1316
|
+
|
|
1317
|
+
ports:
|
|
1318
|
+
- containerPort: 8443
|
|
1319
|
+
name: https
|
|
1320
|
+
protocol: TCP
|
|
1321
|
+
|
|
1322
|
+
env:
|
|
1323
|
+
- name: QUARKUS_PROFILE
|
|
1324
|
+
value: "production"
|
|
1325
|
+
- name: OIDC_CLIENT_SECRET
|
|
1326
|
+
valueFrom:
|
|
1327
|
+
secretKeyRef:
|
|
1328
|
+
name: patient-service-oidc
|
|
1329
|
+
key: client-secret
|
|
1330
|
+
|
|
1331
|
+
resources:
|
|
1332
|
+
requests:
|
|
1333
|
+
memory: "256Mi"
|
|
1334
|
+
cpu: "250m"
|
|
1335
|
+
limits:
|
|
1336
|
+
memory: "512Mi"
|
|
1337
|
+
cpu: "500m"
|
|
1338
|
+
|
|
1339
|
+
livenessProbe:
|
|
1340
|
+
httpGet:
|
|
1341
|
+
path: /q/health/live
|
|
1342
|
+
port: 8443
|
|
1343
|
+
scheme: HTTPS
|
|
1344
|
+
initialDelaySeconds: 15
|
|
1345
|
+
periodSeconds: 10
|
|
1346
|
+
|
|
1347
|
+
readinessProbe:
|
|
1348
|
+
httpGet:
|
|
1349
|
+
path: /q/health/ready
|
|
1350
|
+
port: 8443
|
|
1351
|
+
scheme: HTTPS
|
|
1352
|
+
initialDelaySeconds: 5
|
|
1353
|
+
periodSeconds: 5
|
|
1354
|
+
|
|
1355
|
+
volumeMounts:
|
|
1356
|
+
- name: tls-certs
|
|
1357
|
+
mountPath: /certs
|
|
1358
|
+
readOnly: true
|
|
1359
|
+
- name: tmp
|
|
1360
|
+
mountPath: /tmp
|
|
1361
|
+
|
|
1362
|
+
volumes:
|
|
1363
|
+
- name: tls-certs
|
|
1364
|
+
secret:
|
|
1365
|
+
secretName: patient-service-tls
|
|
1366
|
+
- name: tmp
|
|
1367
|
+
emptyDir:
|
|
1368
|
+
medium: Memory
|
|
1369
|
+
sizeLimit: 64Mi
|
|
1370
|
+
---
|
|
1371
|
+
# Network Policy — restrict ingress/egress
|
|
1372
|
+
apiVersion: networking.k8s.io/v1
|
|
1373
|
+
kind: NetworkPolicy
|
|
1374
|
+
metadata:
|
|
1375
|
+
name: patient-service-netpol
|
|
1376
|
+
namespace: healthcare
|
|
1377
|
+
spec:
|
|
1378
|
+
podSelector:
|
|
1379
|
+
matchLabels:
|
|
1380
|
+
app: patient-service
|
|
1381
|
+
policyTypes:
|
|
1382
|
+
- Ingress
|
|
1383
|
+
- Egress
|
|
1384
|
+
ingress:
|
|
1385
|
+
- from:
|
|
1386
|
+
# Only API Gateway can access Patient Service
|
|
1387
|
+
- podSelector:
|
|
1388
|
+
matchLabels:
|
|
1389
|
+
app: api-gateway
|
|
1390
|
+
ports:
|
|
1391
|
+
- port: 8443
|
|
1392
|
+
protocol: TCP
|
|
1393
|
+
egress:
|
|
1394
|
+
# PostgreSQL
|
|
1395
|
+
- to:
|
|
1396
|
+
- podSelector:
|
|
1397
|
+
matchLabels:
|
|
1398
|
+
app: postgresql
|
|
1399
|
+
ports:
|
|
1400
|
+
- port: 5432
|
|
1401
|
+
# Keycloak (token verification)
|
|
1402
|
+
- to:
|
|
1403
|
+
- podSelector:
|
|
1404
|
+
matchLabels:
|
|
1405
|
+
app: keycloak
|
|
1406
|
+
ports:
|
|
1407
|
+
- port: 8443
|
|
1408
|
+
# Kafka (audit events)
|
|
1409
|
+
- to:
|
|
1410
|
+
- podSelector:
|
|
1411
|
+
matchLabels:
|
|
1412
|
+
app: kafka
|
|
1413
|
+
ports:
|
|
1414
|
+
- port: 9093
|
|
1415
|
+
# Vault (encryption)
|
|
1416
|
+
- to:
|
|
1417
|
+
- podSelector:
|
|
1418
|
+
matchLabels:
|
|
1419
|
+
app: vault
|
|
1420
|
+
ports:
|
|
1421
|
+
- port: 8200
|
|
1422
|
+
# DNS
|
|
1423
|
+
- to: []
|
|
1424
|
+
ports:
|
|
1425
|
+
- port: 53
|
|
1426
|
+
protocol: UDP
|
|
1427
|
+
```
|
|
1428
|
+
|
|
1429
|
+
---
|
|
1430
|
+
|
|
1431
|
+
## 8. Bước 6: Security Testing & Compliance
|
|
1432
|
+
|
|
1433
|
+
### 8.1. Automated HIPAA Compliance Verification
|
|
1434
|
+
|
|
1435
|
+
```java
|
|
1436
|
+
// HIPAAComplianceTest.java — Run as integration test
|
|
1437
|
+
|
|
1438
|
+
@QuarkusIntegrationTest
|
|
1439
|
+
public class HIPAAComplianceTest {
|
|
1440
|
+
|
|
1441
|
+
/**
|
|
1442
|
+
* §164.312(a)(1) — Access Control
|
|
1443
|
+
*/
|
|
1444
|
+
@Test
|
|
1445
|
+
void testAccessControl_uniqueUserIdentification() {
|
|
1446
|
+
// Every API call must have a unique user identifier
|
|
1447
|
+
Response response = given()
|
|
1448
|
+
.header("Authorization", "Bearer " + getValidToken("dr.nguyen"))
|
|
1449
|
+
.when()
|
|
1450
|
+
.get("/api/v1/patients/PAT-001")
|
|
1451
|
+
.then()
|
|
1452
|
+
.statusCode(200)
|
|
1453
|
+
.extract().response();
|
|
1454
|
+
|
|
1455
|
+
// Verify audit log has unique user ID
|
|
1456
|
+
AuditEntry audit = getLatestAuditEntry();
|
|
1457
|
+
assertThat(audit.getUserId()).isEqualTo("EMP-001");
|
|
1458
|
+
assertThat(audit.getUserId()).isNotBlank();
|
|
1459
|
+
}
|
|
1460
|
+
|
|
1461
|
+
@Test
|
|
1462
|
+
void testAccessControl_automaticLogoff() {
|
|
1463
|
+
// Session timeout must be <= 15 minutes
|
|
1464
|
+
String token = getValidToken("dr.nguyen");
|
|
1465
|
+
|
|
1466
|
+
// Token should expire within 5 minutes (access token)
|
|
1467
|
+
DecodedJWT jwt = JWT.decode(token);
|
|
1468
|
+
long lifespanSeconds = jwt.getExpiresAt().getTime() / 1000 -
|
|
1469
|
+
jwt.getIssuedAt().getTime() / 1000;
|
|
1470
|
+
assertThat(lifespanSeconds).isLessThanOrEqualTo(300); // 5 min
|
|
1471
|
+
}
|
|
1472
|
+
|
|
1473
|
+
@Test
|
|
1474
|
+
void testAccessControl_encryptionAtRest() {
|
|
1475
|
+
// Create a patient and verify data is encrypted in DB
|
|
1476
|
+
createTestPatient();
|
|
1477
|
+
|
|
1478
|
+
// Direct DB query — PHI fields must be encrypted
|
|
1479
|
+
try (Connection conn = getDirectDBConnection()) {
|
|
1480
|
+
var rs = conn.createStatement().executeQuery(
|
|
1481
|
+
"SELECT full_name_encrypted, ssn_encrypted " +
|
|
1482
|
+
"FROM patient_data.patients WHERE mrn = 'TEST-MRN-001'");
|
|
1483
|
+
|
|
1484
|
+
assertTrue(rs.next());
|
|
1485
|
+
|
|
1486
|
+
String nameField = rs.getString("full_name_encrypted");
|
|
1487
|
+
String ssnField = rs.getString("ssn_encrypted");
|
|
1488
|
+
|
|
1489
|
+
// Fields should be JSON with encrypted data, not plaintext
|
|
1490
|
+
assertThat(nameField).contains("ciphertext");
|
|
1491
|
+
assertThat(nameField).doesNotContain("Nguyễn");
|
|
1492
|
+
assertThat(ssnField).contains("ciphertext");
|
|
1493
|
+
assertThat(ssnField).doesNotContain("123-45-6789");
|
|
1494
|
+
}
|
|
1495
|
+
}
|
|
1496
|
+
|
|
1497
|
+
/**
|
|
1498
|
+
* §164.312(b) — Audit Controls
|
|
1499
|
+
*/
|
|
1500
|
+
@Test
|
|
1501
|
+
void testAuditControls_allPHIAccessLogged() {
|
|
1502
|
+
long auditCountBefore = getAuditLogCount();
|
|
1503
|
+
|
|
1504
|
+
// Access patient record
|
|
1505
|
+
given()
|
|
1506
|
+
.header("Authorization", "Bearer " + getValidToken("dr.nguyen"))
|
|
1507
|
+
.when()
|
|
1508
|
+
.get("/api/v1/patients/PAT-001")
|
|
1509
|
+
.then()
|
|
1510
|
+
.statusCode(200);
|
|
1511
|
+
|
|
1512
|
+
long auditCountAfter = getAuditLogCount();
|
|
1513
|
+
assertThat(auditCountAfter).isGreaterThan(auditCountBefore);
|
|
1514
|
+
|
|
1515
|
+
AuditEntry latest = getLatestAuditEntry();
|
|
1516
|
+
assertThat(latest.getAction()).isEqualTo("READ");
|
|
1517
|
+
assertThat(latest.getResourceType()).isEqualTo("Patient");
|
|
1518
|
+
assertThat(latest.getUserId()).isNotBlank();
|
|
1519
|
+
assertThat(latest.getTimestamp()).isNotNull();
|
|
1520
|
+
assertThat(latest.getResult()).isEqualTo("SUCCESS");
|
|
1521
|
+
}
|
|
1522
|
+
|
|
1523
|
+
@Test
|
|
1524
|
+
void testAuditControls_auditLogsImmutable() {
|
|
1525
|
+
// Attempt to delete audit logs should fail
|
|
1526
|
+
try (Connection conn = getServiceDBConnection()) {
|
|
1527
|
+
assertThrows(SQLException.class, () -> {
|
|
1528
|
+
conn.createStatement().executeUpdate(
|
|
1529
|
+
"DELETE FROM audit_data.access_log WHERE id IS NOT NULL");
|
|
1530
|
+
});
|
|
1531
|
+
}
|
|
1532
|
+
|
|
1533
|
+
// Attempt to update audit logs should fail
|
|
1534
|
+
try (Connection conn = getServiceDBConnection()) {
|
|
1535
|
+
assertThrows(SQLException.class, () -> {
|
|
1536
|
+
conn.createStatement().executeUpdate(
|
|
1537
|
+
"UPDATE audit_data.access_log SET result = 'MODIFIED'");
|
|
1538
|
+
});
|
|
1539
|
+
}
|
|
1540
|
+
}
|
|
1541
|
+
|
|
1542
|
+
/**
|
|
1543
|
+
* §164.312(c)(1) — Integrity
|
|
1544
|
+
*/
|
|
1545
|
+
@Test
|
|
1546
|
+
void testIntegrity_prescriptionDigitalSignature() {
|
|
1547
|
+
// Create prescription
|
|
1548
|
+
String prescriptionId = createTestPrescription();
|
|
1549
|
+
|
|
1550
|
+
// Verify digital signature exists
|
|
1551
|
+
try (Connection conn = getDirectDBConnection()) {
|
|
1552
|
+
var rs = conn.createStatement().executeQuery(
|
|
1553
|
+
"SELECT physician_signature FROM prescription_data.prescriptions " +
|
|
1554
|
+
"WHERE id = '" + prescriptionId + "'");
|
|
1555
|
+
|
|
1556
|
+
assertTrue(rs.next());
|
|
1557
|
+
String signature = rs.getString("physician_signature");
|
|
1558
|
+
assertThat(signature).isNotNull();
|
|
1559
|
+
assertThat(signature).contains("algorithm");
|
|
1560
|
+
assertThat(signature).contains("signature");
|
|
1561
|
+
}
|
|
1562
|
+
}
|
|
1563
|
+
|
|
1564
|
+
/**
|
|
1565
|
+
* §164.312(d) — Person or Entity Authentication
|
|
1566
|
+
*/
|
|
1567
|
+
@Test
|
|
1568
|
+
void testAuthentication_mfaForSensitiveOps() {
|
|
1569
|
+
// Token without MFA claim
|
|
1570
|
+
String tokenNoMFA = getTokenWithoutMFA("dr.nguyen");
|
|
1571
|
+
|
|
1572
|
+
// Creating prescription should require MFA
|
|
1573
|
+
given()
|
|
1574
|
+
.header("Authorization", "Bearer " + tokenNoMFA)
|
|
1575
|
+
.contentType(ContentType.JSON)
|
|
1576
|
+
.body(createPrescriptionPayload())
|
|
1577
|
+
.when()
|
|
1578
|
+
.post("/api/v1/prescriptions")
|
|
1579
|
+
.then()
|
|
1580
|
+
.statusCode(403)
|
|
1581
|
+
.body("error", containsString("MFA"));
|
|
1582
|
+
}
|
|
1583
|
+
|
|
1584
|
+
/**
|
|
1585
|
+
* §164.312(e)(1) — Transmission Security
|
|
1586
|
+
*/
|
|
1587
|
+
@Test
|
|
1588
|
+
void testTransmissionSecurity_tlsEnforced() {
|
|
1589
|
+
// HTTP (non-TLS) request should be rejected
|
|
1590
|
+
given()
|
|
1591
|
+
.baseUri("http://localhost:8080") // HTTP, not HTTPS
|
|
1592
|
+
.when()
|
|
1593
|
+
.get("/api/v1/health")
|
|
1594
|
+
.then()
|
|
1595
|
+
// Should redirect to HTTPS or reject
|
|
1596
|
+
.statusCode(anyOf(is(301), is(400), is(403)));
|
|
1597
|
+
}
|
|
1598
|
+
|
|
1599
|
+
@Test
|
|
1600
|
+
void testTransmissionSecurity_securityHeaders() {
|
|
1601
|
+
Response response = given()
|
|
1602
|
+
.header("Authorization", "Bearer " + getValidToken("dr.nguyen"))
|
|
1603
|
+
.when()
|
|
1604
|
+
.get("/api/v1/patients/PAT-001")
|
|
1605
|
+
.then()
|
|
1606
|
+
.statusCode(200)
|
|
1607
|
+
.extract().response();
|
|
1608
|
+
|
|
1609
|
+
Headers headers = response.headers();
|
|
1610
|
+
assertThat(headers.getValue("Strict-Transport-Security")).isNotNull();
|
|
1611
|
+
assertThat(headers.getValue("X-Content-Type-Options")).isEqualTo("nosniff");
|
|
1612
|
+
assertThat(headers.getValue("X-Frame-Options")).isEqualTo("DENY");
|
|
1613
|
+
assertThat(headers.getValue("Cache-Control")).contains("no-store");
|
|
1614
|
+
}
|
|
1615
|
+
|
|
1616
|
+
/**
|
|
1617
|
+
* RLS Verification — Department Isolation
|
|
1618
|
+
*/
|
|
1619
|
+
@Test
|
|
1620
|
+
void testRLS_departmentIsolation() {
|
|
1621
|
+
// Cardiologist should not see neurology patients
|
|
1622
|
+
String cardioToken = getTokenForDepartment("dr.nguyen", "cardiology");
|
|
1623
|
+
|
|
1624
|
+
String result = given()
|
|
1625
|
+
.header("Authorization", "Bearer " + cardioToken)
|
|
1626
|
+
.when()
|
|
1627
|
+
.get("/api/v1/patients/search?department=neurology")
|
|
1628
|
+
.then()
|
|
1629
|
+
.statusCode(200)
|
|
1630
|
+
.extract().body().asString();
|
|
1631
|
+
|
|
1632
|
+
// RLS should filter out neurology patients
|
|
1633
|
+
assertThat(result).doesNotContain("neurology");
|
|
1634
|
+
}
|
|
1635
|
+
|
|
1636
|
+
@Test
|
|
1637
|
+
void testRLS_patientSelfAccess() {
|
|
1638
|
+
// Patient can only see their own records
|
|
1639
|
+
String patientToken = getTokenForPatient("patient.le", "PAT-001");
|
|
1640
|
+
|
|
1641
|
+
// Access own record — should succeed
|
|
1642
|
+
given()
|
|
1643
|
+
.header("Authorization", "Bearer " + patientToken)
|
|
1644
|
+
.when()
|
|
1645
|
+
.get("/api/v1/patients/PAT-001")
|
|
1646
|
+
.then()
|
|
1647
|
+
.statusCode(200);
|
|
1648
|
+
|
|
1649
|
+
// Access other patient — should fail
|
|
1650
|
+
given()
|
|
1651
|
+
.header("Authorization", "Bearer " + patientToken)
|
|
1652
|
+
.when()
|
|
1653
|
+
.get("/api/v1/patients/PAT-002")
|
|
1654
|
+
.then()
|
|
1655
|
+
.statusCode(anyOf(is(403), is(404)));
|
|
1656
|
+
}
|
|
1657
|
+
}
|
|
1658
|
+
```
|
|
1659
|
+
|
|
1660
|
+
---
|
|
1661
|
+
|
|
1662
|
+
## 9. Bước 7: Monitoring & Observability
|
|
1663
|
+
|
|
1664
|
+
### 9.1. Security Monitoring Stack
|
|
1665
|
+
|
|
1666
|
+
```yaml
|
|
1667
|
+
# docker-compose.monitoring.yml
|
|
1668
|
+
services:
|
|
1669
|
+
# Elasticsearch for audit log storage
|
|
1670
|
+
elasticsearch:
|
|
1671
|
+
image: docker.elastic.co/elasticsearch/elasticsearch:8.15.0
|
|
1672
|
+
environment:
|
|
1673
|
+
- discovery.type=single-node
|
|
1674
|
+
- xpack.security.enabled=true
|
|
1675
|
+
- ELASTIC_PASSWORD=${ELASTIC_PASSWORD}
|
|
1676
|
+
volumes:
|
|
1677
|
+
- es-data:/usr/share/elasticsearch/data
|
|
1678
|
+
|
|
1679
|
+
# Kibana for security dashboards
|
|
1680
|
+
kibana:
|
|
1681
|
+
image: docker.elastic.co/kibana/kibana:8.15.0
|
|
1682
|
+
environment:
|
|
1683
|
+
- ELASTICSEARCH_HOSTS=http://elasticsearch:9200
|
|
1684
|
+
- ELASTICSEARCH_PASSWORD=${ELASTIC_PASSWORD}
|
|
1685
|
+
depends_on:
|
|
1686
|
+
- elasticsearch
|
|
1687
|
+
|
|
1688
|
+
# Grafana for security metrics
|
|
1689
|
+
grafana:
|
|
1690
|
+
image: grafana/grafana:11.0.0
|
|
1691
|
+
volumes:
|
|
1692
|
+
- ./monitoring/grafana/dashboards:/var/lib/grafana/dashboards
|
|
1693
|
+
- ./monitoring/grafana/datasources:/etc/grafana/provisioning/datasources
|
|
1694
|
+
|
|
1695
|
+
# Prometheus for metrics collection
|
|
1696
|
+
prometheus:
|
|
1697
|
+
image: prom/prometheus:v2.53.0
|
|
1698
|
+
volumes:
|
|
1699
|
+
- ./monitoring/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
|
|
1700
|
+
- ./monitoring/prometheus/alerts/:/etc/prometheus/alerts/
|
|
1701
|
+
|
|
1702
|
+
# Alertmanager for security alerts
|
|
1703
|
+
alertmanager:
|
|
1704
|
+
image: prom/alertmanager:v0.27.0
|
|
1705
|
+
volumes:
|
|
1706
|
+
- ./monitoring/alertmanager/config.yml:/etc/alertmanager/config.yml
|
|
1707
|
+
```
|
|
1708
|
+
|
|
1709
|
+
### 9.2. Security Dashboard Panels
|
|
1710
|
+
|
|
1711
|
+
```
|
|
1712
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
1713
|
+
│ Healthcare Security Dashboard │
|
|
1714
|
+
├─────────────────────────────────────────────────────────────┤
|
|
1715
|
+
│ │
|
|
1716
|
+
│ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │
|
|
1717
|
+
│ │ Auth Failures│ │ PHI Access │ │ Emergency │ │
|
|
1718
|
+
│ │ Today │ │ Today │ │ Access │ │
|
|
1719
|
+
│ │ 12 │ │ 1,234 │ │ 0 │ │
|
|
1720
|
+
│ │ ▼ vs yday │ │ ≈ normal │ │ ✅ OK │ │
|
|
1721
|
+
│ └─────────────┘ └─────────────┘ └─────────────┘ │
|
|
1722
|
+
│ │
|
|
1723
|
+
│ ┌──────────────────────────────────────────────────────┐ │
|
|
1724
|
+
│ │ PHI Access by Department (Last 24h) │ │
|
|
1725
|
+
│ │ ████████████████████ Cardiology (450) │ │
|
|
1726
|
+
│ │ ███████████████ Internal Medicine (320) │ │
|
|
1727
|
+
│ │ ██████████ Neurology (210) │ │
|
|
1728
|
+
│ │ █████ Pediatrics (120) │ │
|
|
1729
|
+
│ │ ███ Emergency (78) │ │
|
|
1730
|
+
│ └──────────────────────────────────────────────────────┘ │
|
|
1731
|
+
│ │
|
|
1732
|
+
│ ┌──────────────────────────────────────────────────────┐ │
|
|
1733
|
+
│ │ Access Denied Events (Last 7 days) │ │
|
|
1734
|
+
│ │ ┊ ╭╮ │ │
|
|
1735
|
+
│ │ ┊ ╭╯╰╮ ╭╮ │ │
|
|
1736
|
+
│ │ ┊╭──╯ ╰────╯╰──╮ │ │
|
|
1737
|
+
│ │ ┊╯ ╰────── │ │
|
|
1738
|
+
│ │ └──────────────────────── │ │
|
|
1739
|
+
│ │ Mon Tue Wed Thu Fri Sat Sun │ │
|
|
1740
|
+
│ └──────────────────────────────────────────────────────┘ │
|
|
1741
|
+
│ │
|
|
1742
|
+
│ Recent Security Events: │
|
|
1743
|
+
│ ⚠️ 14:23 — dr.tran: 45 patient records in 3 min (alert) │
|
|
1744
|
+
│ ✅ 14:15 — yta.pham: Normal ward rounds access │
|
|
1745
|
+
│ ✅ 13:50 — lab.tech: Lab results upload (batch) │
|
|
1746
|
+
│ ℹ️ 13:30 — System: Certificate rotation completed │
|
|
1747
|
+
└─────────────────────────────────────────────────────────────┘
|
|
1748
|
+
```
|
|
1749
|
+
|
|
1750
|
+
---
|
|
1751
|
+
|
|
1752
|
+
## 10. Deliverables & Checklist
|
|
1753
|
+
|
|
1754
|
+
### 10.1. Final Project Checklist
|
|
1755
|
+
|
|
1756
|
+
```
|
|
1757
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
1758
|
+
│ Capstone Project — HIPAA Compliance Checklist │
|
|
1759
|
+
├─────────────────────────────────────────────────────────────┤
|
|
1760
|
+
│ │
|
|
1761
|
+
│ IDENTITY & ACCESS MANAGEMENT │
|
|
1762
|
+
│ ☑ Keycloak realm with RBAC/ABAC roles │
|
|
1763
|
+
│ ☑ MFA required for sensitive operations │
|
|
1764
|
+
│ ☑ Break-the-glass emergency access with audit │
|
|
1765
|
+
│ ☑ Session timeout ≤ 15 minutes │
|
|
1766
|
+
│ ☑ Password policy (12+ chars, complexity, history) │
|
|
1767
|
+
│ ☑ Brute force protection enabled │
|
|
1768
|
+
│ │
|
|
1769
|
+
│ DATA PROTECTION │
|
|
1770
|
+
│ ☑ PHI encrypted at rest (Vault Transit / pgcrypto) │
|
|
1771
|
+
│ ☑ PHI encrypted in transit (TLS 1.2+, mTLS) │
|
|
1772
|
+
│ ☑ Column-level encryption for sensitive fields │
|
|
1773
|
+
│ ☑ Key management via HashiCorp Vault │
|
|
1774
|
+
│ ☑ Key rotation policy configured │
|
|
1775
|
+
│ │
|
|
1776
|
+
│ ACCESS CONTROL │
|
|
1777
|
+
│ ☑ Row-Level Security on all PHI tables │
|
|
1778
|
+
│ ☑ Department-based data isolation │
|
|
1779
|
+
│ ☑ Patient self-access restriction │
|
|
1780
|
+
│ ☑ Multi-tenant isolation │
|
|
1781
|
+
│ ☑ Principle of least privilege for DB roles │
|
|
1782
|
+
│ │
|
|
1783
|
+
│ AUDIT & MONITORING │
|
|
1784
|
+
│ ☑ All PHI access logged (audit_data.access_log) │
|
|
1785
|
+
│ ☑ pgAudit enabled for SQL-level audit │
|
|
1786
|
+
│ ☑ Immutable audit trail (no UPDATE/DELETE) │
|
|
1787
|
+
│ ☑ Centralized logging (ELK Stack) │
|
|
1788
|
+
│ ☑ Security alerts for suspicious patterns │
|
|
1789
|
+
│ ☑ After-hours access monitoring │
|
|
1790
|
+
│ │
|
|
1791
|
+
│ APPLICATION SECURITY │
|
|
1792
|
+
│ ☑ JWT validation + claim-based authorization │
|
|
1793
|
+
│ ☑ Input validation (Bean Validation) │
|
|
1794
|
+
│ ☑ Output encoding (XSS prevention) │
|
|
1795
|
+
│ ☑ Parameterized queries (SQL injection prevention) │
|
|
1796
|
+
│ ☑ Security headers configured │
|
|
1797
|
+
│ ☑ Error responses sanitized (no stack traces) │
|
|
1798
|
+
│ ☑ Rate limiting at API Gateway │
|
|
1799
|
+
│ │
|
|
1800
|
+
│ INFRASTRUCTURE SECURITY │
|
|
1801
|
+
│ ☑ Container security (non-root, read-only FS) │
|
|
1802
|
+
│ ☑ Network Policies (microsegmentation) │
|
|
1803
|
+
│ ☑ Pod Security Standards enforced │
|
|
1804
|
+
│ ☑ Service mesh with mTLS (Istio) │
|
|
1805
|
+
│ ☑ Secrets managed by Vault (not in env vars) │
|
|
1806
|
+
│ │
|
|
1807
|
+
│ SECURITY TESTING │
|
|
1808
|
+
│ ☑ SAST in CI/CD (SonarQube, Semgrep, SpotBugs) │
|
|
1809
|
+
│ ☑ SCA dependency scanning (Trivy, Snyk) │
|
|
1810
|
+
│ ☑ DAST with OWASP ZAP + Nuclei │
|
|
1811
|
+
│ ☑ HIPAA compliance integration tests │
|
|
1812
|
+
│ ☑ SBOM generation (CycloneDX) │
|
|
1813
|
+
│ │
|
|
1814
|
+
│ COMPLIANCE │
|
|
1815
|
+
│ ☑ HIPAA Technical Safeguards mapped and verified │
|
|
1816
|
+
│ ☑ Risk Assessment documented │
|
|
1817
|
+
│ ☑ Security Assessment Report generated │
|
|
1818
|
+
│ ☑ Backup & DR procedures tested │
|
|
1819
|
+
│ ☑ Incident Response Plan documented │
|
|
1820
|
+
│ │
|
|
1821
|
+
│ Status: ✅ ALL CHECKS PASSED │
|
|
1822
|
+
│ HIPAA Compliance: 100% Technical Safeguards │
|
|
1823
|
+
└─────────────────────────────────────────────────────────────┘
|
|
1824
|
+
```
|
|
1825
|
+
|
|
1826
|
+
---
|
|
1827
|
+
|
|
1828
|
+
## 11. Tổng kết khóa học
|
|
1829
|
+
|
|
1830
|
+
Qua **24 bài học**, chúng ta đã xây dựng kiến thức và kỹ năng toàn diện để bảo mật hệ thống y tế:
|
|
1831
|
+
|
|
1832
|
+
```
|
|
1833
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
1834
|
+
│ Hành trình Bảo mật Dữ liệu Y Tế │
|
|
1835
|
+
├─────────────────────────────────────────────────────────────┤
|
|
1836
|
+
│ │
|
|
1837
|
+
│ Phần 1: Nền tảng Phần 2: IAM │
|
|
1838
|
+
│ ✓ HIPAA, HL7 FHIR ✓ Keycloak multi-tenant │
|
|
1839
|
+
│ ✓ Threat Modeling ✓ RBAC/ABAC healthcare │
|
|
1840
|
+
│ ✓ Risk Assessment ✓ SMART on FHIR │
|
|
1841
|
+
│ ✓ Architecture ✓ MFA + Emergency Access │
|
|
1842
|
+
│ │
|
|
1843
|
+
│ Phần 3: Database Phần 4: Microservices │
|
|
1844
|
+
│ ✓ PostgreSQL Hardening ✓ Quarkus OIDC + JWT │
|
|
1845
|
+
│ ✓ Encryption (TDE, ✓ API Gateway + WAF │
|
|
1846
|
+
│ pgcrypto) ✓ E2E Encryption │
|
|
1847
|
+
│ ✓ Row-Level Security ✓ mTLS + Service Mesh │
|
|
1848
|
+
│ ✓ pgAudit + CDC │
|
|
1849
|
+
│ │
|
|
1850
|
+
│ Phần 5: Compliance Phần 6: Nâng cao │
|
|
1851
|
+
│ ✓ HIPAA Safeguards ✓ Zero Trust Architecture │
|
|
1852
|
+
│ ✓ Audit Trail + ELK ✓ Container + K8s Security │
|
|
1853
|
+
│ ✓ Data Masking ✓ Penetration Testing │
|
|
1854
|
+
│ ✓ DR + BCP ✓ Capstone Project │
|
|
1855
|
+
│ │
|
|
1856
|
+
│ ═══════════════════════════════════════════════════════ │
|
|
1857
|
+
│ Kết quả: Secure Healthcare Microservices Platform │
|
|
1858
|
+
│ với FULL HIPAA Technical Safeguards compliance │
|
|
1859
|
+
│ trên Quarkus + PostgreSQL + Keycloak │
|
|
1860
|
+
└─────────────────────────────────────────────────────────────┘
|
|
1861
|
+
```
|
|
1862
|
+
|
|
1863
|
+
### Bước tiếp theo
|
|
1864
|
+
|
|
1865
|
+
1. **Fork repository** và chạy local development environment
|
|
1866
|
+
2. **Customize** cho bệnh viện/tổ chức y tế cụ thể
|
|
1867
|
+
3. **Audit** bằng third-party penetration testing
|
|
1868
|
+
4. **Certify** HIPAA compliance với đánh giá chính thức
|
|
1869
|
+
5. **Monitor** liên tục với security dashboard và alert system
|
|
1870
|
+
|
|
1871
|
+
> **Lưu ý quan trọng**: Bảo mật là một **hành trình liên tục**, không phải đích đến. Hệ thống cần được review, audit, và cập nhật thường xuyên khi có vulnerability mới, thay đổi regulations, hoặc mở rộng chức năng.
|
|
1872
|
+
|
|
1873
|
+
---
|
|
1874
|
+
|
|
1875
|
+
---
|
|
1876
|
+
|
|
1877
|
+
<!-- SERIES-NAV:START -->
|
|
1878
|
+
◀ **Bài trước:** [Bài 23: Penetration Testing & Vulnerability Assessment cho Hệ thống Y Tế](/series/bao-mat-du-lieu-y-te-cho-microservices/bai-23-penetration-testing-vulnerability-assessment-y-te)
|
|
1879
|
+
|
|
1880
|
+
🎉 **Chúc mừng!** Bạn đã hoàn thành series. Hãy quay lại [trang tổng quan](/series/bao-mat-du-lieu-y-te-cho-microservices) để ôn tập.
|
|
1881
|
+
<!-- SERIES-NAV:END -->
|