cancel
Showing results for 
Search instead for 
Did you mean: 

SQL Anywhere 16: service does not start when strong encryption is used

Former Member
4,415

The service has the "-ep" parameter but won't prompt for the encryption key and will not start. Error in Windows event log is "Missing database encryption"...duh: I expect it to prompt me!

Anybody can reproduce?

OS: Win 7 Pro 64 bits, 8Gb ram SQL Anywhere 16 dev edition

Accepted Solutions (0)

Answers (2)

Answers (2)

graeme_perrow
Advisor
Advisor

When running as a service, there is no way for the server to prompt for an encryption key. You will need to specify the -ek switch on the command line. If you want, you can specify the -ek switch in a file and use the @file syntax to pass it to the server. You can encrypt/obfuscate this file with dbfhide if you want.

johnsmirnios
Participant

I would amend Graeme's response to say that if you want the file 'encrypted', use dbfhide -w or dbfhide -wm. Otherwise, the file is just obfuscated.

http://dcx.sybase.com/index.html#sa160/en/dbadmin/file-hiding-utility-syntax.html*d5e56897

VolkerBarth
Contributor
0 Kudos

FWIW, that exactly made my add "/obfuscate" in Graeme's answer at the same time...

FWIW2, one might even state that dbfhide -w/-wm uses strong encryption, however, AFAIK with a OS-supplied key... (it's using the DPAPI, right?)

johnsmirnios
Participant

Services cannot prompt: Windows isolates all services so that they cannot access the desktop.

Former Member
0 Kudos

That is not what the documentation states: "the database server is either not a Windows service, or it is a Windows service with the interact with desktop option turned ON" is a condition for the -ep and this is my case (desktop interaction is ON)

VolkerBarth
Contributor
0 Kudos

AFAIK, this depends on the OS version (older Windows versions surely allow services to interact with the desktop - Windoes 7 does not) - so the cited statement should be refined...

johnsmirnios
Participant

The services isolation (aka session 0 isolation) was added by Microsoft in Windows Vista and exists for security reasons (ie, no user-level code running on the desktop can have a security attack vector into a system service via a GUI presented by that service). Also, Microsoft recommends (and requires for Windows Certification fwiw) that services never present GUI elements and warns that "interact with desktop" will likely be removed in a future version of the OS.

It looks like the -ep portion of the doc didn't get updated. I will add a note on DCX.