יצירה וניהול של קבצים

במדריך הזה מוסבר איך ליצור ולנהל קבצים ב-Google Drive באמצעות Google Drive API.

יצירת קובץ

כדי ליצור קובץ ב-Drive שלא מכיל מטא-נתונים או תוכן, צריך להשתמש בשיטה create במשאב files ללא פרמטרים.

כשיוצרים את הקובץ, השיטה מחזירה משאב files. לקובץ ניתן kind של drive.file,‏ id,‏ name של 'ללא שם' וmimeType של application/octet-stream. המאפיין uploadType מסומן כמאפיין חובה, אבל ערך ברירת המחדל שלו הוא media, כך שבעצם לא צריך לספק אותו.

מידע נוסף על מגבלות קבצים ב-Drive זמין במאמר מגבלות על קבצים ותיקיות.

שימוש בפרמטר fields

אם רוצים לציין את השדות שיוחזרו בתגובה, אפשר להגדיר את fields פרמטר המערכת files בכל שיטה של המשאב. אם משמיטים את הפרמטר fields, השרת מחזיר קבוצת ברירת מחדל של שדות שספציפיים לשיטה. לדוגמה, ה-method‏ list מחזירה רק את השדות kind, id, name, mimeType ו-resourceKey של כל קובץ. כדי להחזיר שדות שונים, אפשר לעיין במאמר החזרת שדות ספציפיים.

הבעלות על הקובץ

כשיוצרים קובץ באמצעות Drive API, הבעלות תלויה בפרטי האימות שבהם האפליקציה משתמשת, באופן הבא:

  • חשבון משתמש (OAuth 2.0): אם האפליקציה מאומתת בשם משתמש, המשתמש הזה הופך לבעלים של הקובץ. הקובץ יישמר בתיקייה 'האחסון שלי' או בתיקייה שצוינה. הוא תופס נפח אחסון מהמכסה שלהם.

  • חשבון שירות: אם האפליקציה מבצעת אימות באמצעות חשבון שירות, חשבון השירות הוא הבעלים של הקובץ. הקובץ יישמר באחסון הייעודי ב-Drive של חשבון השירות. קבצים לא מופיעים בחשבונות אחסון אחרים ב-Drive, אלא אם הם שותפו באופן מפורש. אם חשבון השירות נמחק, כל הקבצים שבבעלותו נמחקים באופן מיידי.

    אם אתם משתמשים בחשבון שירות אבל רוצים שחשבון משתמש ספציפי יהיה הבעלים של קובץ, אתם יכולים להשתמש בהענקת גישה ברמת הדומיין. ההרשאה הזו מאפשרת לחשבון השירות להתחזות למשתמש וליצור קבצים בשמו. מידע נוסף מופיע במאמר הענקת הרשאה ברמת הדומיין לחשבון השירות.

מידע נוסף על הרשאות לקבצים זמין במאמר בנושא שיתוף קבצים, תיקיות וכוננים.

יצירת מזהים לשימוש בקבצים

השיטה generateIds במשאב files מאפשרת ליצור מראש מזהי קבצים ייחודיים שאפשר להשתמש בהם כשיוצרים או מעתיקים קבצים ותיקיות ב-Drive. האפשרות הזו יכולה להיות שימושית כשרוצים לשלוט במזהי הקבצים מתוך האפליקציה, במקום לאפשר ל-Drive להקצות אותם באופן אוטומטי.

אפשר להגדיר את מספר המזהים שייווצרו באמצעות פרמטר השאילתה count. אם לא מגדירים את count, המערכת מחזירה 10 כברירת מחדל. המספר המקסימלי של מזהים שאפשר לבקש הוא 1,000.

אפשר גם לציין את space שבו אפשר להשתמש במזהים ואת type של הפריטים שאפשר להשתמש במזהים שלהם.

אחרי שמזהה נוצר, אפשר להעביר אותו לשיטה create או copy דרך השדה id. כך מוודאים שהקובץ שנוצר או הועתק ישתמש במזהה שנקבע מראש.

אם הקובץ נוצר או הועתק בהצלחה, ניסיונות חוזרים יחזירו תגובה עם קוד סטטוס HTTP 409 Conflict ולא ייצרו קבצים כפולים.

שימו לב: אי אפשר להשתמש במזהים שנוצרו מראש כדי ליצור קבצים ב-Google Workspace, למעט application/vnd.google-apps.drive-sdkוapplication/vnd.google-apps.folder סוגי MIME. באופן דומה, אין תמיכה בהעלאות שמתייחסות להמרה לפורמט קובץ של Google Workspace.

יצירת קבצים עם מטא-נתונים בלבד

