Bộ Hướng dẫn Triển khai Core FHIR cho Việt Nam
0.5.0 - Draft for Community Review
Bộ Hướng dẫn Triển khai Core FHIR cho Việt Nam - Draft for Community Review (v0.5.0) built by the FHIR (HL7® FHIR® Standard) Build Tools. See the Directory of published versions
4 bước để cài thử VN Core, build cục bộ và validate resource đầu tiên.
Quy mô phiên bản hiện hành xem tại Trang chủ.
Sơ đồ này nhấn mạnh 3 điểm: VN Core được biên soạn từ một workspace thống nhất, artifact được tách rõ giữa profiles/extensions/terminology/examples, và các gói phát hành đi ra nhiều lớp triển khai khác nhau thay vì ép mọi nhu cầu vào cùng một package.
| Thành phần | Vai trò | Ví dụ |
|---|---|---|
| Hồ sơ | Định nghĩa cấu trúc resource phù hợp Việt Nam | VNCorePatient: CCCD, tên tiếng Việt, dân tộc |
| Phần mở rộng | Thêm phần tử dữ liệu đặc thù Việt Nam | vn-ext-ethnicity: 54 dân tộc |
| CodeSystems | Bộ mã chuẩn hóa | VNEthnicityCS: mã 01=Kinh, 02=Tày… |
| ValueSets | Tập giá trị cho phép | VNEthnicityVS: bind từ VNEthnicityCS |
| NamingSystems | Định danh identifier | VN-CCCD: http://fhir.hl7.org.vn/core/sid/cccd |
| Examples | Dữ liệu mẫu | Bệnh nhân Nguyễn Văn An, BV Chợ Rẫy |
Khi triển khai thật, 3 lớp hướng dẫn bắt buộc phải đọc:
| Gói | Vai trò | Dùng khi nào |
|---|---|---|
hl7.fhir.vn.core |
Gói tổng hợp | Kiểm tra cục bộ, đào tạo, thử nghiệm nhanh và cài đặt trọn bộ |
hl7.fhir.vn.core.base |
Gói lõi ổn định | EMR, HIE, hồ sơ công dân, dữ liệu dùng chung và liên thông FHIR-native |
hl7.fhir.vn.bhyt.submission |
Gói liên thông hồ sơ thanh toán BHYT | Gateway, adapter, kiểm tra và ánh xạ hồ sơ thanh toán; phụ thuộc hl7.fhir.vn.core.base |
hl7.fhir.vn.terminology.clinical |
Gói thuật ngữ lâm sàng | ICD-10 VN, ICD-9-CM, SNOMED CT VN subset, CLS, LOINC, ConceptMap lâm sàng |
hl7.fhir.vn.terminology.traditional-medicine |
Gói thuật ngữ Y học cổ truyền | Toàn bộ bộ mã Y học cổ truyền hiện hành |
hl7.fhir.vn.device |
Gói thiết bị y tế | Danh pháp thiết bị, DeviceDefinition, regulatory workflow, UDI guidance, kiểm định, asset và procurement khi có use case |
| Phần mềm | Phiên bản | Mục đích |
|---|---|---|
| Node.js | 22.x (khuyến nghị) | Chạy SUSHI, khớp với CI |
| SUSHI | >= 3.x | Biên dịch FSH → JSON |
| Java JDK | >= 17 | Chạy IG Publisher |
| Ruby + Jekyll | Homebrew Ruby >= 3.x | IG Publisher dùng Jekyll để render HTML |
Repo public sẽ được công bố sau khi governance và kênh đóng góp được chốt. Trong giai đoạn thí điểm, nhóm triển khai nhận source package trực tiếp từ Omi HealthTech hoặc qua kênh review được chỉ định.
# Cài SUSHI (nếu chưa có)
npm install -g fsh-sushi
# Repo cố định major version của Node tại đây
cat .nvmrc
# Cài Jekyll (cần cho IG Publisher full build)
# macOS/Homebrew Ruby được khuyến nghị để tránh dùng system Ruby 2.6
export PATH="/opt/homebrew/opt/ruby/bin:$PATH"
gem install jekyll bundler --no-document
export PATH="$(/opt/homebrew/opt/ruby/bin/gem env gemdir)/bin:$PATH"
jekyll --version
# Biên dịch FSH → JSON
./scripts/validate.sh --quick
# Kết quả dự kiến: build sạch, 0 lỗi, 0 cảnh báo
# Sinh các gói phát hành
python3 scripts/build-split-packages.py
./scripts/validate.sh --quick sẽ tự sinh lại các tài nguyên JSON thuật ngữ lớn trong input/resources/ trước khi gọi SUSHI. Nếu chỉ chạy sushi . trực tiếp, cần bảo đảm các tài nguyên này đã được cập nhật từ dữ liệu nguồn.
# Tải IG Publisher (lần đầu, ~200MB)
bash _updatePublisher.sh -y
# Build toàn bộ IG → thư mục output/
bash _genonce.sh
# Xem kết quả
open output/index.html # Website IG
open output/qa.html # Báo cáo QA
_genonce.sh sẽ tự dò jekyll trong Homebrew Ruby gem bin nếu executable chưa có sẵn trong PATH.
Ví dụ JSON — bệnh nhân có CCCD, thẻ BHYT, dân tộc Kinh:
{
"resourceType": "Patient",
"meta": {
"profile": ["http://fhir.hl7.org.vn/core/StructureDefinition/vn-core-patient"]
},
"identifier": [
{
"type": {
"coding": [{
"system": "http://fhir.hl7.org.vn/core/CodeSystem/vn-identifier-type-cs",
"code": "CCCD"
}]
},
"system": "http://fhir.hl7.org.vn/core/sid/cccd",
"value": "001099012345"
},
{
"type": {
"coding": [{
"system": "http://fhir.hl7.org.vn/core/CodeSystem/vn-identifier-type-cs",
"code": "BHYT"
}]
},
"system": "http://fhir.hl7.org.vn/core/sid/bhyt",
"value": "DN4010199012345"
}
],
"name": [{
"use": "official",
"text": "Nguyen Van An",
"family": "Nguyen",
"given": ["Van", "An"]
}],
"gender": "male",
"birthDate": "1990-05-15",
"address": [{
"use": "home",
"text": "123 Nguyen Hue, Phuong Ngoc Ha, Ha Noi",
"state": "Ha Noi",
"extension": [
{
"url": "http://fhir.hl7.org.vn/core/StructureDefinition/vn-ext-province",
"valueCoding": {
"system": "http://fhir.hl7.org.vn/core/CodeSystem/vn-province-cs",
"code": "01",
"display": "Ha Noi"
}
},
{
"url": "http://fhir.hl7.org.vn/core/StructureDefinition/vn-ext-ward",
"valueCoding": {
"system": "http://fhir.hl7.org.vn/core/CodeSystem/vn-ward-cs",
"code": "00008",
"display": "Phuong Ngoc Ha"
}
}
]
}],
"extension": [
{
"url": "http://fhir.hl7.org.vn/core/StructureDefinition/vn-ext-ethnicity",
"valueCodeableConcept": {
"coding": [{
"system": "http://fhir.hl7.org.vn/core/CodeSystem/vn-ethnicity-cs",
"code": "01",
"display": "Kinh"
}]
}
}
]
}
# Tải validator (lần đầu)
wget https://github.com/hapifhir/org.hl7.fhir.core/releases/latest/download/validator_cli.jar
# Tạo local package snapshot (nếu chưa có)
bash _genonce.sh
# Validate bằng local package snapshot
java -jar validator_cli.jar patient.json \
-ig output/package.tgz \
-profile http://fhir.hl7.org.vn/core/StructureDefinition/vn-core-patient
# Chạy thêm Tier 2 executable checks của repo
./scripts/validate-tier2.sh
./scripts/validate-security-baseline.sh
./scripts/validate-bhyt-roundtrip.sh
./scripts/validate-terminology-governance.sh
# Mở báo cáo coverage round-trip BHYT
open output/bhyt-roundtrip/index.html
# Build từ source (khuyến nghị cho phiên bản công bố hiện hành 0.5.0)
./scripts/validate.sh --quick
# Sinh các gói phát hành
python3 scripts/build-split-packages.py
# Sử dụng NPM package (khi đã publish lên registry — chưa áp dụng cho 0.5.0)
# npm --registry https://packages.fhir.org install [email protected]
core.base, bhyt.submission, terminology.clinical, terminology.traditional-medicine)validate-tier2.sh, validate-security-baseline.sh, validate-bhyt-roundtrip.sh, validate-terminology-governance.shHướng dẫn tích hợp theo vai trò cụ thể xem Tuân thủ theo vai trò triển khai.
| Lỗi | Nguyên nhân thường gặp | Xem thêm |
|---|---|---|
Unknown code in system cho CCCD/BHYT |
Dùng sai system URI — phải dùng http://fhir.hl7.org.vn/core/sid/cccd |
Registry định danh |
Profile validation error trên Patient.name |
Tiếng Việt có dấu không đúng encoding (phải là UTF-8 NFC) | Tìm kiếm chuỗi & Unicode |
Slice not found trên Patient.identifier |
Thiếu slice cho CCCD hoặc dùng sai discriminator | Hướng dẫn Must Support |
Code not found in ValueSet trên địa chỉ |
Mã tỉnh cũ (63 tỉnh) — phải dùng mã 34 tỉnh theo NQ 202/2025 | Hướng dẫn chung |
Coverage.period không hợp lệ |
Ngày hiệu lực BHYT phải theo format FHIR YYYY-MM-DD, không phải DD/MM/YYYY |
Liên thông hồ sơ BHYT |
| Build SUSHI thành công nhưng IG Publisher báo lỗi | Thường là terminologies không resolve — kiểm tra output/qa.html |
Hướng dẫn Validation |
Nếu lỗi không có trong bảng trên, xem Hướng dẫn Validation hoặc liên hệ [email protected].
| Tài nguyên | Liên kết |
|---|---|
| FHIR R4 Specification | hl7.org/fhir/R4/ |
| FSH School | fshschool.org |
| FHIR Validator | confluence.hl7.org |
| SUSHI Documentation | fshschool.org/docs/sushi/ |
| VN Core — Liên hệ | [email protected] |
| Hướng dẫn kiểm tra hợp lệ | validation-guidance.html |
| Tình huống lâm sàng | clinical-scenarios.html |
| Nếu cần | Nên đọc tiếp |
|---|---|
| Xác định nghĩa vụ tuân thủ theo vai trò (Producer/Consumer/Gateway) | Tuân thủ theo vai trò |
| Hiểu quy tắc nền chung về tên, địa chỉ, định danh và pattern datatype | Hướng dẫn chung |
| Tra cứu các NamingSystem và hệ thống định danh y tế Việt Nam | Danh mục định danh |
| Diễn giải Must Support và cẩm nang ánh xạ HIS → FHIR | Must Support |
| Nắm hành vi tìm kiếm của FHIR server | Tìm kiếm |
| Thiết kế kiểm tra hợp lệ 3 tầng cho resource | Validation |
| Triển khai liên thông hồ sơ BHYT với Cổng giám định BHXH | Liên thông BHYT |
This page is the procedural quickstart for VN Core. It covers prerequisites, local build, a first validation flow, and the next canonical pages to read before deeper implementation. Actor-specific conformance, package boundary, security baseline, and BHYT gateway guidance are documented separately.