| 1 | VAQHSH ;ALB/JRP - ENCRYPT A DISPLAY ARRAY;29-MAR-93 | 
|---|
| 2 | ;;1.5;PATIENT DATA EXCHANGE;;NOV 17, 1993 | 
|---|
| 3 | ENCDSP(TRAN,ROOT,ENCPTR,DSPOFF,DSPCNT) ;ENCRYPT A DISPLAY | 
|---|
| 4 | ;INPUT  : TRAN - Pointer to VAQ - TRANSACTION file | 
|---|
| 5 | ;         ROOT - Where the Display Array is (full global reference) | 
|---|
| 6 | ;         ENCPTR - Pointer to VAQ - ENCRYPTION METHOD file | 
|---|
| 7 | ;         DSPOFF - Offset into Display Array to begin at | 
|---|
| 8 | ;                  Only used for Display Arrays (defaults to 0) | 
|---|
| 9 | ;         DSPCNT - Number of lines in Display Array | 
|---|
| 10 | ;                  Only used for Display Arrays (defaults to full array) | 
|---|
| 11 | ;OUTPUT : 0 - Success | 
|---|
| 12 | ;        -1^Error_Text - Error | 
|---|
| 13 | ;NOTES  : If TRAN>0 | 
|---|
| 14 | ;           Encryption will be based on the transaction | 
|---|
| 15 | ;           Keys will come from the transaction | 
|---|
| 16 | ;         Else | 
|---|
| 17 | ;           Encryption will be based on ENCPTR | 
|---|
| 18 | ;           Keys based on current user | 
|---|
| 19 | ;       : Existance of TRAN takes precedence over ENCPTR | 
|---|
| 20 | ; | 
|---|
| 21 | ;CHECK INPUT | 
|---|
| 22 | S TRAN=+$G(TRAN) | 
|---|
| 23 | S ENCPTR=+$G(ENCPTR) | 
|---|
| 24 | Q:(('TRAN)&('ENCPTR)) "-1^Did not pass pointer to transaction or encryption method" | 
|---|
| 25 | I (TRAN) Q:('$D(^VAT(394.61,TRAN))) "-1^Did not pass valid pointer to VAQ - TRANSACTION file" | 
|---|
| 26 | I (TRAN) S ENCPTR=$$TRANENC^VAQUTL3(TRAN,1) Q:('ENCPTR) "-1^Transaction did not contain pointer to encryption method" | 
|---|
| 27 | Q:('ENCPTR) "-1^Did not pass encryption method" | 
|---|
| 28 | Q:($G(ROOT)="") "-1^Did not pass location of extracted segment" | 
|---|
| 29 | S DSPOFF=+$G(DSPOFF) | 
|---|
| 30 | S DSPCNT=+$G(DSPCNT) | 
|---|
| 31 | ;DECLARE VARIABLES | 
|---|
| 32 | N TMP,ENCMTHD,ENCSTR,STRING,KEY1,KEY2,ERROR,SEQ,SENDER | 
|---|
| 33 | S ERROR=0 | 
|---|
| 34 | ;GET ENCRYPTION METHOD | 
|---|
| 35 | S TMP=$$ENCMTHD^VAQUTL2(ENCPTR,0) | 
|---|
| 36 | Q:(TMP="") "-1^Could not determine encryption method" | 
|---|
| 37 | S ENCMTHD="S ENCSTR="_TMP | 
|---|
| 38 | ;DETERMINE PRIMARY KEY | 
|---|
| 39 | I (TRAN) S SENDER=$$SENDER^VAQCON2(TRAN) Q:($P(SENDER,"^",1)="-1") "-1^Could not determine encryption keys" | 
|---|
| 40 | S:(TRAN) SENDER=$P(SENDER,"^",1) | 
|---|
| 41 | S:(TRAN) KEY1=$$NAMEKEY^VAQUTL3(SENDER,1) | 
|---|
| 42 | S:('TRAN) KEY1=$$DUZKEY^VAQUTL3($G(DUZ),1) | 
|---|
| 43 | ;DETERMINE SECONDARY KEY | 
|---|
| 44 | S:(TRAN) KEY2=$$NAMEKEY^VAQUTL3(SENDER,0) | 
|---|
| 45 | S:('TRAN) KEY2=$$DUZKEY^VAQUTL3($G(DUZ),0) | 
|---|
| 46 | Q:((KEY1="")!(KEY2="")) "-1^Could not determine encryption keys" | 
|---|
| 47 | ;LOOP THROUGH EACH LINE IN DISPLAY | 
|---|
| 48 | S TMP=DSPOFF-.999999999 | 
|---|
| 49 | F SEQ=1:1 Q:((DSPCNT)&(SEQ>DSPCNT))  D  Q:((TMP="")!(ERROR)) | 
|---|
| 50 | .S TMP=$O(@ROOT@("DISPLAY",TMP)) | 
|---|
| 51 | .Q:(TMP="") | 
|---|
| 52 | .;GET LINE | 
|---|
| 53 | .S STRING=@ROOT@("DISPLAY",TMP,0) | 
|---|
| 54 | .;ENCRYPT LINE (DON'T ENCRYPT A NULL LINE) | 
|---|
| 55 | .Q:(STRING="") | 
|---|
| 56 | .X ENCMTHD | 
|---|
| 57 | .I (ENCSTR="") S ERROR="-1^Error using encryption method" Q | 
|---|
| 58 | .;STORE ENCRYPTED LINE | 
|---|
| 59 | .S @ROOT@("DISPLAY",TMP,0)=ENCSTR | 
|---|
| 60 | Q:(ERROR) ERROR | 
|---|
| 61 | Q 0 | 
|---|