คำอธิบาย
ใช้ chrome.syncFileSystem
API เพื่อบันทึกและซิงค์ข้อมูลใน Google ไดรฟ์ API นี้ไม่ได้ใช้สำหรับเข้าถึงเอกสารของผู้ใช้ที่กำหนดเองที่เก็บไว้ใน Google ไดรฟ์ มอบพื้นที่เก็บข้อมูลที่ซิงค์ได้สำหรับแต่ละแอปโดยเฉพาะสำหรับการใช้งานแบบออฟไลน์และการแคช เพื่อให้ข้อมูลเดียวกันนั้นพร้อมใช้งานบนไคลเอ็นต์ที่ต่างกัน อ่านจัดการข้อมูลเพื่อดูข้อมูลเพิ่มเติมเกี่ยวกับการใช้ API นี้
สิทธิ์
syncFileSystem
ประเภท
ConflictResolutionPolicy
ค่าแจกแจง
"last_write_win"
"manual"
FileInfo
พร็อพเพอร์ตี้
-
การดำเนินการ
SyncAction ไม่บังคับ
ดำเนินการซิงค์เพื่อเริ่มการทำงานของเหตุการณ์
onFileStatusChanged
ค่าการดำเนินการอาจเป็น'added'
,'updated'
หรือ'deleted'
มีผลเมื่อสถานะเป็น'synced'
เท่านั้น -
direction
SyncDirection ไม่บังคับ
ทิศทางการซิงค์สําหรับเหตุการณ์
onFileStatusChanged
ค่าทิศทางการซิงค์อาจเป็น'local_to_remote'
หรือ'remote_to_local'
มีผลเมื่อสถานะเป็น'synced'
เท่านั้น -
fileEntry
รายการ
fileEntry
สำหรับไฟล์เป้าหมายที่สถานะมีการเปลี่ยนแปลง มีข้อมูลชื่อและเส้นทางของไฟล์ที่ซิงค์ เมื่อลบไฟล์แล้ว ข้อมูลfileEntry
จะยังใช้ได้อยู่แต่จะไม่มีไฟล์อยู่อีกต่อไป -
สถานะ
สถานะไฟล์ที่เกิดขึ้นหลังจากเหตุการณ์
onFileStatusChanged
ค่าสถานะอาจเป็น'synced'
,'pending'
หรือ'conflicting'
FileStatus
ค่าแจกแจง
"ซิงค์แล้ว"
ไม่ขัดแย้งกันและไม่มีการเปลี่ยนแปลงภายในเครื่องที่รอดำเนินการ
"pending"
มีการเปลี่ยนแปลงในเครื่องที่รอดำเนินการอย่างน้อย 1 รายการที่ยังไม่ได้ซิงค์
"ข้อขัดแย้ง"
ไฟล์ขัดแย้งกับเวอร์ชันระยะไกลและต้องแก้ไขด้วยตนเอง
FileStatusInfo
พร็อพเพอร์ตี้
-
ข้อผิดพลาด
string ไม่บังคับ
ข้อผิดพลาดที่ไม่บังคับซึ่งจะแสดงก็ต่อเมื่อมีปัญหาในการเรียก FileStatus สำหรับไฟล์ที่ระบุ
-
fileEntry
รายการ
หนึ่งในรายการจะมอบให้กับ getFileStatuses
-
สถานะ
ค่าสถานะอาจเป็น
'synced'
,'pending'
หรือ'conflicting'
ServiceInfo
พร็อพเพอร์ตี้
-
คำอธิบาย
สตริง
-
รัฐ
ServiceStatus
ค่าแจกแจง
"initializing"
บริการซิงค์กำลังเริ่มต้น (เช่น การกู้คืนข้อมูลจากฐานข้อมูล ตรวจสอบการเชื่อมต่อและการตรวจสอบสิทธิ์กับบริการ เป็นต้น)
"กำลังทำงาน"
บริการการซิงค์เริ่มทำงานแล้ว
"authentication_required"
บริการซิงค์ไม่ซิงค์ข้อมูลไฟล์เนื่องจากผู้ใช้ต้องตรวจสอบสิทธิ์บริการระยะไกลเพื่อดำเนินการต่อ
"temporary_unavailable"
บริการซิงค์ไม่ซิงค์ข้อมูลไฟล์เนื่องจากบริการระยะไกลไม่พร้อมใช้งาน (ชั่วคราว) เนื่องจากมีข้อผิดพลาดที่กู้คืนได้ เช่น เครือข่ายออฟไลน์อยู่ บริการระยะไกลใช้งานไม่ได้หรือเข้าถึงไม่ได้ ฯลฯ คุณควรระบุรายละเอียดเพิ่มเติมตามพารามิเตอร์ description
ใน OnServiceInfoUpdated (ซึ่งอาจมีรายละเอียดเฉพาะบริการ)
"disable"
บริการซิงค์ถูกปิดใช้งานและเนื้อหาจะไม่มีการซิงค์ (เช่น กรณีนี้อาจเกิดขึ้นเมื่อผู้ใช้ไม่มีบัญชีในบริการระยะไกลหรือบริการซิงค์มีข้อผิดพลาดที่กู้คืนไม่ได้)
StorageInfo
พร็อพเพอร์ตี้
-
quotaBytes
ตัวเลข
-
usageBytes
ตัวเลข
SyncAction
ค่าแจกแจง
"เพิ่มแล้ว"
"อัปเดต"
"ลบแล้ว"
SyncDirection
ค่าแจกแจง
"local_to_remote"
"remote_to_local"
เมธอด
getConflictResolutionPolicy()
chrome.syncFileSystem.getConflictResolutionPolicy(
callback?: function,
)
รับนโยบายการแก้ไขข้อขัดแย้งปัจจุบัน
พารามิเตอร์
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(policy: ConflictResolutionPolicy) => void
-
policy
-
การคืนสินค้า
-
Promise<ConflictResolutionPolicy>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
getFileStatus()
chrome.syncFileSystem.getFileStatus(
fileEntry: Entry,
callback?: function,
)
แสดงผล FileStatus
สำหรับ fileEntry
ที่ระบุ ค่าสถานะอาจเป็น 'synced'
, 'pending'
หรือ 'conflicting'
โปรดทราบว่าสถานะ 'conflicting'
จะเกิดขึ้นก็ต่อเมื่อตั้งค่านโยบายการแก้ไขข้อขัดแย้งของบริการเป็น 'manual'
เท่านั้น
พารามิเตอร์
-
fileEntry
รายการ
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(status: FileStatus) => void
-
สถานะ
-
การคืนสินค้า
-
Promise<FileStatus>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
getFileStatuses()
chrome.syncFileSystem.getFileStatuses(
fileEntries: object[],
callback?: function,
)
แสดงผล FileStatus
แต่ละรายการสำหรับอาร์เรย์ fileEntry
ที่ระบุ โดยทั่วไปจะเรียกใช้ด้วยผลลัพธ์จาก dirReader.readEntries()
พารามิเตอร์
-
fileEntries
object[]
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(status: FileStatusInfo[]) => void
-
สถานะ
-
การคืนสินค้า
-
Promise<FileStatusInfo[]>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
getServiceStatus()
chrome.syncFileSystem.getServiceStatus(
callback?: function,
)
แสดงผลแบ็กเอนด์การซิงค์ปัจจุบัน
พารามิเตอร์
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(status: ServiceStatus) => void
-
สถานะ
-
การคืนสินค้า
-
Promise<ServiceStatus>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
getUsageAndQuota()
chrome.syncFileSystem.getUsageAndQuota(
fileSystem: DOMFileSystem,
callback?: function,
)
แสดงผลการใช้งานปัจจุบันและโควต้าเป็นไบต์สำหรับพื้นที่จัดเก็บไฟล์ 'syncable'
ของแอป
พารามิเตอร์
-
fileSystem
DOMFileSystem
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(info: StorageInfo) => void
-
ข้อมูล
-
การคืนสินค้า
-
Promise<StorageInfo>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
requestFileSystem()
chrome.syncFileSystem.requestFileSystem(
callback?: function,
)
แสดงระบบไฟล์ที่ซิงค์ได้และสนับสนุนโดย Google ไดรฟ์ อินสแตนซ์ DOMFileSystem
ที่แสดงผลนั้นสามารถทำงานได้ในลักษณะเดียวกับระบบไฟล์ชั่วคราวและถาวร (โปรดดู http://dev.w3.org/2009/dap/file-system/file-dir-sys.html)
การเรียกใช้คำสั่งนี้หลายครั้งจากแอปเดียวกันจะเป็นการคืนแฮนเดิลเดียวกันลงในระบบไฟล์เดียวกัน
โปรดทราบว่าการโทรนี้อาจล้มเหลว เช่น หากผู้ใช้ไม่ได้ลงชื่อเข้าใช้ Chrome หรือไม่มีการทำงานของเครือข่าย ในการจัดการข้อผิดพลาดเหล่านี้ สิ่งสำคัญคือต้องตรวจสอบ chrome.runtime.lastError ใน Callback
พารามิเตอร์
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้(fileSystem: DOMFileSystem) => void
-
fileSystem
DOMFileSystem
-
การคืนสินค้า
-
Promise<DOMFileSystem>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
setConflictResolutionPolicy()
chrome.syncFileSystem.setConflictResolutionPolicy(
policy: ConflictResolutionPolicy,
callback?: function,
)
ตั้งค่านโยบายการแก้ไขความขัดแย้งเริ่มต้นสำหรับพื้นที่เก็บไฟล์ 'syncable'
ของแอป ค่าเริ่มต้นจะตั้งไว้เป็น 'last_write_win'
เมื่อตั้งค่านโยบายการแก้ไขความขัดแย้งเป็น 'last_write_win'
ความขัดแย้งสำหรับไฟล์ที่มีอยู่จะได้รับการแก้ไขโดยอัตโนมัติในครั้งต่อไปที่ไฟล์ได้รับการอัปเดต คุณเลือกให้ callback
ได้ หากต้องการทราบว่าคําขอสําเร็จหรือไม่
พารามิเตอร์
-
policy
-
Callback
ไม่บังคับ
พารามิเตอร์
callback
มีลักษณะดังนี้() => void
การคืนสินค้า
-
คำมั่นสัญญา<โมฆะ>
Chrome 117 ขึ้นไปPromise รองรับไฟล์ Manifest V3 ขึ้นไปเท่านั้น ส่วนแพลตฟอร์มอื่นๆ ต้องใช้ Callback
กิจกรรม
onFileStatusChanged
chrome.syncFileSystem.onFileStatusChanged.addListener(
callback: function,
)
เริ่มทำงานเมื่อไฟล์ได้รับการอัปเดตโดยบริการซิงค์ในเบื้องหลัง
พารามิเตอร์
-
Callback
ฟังก์ชัน
พารามิเตอร์
callback
มีลักษณะดังนี้(detail: FileInfo) => void
-
รายละเอียด
-
onServiceStatusChanged
chrome.syncFileSystem.onServiceStatusChanged.addListener(
callback: function,
)
เริ่มทำงานเมื่อเกิดข้อผิดพลาดหรือการเปลี่ยนแปลงสถานะอื่นๆ ในแบ็กเอนด์การซิงค์ (เช่น เมื่อปิดใช้การซิงค์ชั่วคราวเนื่องจากเกิดข้อผิดพลาดในเครือข่ายหรือการตรวจสอบสิทธิ์)
พารามิเตอร์
-
Callback
ฟังก์ชัน
พารามิเตอร์
callback
มีลักษณะดังนี้(detail: ServiceInfo) => void
-
รายละเอียด
-