קבצים של מטא-נתונים בלבד לא מכילים תוכן. מטא-נתונים הם נתונים (כמו name,‏ mimeType ו-createdTime) שמתארים את הקובץ. שדות כמו name לא תלויים במשתמש ומופיעים באופן זהה לכל משתמש, בעוד ששדות כמו viewedByMeTime מכילים ערכים ספציפיים למשתמש.

דוגמה לקובץ מטא-נתונים בלבד היא תיקייה עם סוג ה-MIME‏ application/vnd.google-apps.folder. מידע נוסף זמין במאמר בנושא יצירה של תיקיות והוספת קבצים לתיקיות. דוגמה נוספת היא קיצור דרך שמפנה לקובץ אחר ב-Drive עם סוג ה-MIME‏ application/vnd.google-apps.shortcut. מידע נוסף זמין במאמר בנושא יצירת קיצור דרך לקובץ ב-Drive.

ניהול תמונות ממוזערות

תמונות ממוזערות עוזרות למשתמשים לזהות קבצים ב-Drive. ‫Drive יכול ליצור באופן אוטומטי תמונות ממוזערות לסוגי קבצים נפוצים, או שאתם יכולים לספק תמונה ממוזערת שנוצרה על ידי האפליקציה שלכם. מידע נוסף זמין במאמר בנושא העלאת תמונות ממוזערות.

העתקת קובץ קיים

כדי להעתיק קובץ ולהחיל עדכונים שנדרשים, משתמשים בשיטה copy במשאב files. כדי למצוא את fileId להעתקה, משתמשים בשיטה list.

אפשר להחיל עדכונים באמצעות סמנטיקה של תיקון, כלומר אפשר לבצע שינויים חלקיים במשאב. חובה להגדיר במפורש את השדות שרוצים לשנות בבקשה. כל השדות שלא נכללים בבקשה שומרים על הערכים הקיימים שלהם. מידע נוסף מופיע במאמר עבודה עם משאבים חלקיים.

אפשר להגדיר מראש את מזהה הקובץ של הקובץ שהועתק באמצעות ה-method‏ generateIds. מידע נוסף זמין במאמר בנושא יצירת מזהים לשימוש בקבצים.

שימו לב שצריך להשתמש בהיקף מתאים של Drive API כדי לתת הרשאה לקריאה. מידע נוסף על היקפי ההרשאות של Drive זמין במאמר בחירת היקפי הרשאות של Google Drive API.

מגבלות ושיקולים

כשמתכוננים להעתקת קבצים, חשוב לשים לב למגבלות ולשיקולים הבאים:

  • הרשאות:

    • האובייקט DownloadRestrictionsMetadata של המשאב files קובע מי יכול להעתיק את הקובץ. מידע נוסף זמין במאמר בנושא איך מונעים ממשתמשים להוריד, להדפיס או להעתיק את הקובץ.
    • המשאב של השדה capabilities.canCopy קובע אם המשתמש יכול להעתיק קובץ. מידע נוסף זמין במאמר הסבר על היכולות של קבצים.
    • המשתמש שיצר את העותק הוא הבעלים של הקובץ שהועתק. הגדרות שיתוף אחרות מקובץ המקור לא משוכפלות. אם העותק נוצר בתיקייה משותפת, הוא מקבל את ההרשאות של התיקייה הזו.
    • הבעלות על קובץ שהועתק עשויה להשתנות, וההעתק לא יקבל בירושה את הרשאות השיתוף של הקובץ המקורי. יכול להיות שיהיה צורך לאפס את ההגדרות האלה.
  • ניהול קבצים:

    • אי אפשר להעתיק קבצים מסוימים, כמו קיצורי דרך של צד שלישי.
    • אפשר להעתיק קובץ רק לתיקיית אב אחת. אי אפשר לציין כמה הורים. אם השדה parents לא מצוין, הקובץ מקבל בירושה את כל תיקיות ההורה שאפשר לגלות מקובץ המקור.
    • למרות שתיקייה היא סוג של קובץ, אי אפשר להעתיק תיקייה. במקום זאת, יוצרים תיקיית יעד ומגדירים את השדה parents של הקבצים הקיימים לתיקיית היעד. אחר כך תוכלו למחוק את תיקיית המקור המקורית.
    • אלא אם מציינים שם קובץ חדש, השיטה copy יוצרת קובץ עם אותו שם כמו הקובץ המקורי.
    • שימוש מופרז ב-copy עלול לגרום לחריגה ממגבלות המכסה של Drive API. מידע נוסף זמין במאמר בנושא מגבלות שימוש.

הנה כמה פעולות שאפשר לנסות: