คู่มืออ้างอิงนี้ครอบคลุมไวยากรณ์ Common Expression Language (CEL) ที่เกี่ยวข้องกับ
การสร้างนิพจน์สำหรับคำสั่ง @auth(expr:)
และ @check(expr:)
ดูข้อมูลอ้างอิงทั้งหมดสำหรับ CEL ได้ใน ข้อกำหนด CEL
ส่งตัวแปรทดสอบในคําค้นหาและการกลายพันธุ์
@auth(expr)
ไวยากรณ์ช่วยให้คุณเข้าถึงและทดสอบตัวแปรจากคําค้นหาและการเปลี่ยนแปลงได้
เช่น คุณสามารถรวมตัวแปรการดำเนินการ เช่น $status
โดยใช้
vars.status
mutation Update($id: UUID!, $status: Any) @auth(expr: "has(vars.status)")
ข้อมูลที่ใช้ได้กับนิพจน์: คำขอ การตอบกลับ this
คุณใช้ข้อมูลเพื่อ
- การประเมินด้วยนิพจน์ CEL ในคำสั่ง
@auth(expr:)
และ@check(expr:)
- การกำหนดค่าโดยใช้นิพจน์เซิร์ฟเวอร์
<field>_expr
ทั้งนิพจน์ CEL @auth(expr:)
และ @check(expr:)
สามารถประเมินรายการต่อไปนี้ได้
request.operationName
vars
(ชื่อแทนสำหรับrequest.variables
)auth
(ชื่อแทนสำหรับrequest.auth
)
ในการเปลี่ยนแปลง คุณสามารถเข้าถึงและกำหนดเนื้อหาของรายการต่อไปนี้ได้
response
(เพื่อตรวจสอบผลลัพธ์บางส่วนในตรรกะแบบหลายขั้นตอน)
นอกจากนี้ นิพจน์ @check(expr:)
ยังประเมินค่าต่อไปนี้ได้ด้วย
this
(ค่าของฟิลด์ปัจจุบัน)response
(เพื่อตรวจสอบผลลัพธ์บางส่วนในตรรกะแบบหลายขั้นตอน)
การเชื่อมโยง request.operationName
request.operarationName
binding stores the type of operation, either query
or mutation.
การเชื่อมโยง vars
(request.vars)
vars
การเชื่อมโยงช่วยให้นิพจน์เข้าถึงตัวแปรทั้งหมด
ที่ส่งในการค้นหาหรือการเปลี่ยนแปลงได้
คุณใช้ vars.<variablename>
ในนิพจน์เป็นชื่อแทนสำหรับ request.variables.<variablename>
ที่มีคุณสมบัติครบถ้วนได้
# The following are equivalent
mutation StringType($v: String!) @auth(expr: "vars.v == 'hello'")
mutation StringType($v: String!) @auth(expr: "request.variables.v == 'hello'")
การเชื่อมโยง auth
(request.auth)
Authentication ระบุผู้ใช้ที่ขอสิทธิ์เข้าถึงข้อมูลของคุณและให้ข้อมูลดังกล่าวเป็นข้อผูกมัดที่คุณสามารถสร้างต่อในนิพจน์ได้
ในตัวกรองและนิพจน์ คุณสามารถใช้ auth
เป็นชื่อแทนของ
request.auth
ได้
การเชื่อมโยงการให้สิทธิ์มีข้อมูลต่อไปนี้
uid
: รหัสผู้ใช้ที่ไม่ซ้ำกันซึ่งกำหนดให้กับผู้ใช้ที่ส่งคำขอtoken
: แผนที่ของค่าที่รวบรวมโดย Authentication
ดูรายละเอียดเพิ่มเติมเกี่ยวกับเนื้อหาของ auth.token
ได้ที่
ข้อมูลในโทเค็นการให้สิทธิ์
การเชื่อมโยง response
response
Binding มีข้อมูลที่เซิร์ฟเวอร์รวบรวมเพื่อตอบสนองต่อการค้นหาหรือการเปลี่ยนแปลง ขณะที่รวบรวมข้อมูล
เมื่อการดำเนินการดำเนินไปและแต่ละขั้นตอนเสร็จสมบูรณ์แล้ว
response
จะมีข้อมูลการตอบกลับจากขั้นตอนที่เสร็จสมบูรณ์แล้ว
response
การเชื่อมโยงมีโครงสร้างตามรูปร่างของ
การดำเนินการที่เชื่อมโยง รวมถึงฟิลด์แบบซ้อน (หลายรายการ) และคิวรีแบบฝัง (หากมี)
โปรดทราบว่าเมื่อเข้าถึงข้อมูลการตอบกลับการค้นหาที่ฝัง ฟิลด์อาจมี
ข้อมูลประเภทใดก็ได้ ทั้งนี้ขึ้นอยู่กับข้อมูลที่ขอในการค้นหาที่ฝัง เมื่อคุณ
เข้าถึงข้อมูลที่ฟิลด์การเปลี่ยนแปลง เช่น _insert
และ _delete
แสดงผล ฟิลด์ดังกล่าวอาจ
มีคีย์ UUID, จำนวนการลบ, ค่า Null (ดูข้อมูลอ้างอิงการเปลี่ยนแปลง)
เช่น
- ในการเปลี่ยนแปลงที่มีการฝังการค้นหา
response
การเชื่อมโยงจะมีข้อมูลการค้นหาที่response.query.<fieldName>.<fieldName>....
ใน กรณีนี้คือresponse.query.todoList
และresponse.query.todoList.priority
mutation CheckTodoPriority(
$uniqueListName: String!
) {
# This query is identified as `response.query`
query @check(expr: "response.query.todoList.priority == 'high'", message: "This list is not for high priority items!") {
# This field is identified as `response.query.todoList`
todoList(where: { name: $uniqueListName }) {
# This field is identified as `response.query.todoList.priority`
priority
}
}
}
- ในการเปลี่ยนแปลงหลายขั้นตอน เช่น มีฟิลด์
_insert
หลายรายการresponse
การเชื่อมโยงจะมีข้อมูลบางส่วนที่response.<fieldName>.<fieldName>....
ในกรณีนี้คือresponse.todoList_insert.id
mutation CreateTodoListWithFirstItem(
$listName: String!,
$itemContent: String!
) @transaction {
# Step 1
todoList_insert(data: {
id_expr: "uuidV4()",
name: $listName,
})
# Step 2:
todo_insert(data: {
listId_expr: "response.todoList_insert.id" # <-- Grab the newly generated ID from the partial response so far.
content: $itemContent,
})
}
การเชื่อมโยง this
การเชื่อมโยง this
จะประเมินเป็นฟิลด์ที่แนบคำสั่ง @check
ไว้ ในกรณีพื้นฐาน คุณอาจประเมินผลลัพธ์ของคำค้นหาที่มีค่าเดียว
mutation UpdateMovieTitle (
$movieId: UUID!,
$newTitle: String!)
@auth(level: USER)
@transaction {
# Step 1: Query and check
query @redact {
moviePermission( # Look up a join table called MoviePermission with a compound key.
key: {movieId: $movieId, userId_expr: "auth.uid"}
) {
# Check if the user has the editor role for the movie. `this` is the string value of `role`.
# If the parent moviePermission is null, the @check will also fail automatically.
role @check(expr: "this == 'editor'", message: "You must be an editor of this movie to update title")
}
}
# Step 2: Act
movie_update(id: $movieId, data: {
title: $newTitle
})
}
หากฟิลด์ที่แสดงผลเกิดขึ้นหลายครั้งเนื่องจากบรรพบุรุษเป็นลิสต์ ระบบจะทดสอบแต่ละ
อินสแตนซ์ด้วย this
ที่เชื่อมโยงกับแต่ละค่า
สำหรับเส้นทางใดๆ หากบรรพบุรุษเป็น null
หรือ []
ระบบจะไม่เข้าถึงฟิลด์และจะข้ามการประเมิน CEL สำหรับเส้นทางนั้น กล่าวคือ
การประเมินจะเกิดขึ้นเมื่อ this
เป็น null
หรือไม่ใช่ null
เท่านั้น แต่จะไม่เกิดขึ้นเมื่อเป็น undefined
เมื่อฟิลด์เป็นลิสต์หรือออบเจ็กต์ this
จะมีโครงสร้างเดียวกัน
(รวมถึงออบเจ็กต์ย่อยทั้งหมดที่เลือกในกรณีที่เป็นออบเจ็กต์) ดังตัวอย่างต่อไปนี้
mutation UpdateMovieTitle2($movieId: UUID!, $newTitle: String!) @auth(level: USER) @transaction {
# Step 1: Query and check
query {
moviePermissions( # Now we query for a list of all matching MoviePermissions.
where: {movieId: {eq: $movieId}, userId: {eq_expr: "auth.uid"}}
# This time we execute the @check on the list, so `this` is the list of objects.
# We can use the `.exists` macro to check if there is at least one matching entry.
) @check(expr: "this.exists(p, p.role == 'editor')", message: "You must be an editor of this movie to update title") {
role
}
}
# Step 2: Act
movie_update(id: $movieId, data: {
title: $newTitle
})
}
ไวยากรณ์นิพจน์ที่ซับซ้อน
คุณเขียนนิพจน์ที่ซับซ้อนมากขึ้นได้โดยใช้ร่วมกับโอเปอเรเตอร์ &&
และ ||
mutation UpsertUser($username: String!) @auth(expr: "(auth != null) && (vars.username == 'joe')")
ส่วนต่อไปนี้จะอธิบายโอเปอเรเตอร์ทั้งหมดที่ใช้ได้
โอเปอเรเตอร์และลำดับความสำคัญของโอเปอเรเตอร์
ใช้ตารางต่อไปนี้เป็นข้อมูลอ้างอิงสำหรับตัวดำเนินการและลำดับความสำคัญที่เกี่ยวข้อง
กำหนดนิพจน์ที่กำหนดเอง a
และ b
, ฟิลด์ f
และดัชนี i
โอเปอเรเตอร์ | คำอธิบาย | การเปลี่ยนกลุ่ม |
---|---|---|
a[i] a() a.f |
การเข้าถึงดัชนี การเรียกใช้ และฟิลด์ | ซ้ายไปขวา |
!a -a |
การนิเสธแบบเอกภาค | ขวาไปซ้าย |
a/b a%b a*b |
โอเปอเรเตอร์การคูณ | ซ้ายไปขวา |
a+b a-b |
โอเปอเรเตอร์การบวก | ซ้ายไปขวา |
a>b a>=b a<b a<=b |
โอเปอเรเตอร์ที่เกี่ยวข้อง | ซ้ายไปขวา |
a in b |
มีอยู่ในรายการหรือแผนที่ | ซ้ายไปขวา |
type(a) == t |
การเปรียบเทียบประเภท โดยที่ t อาจเป็น bool, int, float,
number, string, list, map, timestamp หรือ duration |
ซ้ายไปขวา |
a==b a!=b |
โอเปอเรเตอร์การเปรียบเทียบ | ซ้ายไปขวา |
a && b |
AND แบบมีเงื่อนไข | ซ้ายไปขวา |
a || b |
หรือแบบมีเงื่อนไข | ซ้ายไปขวา |
a ? true_value : false_value |
นิพจน์ Ternary | ซ้ายไปขวา |
ข้อมูลในโทเค็นการตรวจสอบสิทธิ์
ออบเจ็กต์ auth.token
อาจมีค่าต่อไปนี้
ช่อง | คำอธิบาย |
---|---|
email |
อีเมลที่เชื่อมโยงกับบัญชี (หากมี) |
email_verified |
true หากผู้ใช้ยืนยันว่าตนมีสิทธิ์เข้าถึงอีเมล email ผู้ให้บริการบางรายจะยืนยันอีเมลที่ตนเป็นเจ้าของโดยอัตโนมัติ |
phone_number |
หมายเลขโทรศัพท์ที่เชื่อมโยงกับบัญชี (หากมี) |
name |
ชื่อที่แสดงของผู้ใช้ หากตั้งค่าไว้ |
sub |
UID ของ Firebase ของผู้ใช้ ซึ่งจะไม่ซ้ำกันภายในโปรเจ็กต์ |
firebase.identities |
พจนานุกรมของข้อมูลระบุตัวตนทั้งหมดที่เชื่อมโยงกับบัญชีของผู้ใช้รายนี้ คีย์ของพจนานุกรมอาจเป็นค่าใดค่าหนึ่งต่อไปนี้ email , phone , google.com , facebook.com , github.com , twitter.com ค่าของพจนานุกรมคืออาร์เรย์ของตัวระบุที่ไม่ซ้ำกันสำหรับผู้ให้บริการข้อมูลประจำตัวแต่ละรายที่เชื่อมโยงกับบัญชี เช่น auth.token.firebase.identities["google.com"][0] มีรหัสผู้ใช้ Google รายแรกที่เชื่อมโยงกับบัญชี |
firebase.sign_in_provider |
ผู้ให้บริการลงชื่อเข้าใช้ที่ใช้รับโทเค็นนี้ อาจเป็นสตริงใดก็ได้ต่อไปนี้ custom , password , phone , anonymous , google.com , facebook.com , github.com , twitter.com |
firebase.tenant |
รหัสผู้เช่าที่เชื่อมโยงกับบัญชี (หากมี) เช่น tenant2-m6tyz |
ฟิลด์เพิ่มเติมในโทเค็นรหัส JWT
นอกจากนี้ คุณยังเข้าถึงฟิลด์auth.token
ต่อไปนี้ได้ด้วย
การอ้างสิทธิ์โทเค็นที่กำหนดเอง | ||
---|---|---|
alg |
อัลกอริทึม | "RS256" |
iss |
ผู้ออก | อีเมลบัญชีบริการของโปรเจ็กต์ |
sub |
เรื่อง | อีเมลบัญชีบริการของโปรเจ็กต์ |
aud |
กลุ่มเป้าหมาย | "https://identitytoolkit.googleapis.com/google.identity.identitytoolkit.v1.IdentityToolkit" |
iat |
เวลาที่ออก | เวลาปัจจุบันเป็นวินาทีนับตั้งแต่ Epoch ของ UNIX |
exp |
เวลาหมดอายุ |
เวลาเป็นวินาทีนับตั้งแต่ Epoch ของ UNIX ที่โทเค็นหมดอายุ โดยช้ากว่าiat ได้สูงสุด 3,600 วินาที
หมายเหตุ: การตั้งค่านี้จะควบคุมเฉพาะเวลาที่โทเค็นที่กำหนดเองหมดอายุ เท่านั้น แต่เมื่อคุณลงชื่อเข้าใช้ผู้ใช้โดยใช้ signInWithCustomToken() ผู้ใช้จะยังคงลงชื่อเข้าใช้อุปกรณ์
จนกว่าเซสชันจะใช้งานไม่ได้หรือผู้ใช้จะออกจากระบบ
|
<claims> (ไม่บังคับ) |
การอ้างสิทธิ์ที่กำหนดเองที่ไม่บังคับเพื่อรวมไว้ในโทเค็น ซึ่งเข้าถึงได้ผ่าน
auth.token (หรือ request.auth.token ) ใน
นิพจน์ เช่น หากสร้างการอ้างสิทธิ์ที่กำหนดเอง
adminClaim คุณจะเข้าถึงการอ้างสิทธิ์ดังกล่าวได้ด้วย
auth.token.adminClaim
|