במדריך הזה מוסבר איך להשתמש בתצוגות מאובטחות עם פרמטרים ב-AlloyDB Omni כדי להגביל את גישת המשתמשים לתצוגות עם פרמטרים באמצעות AlloyDB Omni Studio או psql.
הדוגמאות שמופיעות במאמר נועדו להמחיש את היכולות של תצוגות מאובטחות עם פרמטרים. הדוגמאות האלה מיועדות להמחשה בלבד.
מטרות
- יצירה של תצוגות מאובטחות עם פרמטרים בעלי שמות.
- יוצרים את תפקיד מסד הנתונים שבו האפליקציה משתמשת כדי להתחבר למסד הנתונים ולגשת לתצוגות מאובטחות עם פרמטרים.
- נותנים לתפקיד החדש הרשאות לתצוגות המאובטחות ומבטלים את הגישה לטבלאות הבסיס.
- מתחברים באמצעות התפקיד החדש ומוודאים שאי אפשר לגשת לטבלאות המוגבלות.
- מריצים שאילתות בתצוגה המאובטחת שמכילה פרמטרים באמצעות הפונקציה
execute_parameterized_query.
התקנה וחיבור למסד נתונים
- התקנה של AlloyDB Omni(ל-Kubernetes, לקונטיינרים).
- יצירת אשכול והמופע הראשי שלו.
- התחברות למופע (ל-Kubernetes, לקונטיינרים)
הכנת הסביבה
כדי להתכונן להרצת שאילתות בתצוגה מאובטחת עם פרמטרים, צריך קודם להגדיר תצוגות עם פרמטרים, את מסד הנתונים ואת התפקידים במסד הנתונים, את התוסף parameterized_view ואת סכימת האפליקציה.
לפני שמשתמשים בתצוגות מאובטחות עם פרמטרים, צריך לבצע את הפעולות הבאות פעם אחת בכל מאגר חדש של postgres. אפשר להחיל כל הגדרה באמצעות ALTER SYSTEM או לערוך ישירות את postgresql.conf.:
- מוסיפים את parameterized_views אל
shared_preload_libraries. - מגדירים את
parameterized_views.enabled=onכדי להפעיל את התכונה. - מפעילים מחדש את postgres כדי שהשינויים ייכנסו לתוקף.
הגדרת מסד הנתונים
- יוצרים מסד נתונים בשם
databaseלנתוני האפליקציה ולתצוגות עם פרמטרים. מידע נוסף זמין במאמר יצירת מסד נתונים.
יצירה של תפקידים במסד הנתונים, התוסף וסכימת האפליקציה
באמצעות psql, מתחברים למסד הנתונים בתור המשתמש
postgresאו בתור משתמש עם הרשאות סופר-משתמש ב-AlloyDB Omni.psql database -U postgresמידע נוסף זמין במאמר בנושא ניהול משתמשים במסד נתונים ב-AlloyDB Omni.
יוצרים את התוסף
parameterized_viewsבמסד הנתונים.-- Requires parameterized_views.enabled set to true CREATE EXTENSION parameterized_views;כשיוצרים את התוסף, המערכת יוצרת גם סכימה בשם
parameterized_viewsכדי שממשקי ה-API ייכללו במרחב השמות של הסכימה הזו, וכדי שממשקי ה-API האלה לא יתנגשו עם ממשקי API קיימים.יוצרים את תפקיד האדמין ב-AlloyDB Omni, שכולל בעלות על מסד הנתונים וניהול שלו.
CREATE ROLE admin_user WITH LOGIN PASSWORD '...'; GRANT ALL PRIVILEGES ON DATABASE database TO admin_user;מידע נוסף זמין במאמר
CREATE USER.יוצרים תפקיד חדש במסד הנתונים להרצת שאילתות מול תצוגות מאובטחות עם פרמטרים. זוהי הרשאה ב-AlloyDB Omni שהאפליקציה משתמשת בה כדי להתחבר למסד הנתונים ולהיכנס אליו כדי להריץ שאילתות עם גישה מוגבלת לפונקציות או לאובייקטים ציבוריים לסט המינימלי הנדרש.
מידע נוסף זמין במאמר
CREATE USER.מתחברים בתור משתמש עם הרשאת אדמין.
SET role TO admin_user;יוצרים את הסכימה שמכילה את הטבלאות.
CREATE SCHEMA schema;יוצרים את הטבלאות ומזינים נתונים.
CREATE TABLE schema.checked_items(bag_id INT,timestamp TIMESTAMP, loc_code CHAR(3), scan_type CHAR(1), location TEXT, customer_id INT); INSERT INTO schema.checked_items (bag_id, timestamp, loc_code, scan_type, location, customer_id) VALUES (101, '2023-10-26 10:00:00', 'ABC', 'I', 'Warehouse A', 123), (102, '2023-10-26 10:15:30', 'DEF', 'O', 'Loading Dock B', 456), (103, '2023-10-26 10:30:45', 'GHI', 'I', 'Conveyor Belt 1', 789), (104, '2023-10-26 11:00:00', 'JKL', 'O', 'Shipping Area C', 101), (105, '2023-10-26 11:45:15', 'MNO', 'I', 'Sorting Station D', 202), (106, '2023-10-26 12:00:00', 'PQR', 'O', 'Truck Bay E', 303);
יצירת תצוגות מאובטחות עם פרמטרים והגדרת הרשאות גישה
כדי ליצור תצוגות פרמטריות מאובטחות ולהגדיר הרשאות גישה מתאימות לטבלת הבסיס ולתצוגות, פועלים לפי השלבים הבאים:
באמצעות psql, מתחברים למסד הנתונים כ-
admin_user.psql database -U admin_userכדי לספק גישה מוגבלת לתצוגה, יוצרים תצוגה מאובטחת עם פרמטרים.
CREATE VIEW schema.secure_checked_items WITH (security_barrier) AS SELECT bag_id, timestamp, location FROM schema.checked_items t WHERE customer_id = $@app_end_userid;נותנים גישה לתצוגה.
GRANT SELECT ON schema.secure_checked_items TO psv_user;כדי לגשת לתצוגה, צריך לתת גישה לסכימה.
GRANT USAGE ON SCHEMA schema TO psv_user;ביטול גישה ישירה לטבלת הבסיס.
REVOKE ALL PRIVILEGES ON schema.checked_items FROM psv_user;
אימות אבטחת מידע
כדי לוודא שהתצוגות המאובטחות עם הפרמטרים מגבילות את הגישה לתצוגות המיועדות, מריצים את הפקודות הבאות בתור psv_user. זהו תפקיד במסד נתונים של AlloyDB Omni שהאפליקציה משתמשת בו כדי להתחבר למסד הנתונים ולהיכנס אליו כדי להריץ שאילתות.
התחברות כמשתמש בתצוגות מאובטחות עם פרמטרים.
psql database -U psv_userמוודאים שאי אפשר לגשת לטבלת הבסיס.
SELECT * FROM schema.checked_items; ERROR: permission denied for table checked_itemsאפשר לגשת לתצוגה מאובטחת עם פרמטרים באמצעות הפונקציה
execute_parameterized_query.SELECT * FROM parameterized_views.execute_parameterized_query( query => 'SELECT * from schema.secure_checked_items', param_names => ARRAY ['app_end_userid'], param_values => ARRAY ['303'] );כדי לשפר את האבטחה של שאילתות שנוצרו בשפה טבעית, אפשר לשלב את התצוגות המאובטחות עם פרמטרים באמצעות שפה טבעית.
הסרת המשאבים
כדי לנקות, אפשר להסיר את ההתקנה של מופע AlloyDB Omni או להשאיר את המופע ולמחוק את האובייקטים הבודדים.
המאמרים הבאים
- מידע נוסף על תצוגות מאובטחות עם פרמטרים
- כך מנהלים את אבטחת מידע של האפליקציה באמצעות תצוגות מאובטחות עם פרמטרים.