Re: [PATCH] Fix leaky VIEWs for RLS - Mailing list pgsql-hackers
| From | KaiGai Kohei | 
|---|---|
| Subject | Re: [PATCH] Fix leaky VIEWs for RLS | 
| Date | |
| Msg-id | 4C0D8A76.4000206@ak.jp.nec.com Whole thread Raw | 
| In response to | Re: [PATCH] Fix leaky VIEWs for RLS (Heikki Linnakangas <heikki.linnakangas@enterprisedb.com>) | 
| Responses | Re: [PATCH] Fix leaky VIEWs for RLS | 
| List | pgsql-hackers | 
(2010/06/07 20:53), Heikki Linnakangas wrote: > On 07/06/10 14:06, Stephen Frost wrote: >> * Heikki Linnakangas (heikki.linnakangas@enterprisedb.com) wrote: >>> The big difference is what information can be obtained, not how fast it >>> can be obtained. >> >> Actually, I disagree. Time required to acquire the data does matter. > > Depends on the magnitude, of course. If it takes 1 year per row, that's > probably acceptable. If it takes 1 second, that's extremely slow > compared to normal queries, but most likely still disastreous from a > security point of view. > FYI, the classic also mentioned about bandwidth of covert channel, although it was already obsoleted. See the page.80 of: http://csrc.nist.gov/publications/history/dod85.pdf It said 1bit/sec are acceptable on DoD in 25 years ago. >>> Imagine a table that holds username/passwords for users. Each user is >>> allowed to see his own row, including password, but not anyone else's. >>> EXPLAIN side-channel might give pretty accurate information of how many >>> rows there is in the table, and via clever EXPLAIN+statistics probing >>> you might be able to find out what the top-10 passwords are, for >>> example. But if you wanted to know what your neighbor's password is, the >>> side-channels would not help you much, but an error message would reveal >>> it easily. >> >> Using only built-ins, could you elaborate on how one could pick exactly >> what row was revealed using an error case? That strikes me as >> difficult, but perhaps I'm not thinking creatively enough. > > WHERE should do it: > > SELECT * FROM secrets_view WHERE username = 'neighbor' AND > password::integer = 1234; > ERROR: invalid input syntax for integer: "neighborssecretpassword" > > Assuming that username = 'neighbor' is evaluated before the cast. > In this case, is it unnecessary to expose the given argument in the error message (from security perspective), isn't it? Because it is basically matter of the integer input handler, it seems to me what we should fix up is int4in(), not optimizer. Perhaps, we should categorize the issued functionalities base on the level of its threat when abused. * High-threat Functions have side-effect that allows to move the given arguments into another tables or other high-bandwidth chennel. E.g) lowrite(), pg_write_file() -> It should be fixed soon. * Middle-threat Functions have side-effect that allows to move the given arguments using error messages or other low-bandwidth channel. E.g) int4in() -> It should be fixed in long term. * Row-threat Functions can imply existence of invisible tuples, but it does not expose the value itself. E.g) EXPLAIN statement, PK/FK constraints -> It should not be fixed in PostgreSQL. Now we allow all of them. But isn't it valuable to fix the high-threat first? Then, we can revise error messages in built-in functions, I think. Thanks, -- KaiGai Kohei <kaigai@ak.jp.nec.com>
pgsql-hackers by date: