I've written a method that signs URLs to read an S3 bucket that is accessed through Cloudfront:
private HTTPResponse signURL(String endpoint) {
String keyPairId = 'keyPairId';
String secret = 'SOME_SECRET';
String method = 'GET';
Datetime dt = Datetime.now();
Long l = dt.getTime();
Long expiryLong = (l / 1000) + 3600;
String expiry = String.valueOf(expiryLong);
String policy = policy('http://' + cfhost + '/' + endpoint, expiry);
String policyEnc = EncodingUtil.base64Encode(Blob.valueOf(policy));
String rPolicy = cfReplace(policyEnc);
Blob mac = Crypto.generateMac('HMACSHA1',
Blob.valueOf(rPolicy),
Blob.valueOf(secret));
String signature = cfReplace(EncodingUtil.base64Encode(mac));
HttpRequest req = new HttpRequest();
req.setMethod(method);
req.setEndpoint('http://' + cfhost + '/' + endpoint + '?Policy=' +
policyEnc + '&Signature=' + signature + '&Key-Pair-Id=' +
keyPairId);
Http http = new Http();
HTTPResponse res = http.send(req);
return res;
}
Now, my method works fine if the endpoint is set to ''
. If I put the folder name in the endpoint (like 00Q17000008LRcAEAW/*
) I get a bunch of errors in the XML response.
XMLNode[ELEMENT,Error,null,null,null,[XMLNode[ELEMENT,Code,null,null,null,[XMLNode[TEXT,null,null,null,null,null,NoSuchKey,]],null,], XMLNode[ELEMENT,Message,null,null,null,[XMLNode[TEXT,null,null,null,null,null,The specified key does not exist.,]],null,], XMLNode[ELEMENT,Key,null,null,null,[XMLNode[TEXT,null,null,null,null,null,00Q17000008LRcAEAW/*,]],null,], XMLNode[ELEMENT,RequestId,null,null,null,[XMLNode[TEXT,null,null,null,null,null,some_req_id,]],null,], XMLNode[ELEMENT,HostId,null,null,null,[XMLNode[TEXT,null,null,null,null,null,some_host_id,]],null,]],null,]
I can't list the whole bucket because it's too big for the 1000-key limit. How can I list the folder?