Sample code for 30+ languages & platforms
Swift

Create a File in a Folder

See more Google Drive Examples

Creates (uploads) a file to be located in a particular folder.

See Google Drive Files: create for more details.

Also See Google Drive Multipart Upload for more details.

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    success = true

    // This example 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.

    let gAuth = CkoAuthGoogle()!
    gAuth.accessToken = "GOOGLE-DRIVE-ACCESS-TOKEN"

    let rest = CkoRest()!

    // Connect using TLS.
    var bAutoReconnect: Bool = true
    success = rest.connect(hostname: "www.googleapis.com", port: 443, tls: true, autoReconnect: bAutoReconnect)

    // Provide the authentication credentials (i.e. the access token)
    rest.setAuthGoogle(authProvider: gAuth)

    // -------------------------------------------------------------------------
    // A multipart upload to Google Drive needs a multipart/related Content-Type
    rest.addHeader(name: "Content-Type", value: "multipart/related")

    // Specify each part of the request.

    // The 1st part is JSON with information about the file.
    rest.partSelector = "1"
    rest.addHeader(name: "Content-Type", value: "application/json; charset=UTF-8")

    let json = CkoJsonObject()!
    json.appendString(name: "name", value: "testHello.txt")
    json.appendString(name: "description", value: "A simple file that says Hello World.")
    json.appendString(name: "mimeType", value: "text/plain")

    // To place the file in a folder, we must add a parents[] array to the JSON
    // and list the folder id's.  It's possible for a file to be in multiple folders at once
    // if it has more than one parent.  If no parents are specified, then the file is created
    // in the My Drive folder.  
    // Note: We'll assume we already have the id if the folder.  It is the id's that are specified here,
    // not the folder names.

    let parents = CkoJsonArray()!
    json.appendArray2(name: "parents", jarr: parents)

    var folderId: String? = "0B53Q6OSTWYolY2tPU1BnYW02T2c"
    parents.addString(at: -1, value: folderId)

    rest.setMultipartBodyString(bodyText: json.emit())

    // The 2nd part is the file content, which will contain "Hello World!"
    rest.partSelector = "2"
    rest.addHeader(name: "Content-Type", value: "text/plain")

    var fileContents: String? = "Hello World!"
    rest.setMultipartBodyString(bodyText: fileContents)

    var jsonResponse: String? = rest.fullRequestMultipart(httpVerb: "POST", uriPath: "/upload/drive/v3/files?uploadType=multipart")
    if rest.lastMethodSuccess == false {
        print("\(rest.lastErrorText!)")
        return
    }

    // A successful response will have a status code equal to 200.
    if rest.responseStatusCode.intValue != 200 {
        print("response status code = \(rest.responseStatusCode.intValue)")
        print("response status text = \(rest.responseStatusText!)")
        print("response header: \(rest.responseHeader!)")
        print("response JSON: \(jsonResponse!)")
        return
    }

    // Show the JSON response.
    json.load(json: jsonResponse)

    // Show the full JSON response.
    json.emitCompact = false
    print("\(json.emit()!)")

    // A successful response looks like this:
    // {
    //   "kind": "drive#file",
    //   "id": "0B53Q6OSTWYoldmJ0Z3ZqT2x5MFk",
    //   "name": "Untitled",
    //   "mimeType": "text/plain"
    // }

    // Get the fileId:
    print("fileId: \(json.string(of: "id")!)")

}