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