Visual FoxPro
Visual FoxPro
Create Folder
See more Google Drive Examples
In the Drive API, a folder is essentially a file — one identified by the special folder MIME type application/vnd.google-apps.folderSee Google Drive Files: create for more details.
Also See Working with Folders for more details.
Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loGAuth
LOCAL loRest
LOCAL lnBAutoReconnect
LOCAL loJson
LOCAL lcJsonResponse
lnSuccess = 0
* Creating a folder is technically an upload of a 0-length file
* having a MIME type of "application/vnd.google-apps.folder"
lnSuccess = 1
* It requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
* This example uses a previously obtained access token having permission for the
* Google Drive scope.
loGAuth = CreateObject('Chilkat.AuthGoogle')
loGAuth.AccessToken = "GOOGLE-DRIVE-ACCESS-TOKEN"
loRest = CreateObject('Chilkat.Rest')
* Connect using TLS.
lnBAutoReconnect = 1
lnSuccess = loRest.Connect("www.googleapis.com",443,1,lnBAutoReconnect)
* Provide the authentication credentials (i.e. the access token)
loRest.SetAuthGoogle(loGAuth)
* A multipart upload to Google Drive needs a multipart/related Content-Type
loRest.AddHeader("Content-Type","multipart/related")
* Specify each part of the request.
* The 1st part is JSON with information about the folder.
loRest.PartSelector = "1"
loRest.AddHeader("Content-Type","application/json; charset=UTF-8")
loJson = CreateObject('Chilkat.JsonObject')
loJson.AppendString("name","testFolder")
loJson.AppendString("description","A folder to contain test files.")
loJson.AppendString("mimeType","application/vnd.google-apps.folder")
loRest.SetMultipartBodyString(loJson.Emit())
* The 2nd part would be the file content.
* Since this is a folder, skip the 2nd part entirely and go straight to the upload..
lcJsonResponse = loRest.FullRequestMultipart("POST","/upload/drive/v3/files?uploadType=multipart")
IF (loRest.LastMethodSuccess <> 1) THEN
? loRest.LastErrorText
RELEASE loGAuth
RELEASE loRest
RELEASE loJson
CANCEL
ENDIF
* A successful response will have a status code equal to 200.
IF (loRest.ResponseStatusCode <> 200) THEN
? "response status code = " + STR(loRest.ResponseStatusCode)
? "response status text = " + loRest.ResponseStatusText
? "response header: " + loRest.ResponseHeader
? "response JSON: " + lcJsonResponse
RELEASE loGAuth
RELEASE loRest
RELEASE loJson
CANCEL
ENDIF
* Show the JSON response.
loJson.Load(lcJsonResponse)
* Show the full JSON response.
loJson.EmitCompact = 0
? loJson.Emit()
* A successful response looks like this:
* {
* "kind": "drive#file",
* "id": "0B53Q6OSTWYolY2tPU1BnYW02T2c",
* "name": "testFolder",
* "mimeType": "application/vnd.google-apps.folder"
* }
* Get the fileId:
? "fileId: " + loJson.StringOf("id")
RELEASE loGAuth
RELEASE loRest
RELEASE loJson