-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' of https://github.com/philongbuile/SONA-healthcar…
…e-data-management into main
- Loading branch information
Showing
6 changed files
with
90 additions
and
187 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
test-nework: | ||
cd fabric && ./startFabric.sh typescript | ||
|
||
apiserver: | ||
cd sona/apiserver && npm install && ts-node apiserver.js | ||
|
||
install: | ||
cd fe && npm install | ||
|
||
run: | ||
cd fe && npm start |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,191 +1,88 @@ | ||
# Sona Healthcare System | ||
|
||
> SONA is an application system for Electric Healthcare Record (EHR) Management with permissioned blockchain support. We apply Hyperledger Fabric to complete our solution in blockchain. With that being said, it can become more secure, lightweight and convenient for data access, management, and security. | ||
> SONA (**S**tuttgart **O**nline **N**etwork he**A**lthcare) is an application for Electric Healthcare Store (EHR) with blockchain support. We apply Hyperledger Fabric to complete our solution in blockchain. With that being said, it can become more secure, lightweight and convenient for data access, management, and security. | ||
> | ||
## Our team | ||
|
||
- Bui Le Phi Long (team leader) | ||
- Bui Le Phi Long: (team lead) | ||
- Truong Canh Thanh Vinh (dev) | ||
- Huynh Cam Tu (dev) | ||
- Nguyen Quoc Trung (dev, UI/UX designer) | ||
- Le Duc Minh (dev) | ||
- Instructor: Prof. Martin Kapples | ||
|
||
## Architecture and Design | ||
|
||
## Setup | ||
|
||
# bring up test network with sona chaincode | ||
- cd into fabric/ | ||
- run ./startFabric.sh typescript | ||
|
||
# run apiserver to connect to fabric network | ||
- cd into sona/apiserver | ||
- run npm install | ||
- run apiserver.ts | ||
|
||
# initledger to initialize data for sona network | ||
- cd into sona/apiserver/src | ||
# install dependencies | ||
- run npm install | ||
# enroll admin | ||
- run enrollAdmin.ts | ||
# register user | ||
- open file registerUser.ts, change the content of userID variable to the userID you want to register | ||
- run registerUser.ts | ||
# initialize data | ||
- run invoke.ts | ||
|
||
|
||
|
||
|
||
## Routes: | ||
- POST /patient/create/ | ||
req.body: fullname, username, address, phone, dob, gender, authorized_doctor | ||
[Doctor] | ||
|
||
|
||
- GET /patient/query/:username | ||
patient = { | ||
docType: 'patient', | ||
FullName: fullname, | ||
Username: username, | ||
Phone: phone, | ||
Address: address, | ||
DoB: dob, | ||
Gender: gender, | ||
MedicalInfo: medinfo_id, | ||
AuthorizedDoctors: [operator_username] | ||
}; | ||
[Patient] | ||
|
||
- get /patient/doctorQuery/:patient_username/:doctor_username | ||
patient = { | ||
docType: 'patient', | ||
FullName: fullname, | ||
Username: username, | ||
Phone: phone, | ||
Address: address, | ||
DoB: dob, | ||
Gender: gender, | ||
MedicalInfo: medinfo_id, | ||
AuthorizedDoctors: [operator_username] | ||
}; | ||
[Doctor] | ||
|
||
- GET /patient/authorize_doctor/:patient_username/:operator_username | ||
patient = { | ||
docType: 'patient', | ||
FullName: fullname, | ||
Username: username, | ||
Phone: phone, | ||
Address: address, | ||
DoB: dob, | ||
Gender: gender, | ||
MedicalInfo: medinfo_id, | ||
AuthorizedDoctors: [operator_username] | ||
} | ||
[Patient] | ||
|
||
- GET /patient/revoke_doctor/:patient_username/:operator_username | ||
[Patient] | ||
|
||
- GET/operator/query/:username | ||
operator = { | ||
docType: 'operator', | ||
Username: username, | ||
Role: role | ||
} | ||
[User] | ||
- POST /operator/create/ | ||
req.body: username, role | ||
[Admin] -> create doctor or researcher | ||
|
||
- GET /record/query/:medinfo_id | ||
- return array of usage-records of that medinfo_id | ||
[ | ||
{ | ||
Case_ID: 'case2', | ||
MedicalInfo_ID: 'medical1', | ||
Record_ID: 'record', | ||
Operation: 'read', | ||
Roles: 'doctor', | ||
OperatorName: 'Doctor1', | ||
Time : '22/03/2010' | ||
}, | ||
{ | ||
Case_ID: 'case1', | ||
MedicalInfo_ID: 'medical1', | ||
Record_ID: 'record1', | ||
Operation: 'read', | ||
Roles: 'doctor', | ||
OperatorName: 'Doctor1', | ||
Time: '22/03/2010' | ||
}, | ||
] | ||
|
||
[Patient], [Researcher] | ||
|
||
|
||
- GET medinfo/operator_query_medicalinfo/:medicalinfo_id/:operator_username | ||
- return 1 medicalinfo object | ||
|
||
{ | ||
ID: 'medical1', | ||
Cases: [ | ||
{ | ||
Case_ID: 'case1', | ||
Examinations: [ | ||
{ | ||
TestResult : 'Success', | ||
Diagnosis: 'Allergic Rhinitis', | ||
Treatment: 'Use medicine' | ||
|
||
} | ||
]}] | ||
}, | ||
[Patient], [Doctor], [Researcher] -> get medical info by id | ||
|
||
- GET /medinfo/patient_query_medicalinfo/:medicalinfo_id/ | ||
- return 1 medicalinfo object | ||
{ | ||
ID: 'medical1', | ||
Cases: [ | ||
{ | ||
Case_ID: 'case1', | ||
Examinations: [ | ||
{ | ||
TestResult : 'Success', | ||
Diagnosis: 'Allergic Rhinitis', | ||
Treatment: 'Use medicine' | ||
|
||
} | ||
]}] | ||
}, | ||
[Patient] -> get medical info by id | ||
|
||
- POST /medinfo/query_by_keyword/ | ||
- req.body.keywords = ['keyword1', 'keyword2'] | ||
- return array of medicalinfo's containing the keywords | ||
[Researcher] | ||
|
||
- POST /medinfo/addcase/ | ||
req.body.info_id, | ||
req.body.test_result, | ||
req.body.diagnosis, | ||
req.body.treatment, | ||
req.body.operator_username, | ||
req.body.patient_username, | ||
|
||
[Doctor] [Researcher] | ||
|
||
- POST /medinfo/appendcase/ | ||
req.body.info_id, | ||
req.body.case_id, | ||
req.body.test_result, | ||
req.body.diagnosis, | ||
req.body.treatment, | ||
req.body.operator_username, | ||
req.body.patient_username, | ||
|
||
[Doctor] [Researcher] | ||
## Tech specs | ||
|
||
- Backend: Mongo + Typescript + Express | ||
- Blockchain: Hyperledger Fabric + CouchDB + Typescript | ||
- Frontend: ReactJS + Redux + Typescript + TailwindCSS | ||
|
||
## Documentation | ||
|
||
- Full report: | ||
- API Docs: | ||
|
||
## Sona Test Network | ||
|
||
The first most important part of this project is the blockchain network. The test network is being introduced in Fabric v2.0 as the long term replacement for the `first-network`sample. By ultilizing and customising the network for our application, we make a startFabric script in order for you to feel free to test the network within one command line. | ||
|
||
Before you can start the test network, you need to follow the instructions to [Install the Samples, Binaries and Docker Images](https://hyperledger-fabric.readthedocs.io/en/latest/install.html) in the Hyperledger Fabric documentation. Because the “bin” folder can be different for mac user / window user / linux user. | ||
|
||
## Running on your local machine | ||
|
||
In fact, our application provide you full support of the docker images and all you need is to set up bin file depend on your operating system first (this can be optional), | ||
|
||
```bash | ||
// read the full version in | ||
// https://hyperledger-fabric.readthedocs.io/en/release-2.5/install.html | ||
./install-fabric.sh --fabric-version 2.2.1 binary | ||
``` | ||
|
||
then run to bring up the test network: | ||
|
||
```makefile | ||
make test-network | ||
``` | ||
|
||
then run API server of the blockchain | ||
|
||
```makefile | ||
make apiserver | ||
``` | ||
|
||
Then you can access to the backend now on [https://locahost:8080](https://locahost:8080) | ||
|
||
and finally, install and run the frontend, in cas you need to see the full version of the application | ||
|
||
```makefile | ||
make install | ||
make localrun | ||
``` | ||
|
||
Now it’s online on [https://locahost:3000](https://locahost:3000) | ||
|
||
## Running without network needed (if you don’t want to care about the network) | ||
|
||
However, the network now is hosted on our virtual machine in digital ocean. Therefore, the good news is no need to care about the network. Just simply run the frontend, and it will automatically work like magic. | ||
|
||
```makefile | ||
make install | ||
make run | ||
``` | ||
|
||
# 📚 Contribution | ||
|
||
The main purpose of this repository is to continue evolving our project not only in university but also in the industry, making it faster and easier to use. We are always grateful to the community for contributing bugfixes and improvements. | ||
|
||
## Contribution Guide | ||
|
||
1. Fork the repo. | ||
2. Clone the repo. | ||
3. Fix bugs, add function, test on your local machine. | ||
4. Create a new branch and open a pull request to us. | ||
5. You can also create a thread, so that we can discuss more about the repo. | ||
|
||
## Thank You! | ||
|
||
Thank you to all people who have dedicated their time and talent to contribute to this project! |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters