Jamie Rumbelow
Jamie Rumbelow

Reputation: 5095

Best authentication solution for RESTful Database Server

I'm writing a RESTful Database Server called Phoenix. Being an easy interface into an entire application's data, security is quite an important issue, and I'm interested in what authentication solutions any of you could suggest.

It needs to be:

I'd love to hear your suggestions - thank you!

Jamie

Upvotes: 1

Views: 382

Answers (2)

ZZ Coder
ZZ Coder

Reputation: 75496

I have a similar server. I choose to use OAuth signing for its simplicity,

http://oauth.net/core/1.0#signing_process

We don't enforce the nonce, just limit the timestamp to a short window (30 seconds) to thwart replay.

The OAuth library is available on many platforms so you don't have to write much code to implement it. Don't know why you think OAuth is not implementable.

For each client allowed to access the data, it's assigned a consumer_key and a consumer_secret. All the requests are signed with consumer_secret so only client knowing the secret can get access.

We also considered other options. HTTTP Basic Auth over SSL is too expensive. HTTP Digest Auth is too slow because it needs to wait for a challenge.

Upvotes: 0

Karl Anderson
Karl Anderson

Reputation: 1798

Not much information here about what your security or implementation needs are. The quick answers are Basic or Digest over SSL, or signed requests. Are there reasons not to use these?

Signing requests typically adds a timestamp and/or a nonce, so any request can be authenticated. See the Amazon AWS authentication documentation for a description and libraries.

Upvotes: 1

Related Questions