| This is the legacy 4D documentation web site. Documentations are progressively being moved to developer.4d.com | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|  | 
    4D v20.6
 Encrypt data file 
         | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Encrypt data file ( structurePath ; dataPath {; newPassPhrase | newDataKey {; archiveFolder {; curPassPhrase | curDataKey {; methodName}}}} ) -> Function result | ||||||||
| Parameter | Type | Description | ||||||
| structurePath | Text |   | Pathname of structure file | |||||
| dataPath | Text |   | Pathname of data file to encrypt | |||||
| newPassPhrase | newDataKey | Text, Object |   | In case of replacement: new passPhrase (text) or new encryption key (object) | |||||
| archiveFolder | Text |   | Pathname of folder where original files will be stored | |||||
| curPassPhrase | curDataKey | Text, Object |   | Current passPhrase (text) or current encryption key (object) | |||||
| methodName | Text |   | Name of 4D callback method | |||||
| Function result | Text |   | Full pathname of folder where original files have been stored | |||||
The Encrypt data file command is used to encrypt or re-encrypt the data file designated by the dataPath parameter associated to the structurePath parameter. It can also be used to remove encryption from the database. The command does not modify the original files, it returns the full path name of the folder created to backup the original data file.
Notes:
Executing this command will encrypt or modify the encryption of all tables of the database that have been set as "encryptable". For more information, please refer to the Encryptable section.
Warning: Encrypting a database is a lengthy operation. It displays a progress indicator (which could be interrupted by the user). Note also that database encryption sequence includes a compacting step.
In the structurePath parameter, you can pass an empty string or the full pathname of the structure file associated with the data file that you want to encrypt. This information is needed for the encrypting procedure. If you pass an empty string, a standard Open file dialog appears so that the user can designate the structure file to be used. Otherwise, you can pass a full pathname, expressed in the syntax of the operating system.
In the dataPath parameter, you can pass an empty string, a file name, or a full pathname (must expressed in the syntax of the operating system). If you pass an empty string, a standard Open file dialog appears so that the user can designate the data file to be encrypted. This file must correspond to the structure file defined in the structurePath parameter. If you only pass the name of the data file, 4D will look for it at the same level as the structure file.
The command does not modifiy the original files. They are moved in the archiveFolder folder (if passed) into a special folder named Replaced files (Encrypting) YYYY-MM-DD HH-MM-SS or Replaced files (Decrypting) YYYY-MM-DD HH-MM-SS where YYYY-MM-DD HH-MM-SS represents the date and time of the operation. For example: "Replaced files (Encrypting) 2018-09-29 13-00-35". New encrypted or decrypted data file automatically replaces the original file. 
If you passed "" in archiveFolder, a standard Open folder dialog will appear so that the user can specify the location of the folder to be created. If archiveFolder is omitted, the original files are automatically stored in a timestamped folder created next to the structure file.
The method parameter is used to set a callback method that will be called regularly during the encryption process. If you pass an empty string or an invalid method name, this parameter is ignored (no method is called). When it is called, this method receives up to 5 parameters depending on the event type originating the call (see below). It is imperative to declare these parameters in the method:
| Event | $1 (Longint) | $2 (Longint) | $3 (Text) | $4 (Longint) | $5 (Longint) | 
| Message | 1 | 0 | Progress message (e.g. "Encrypting BLOBs in table Documents") | Percentage done (e.g. 50) | Reserved | 
| Encryption finished | 2 | 0 | OK message (e.g. "Done") | 0 | Reserved | 
| Error | 3 | 0 | Error message (e.g. "Problem on the XX data table: Encryption key has not been provided") | 0 | Reserved | 
| End of execution | 4 | 0 | "Done" | 0 | Reserved | 
| Warning(*) | 5 | Object type | Text of error | Table or index number | Reserved | 
(*) Warning returned at the verification step (see VERIFY DATA FILE command).
Returned value
Actual path of the destination folder of the original files.
Encrypt a data file for the first time:
 C_TEXT($folder;$passphrase)
 $passphrase:=Request("Enter the passphrase")
 If(OK=1)
  //Because the data file is not encrypted, no current encryption key is provided
    $folder:=Encrypt data file(Structure file;"myData.4DD";$passphrase)
 End ifRe-encrypt an encrypted data file (change the passphrase):
 C_TEXT($folder;$targetFolder;$passphrase;$newPassphrase)
 $passphrase:=Request("Enter the current passphrase")
 If(OK=1)
    $newPassphrase:=Request("Enter the new passphrase")
    If(OK=1)
       $targetFolder:=Get 4D folder(Database folder)+"Save"+Folder separator
  //As the data file is encrypted, the current encryption key must be provided
       $folder:=Encrypt data file(Structure file;"myData.4DD";$newPassphrase;$targetFolder;$passphrase)
    End if
 End ifRemove encryption from an encrypted data file:
 C_TEXT($folder;$targetFolder;$passphrase)
 $passphrase:=Request("Enter the passphrase")
 If(OK=1)
    $targetFolder:=Get 4D folder(Database folder)+"DecryptedData"+Folder separator
  //The new passphrase is set to an empty string to decrypt all data
  //The current passphrase must be provided
    $folder:=Encrypt data file(Structure file;"myData.4DD";"";$targetFolder;$passphrase)
 End ifRe-encrypt an encrypted data file with the current key (for example, when the encryptable status has been changed for some tables).
 C_TEXT($folder;$passPhrase)
 C_BOOLEAN($added)
 
 $passphrase:=Request("Enter the passphrase")
 If(OK=1)
    $added:=Register data key($passphrase) //The data key is now in the 4D keychain
    $folder:=Encrypt data file(Structure file;"myData.4DD")
 End if
									4D Blog - New 4D commands to work with encrypted data
									
									Data file encryption status
									
									Decrypt data BLOB
									
									Encrypt data BLOB
									
									New data key
									
	Product:  4D
	Theme:  Data Security
	Number:  
        1610
        
        
        
	
	Created:  4D v17 R5
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	4D Language Reference ( 4D v20)
	
	
	4D Language Reference ( 4D v20.1)
	
	
	
	4D Language Reference ( 4D v20.2)
	
	4D Language Reference ( 4D v20.3)
	
	4D Language Reference ( 4D v20.4)
	
	
	4D Language Reference ( 4D v20.5)
	4D Language Reference ( 4D v20.6)
	
	
	
 Add a comment
Add a comment