テストケースとして、GoogleScriptsを使用してGoogleドライブからDropboxにファイルをコピーしようとしています
function pushBuild() {
// Setup OAuthServiceConfig
var oAuthConfig = UrlFetchApp.addOAuthService("dropbox");
oAuthConfig.setAccessTokenUrl("https://api.dropbox.com/1/oauth/access_token");
oAuthConfig.setRequestTokenUrl("https://api.dropbox.com/1/oauth/request_token");
oAuthConfig.setAuthorizationUrl("https://www.dropbox.com/1/oauth/authorize");
oAuthConfig.setConsumerKey(ScriptProperties.getProperty("dropboxKey"));
oAuthConfig.setConsumerSecret(ScriptProperties.getProperty("dropboxSecret"));
var fileName = "blah.zip"
var folderName = "upload_dir"
var docs = DocsList.getFolder(folderName).find(fileName);
for(n=0;n<docs.length;++n){
if(docs[n].getName() == fileName){
var ID = docs[n].getId();
var options = {
"oAuthServiceName" : "dropbox",
"oAuthUseToken" : "always",
"method" : "put",
"payload" : docs[n].getBlob().getBytes(),
"contentType" : "application/zip"
};
var response = UrlFetchApp.fetch("https://api-content.dropbox.com/1/files_put/sandbox/upload_dir/" + fileName, options);
Logger.log(response);
}
}
}
Dropboxにアプリケーションの承認リクエストが表示され、アプリが正常に承認されたことが示されますが、確認すると、アプリが[マイアプリ]のリストになく、ファイルがアップロードされておらず、ログのエントリ。ディレクトリ「upload_dir」はGDとDBの両方に存在します。「AppFolder」と「FullDropbox」のアプリタイプで同じコードを試しましたが、同じ結果が得られます。
さらに、スクリプトをもう一度実行すると、次のような承認ページが再度トリガーされます。
表示するには、[許可]をクリックすると成功画面が表示されますが、アプリケーションは[マイアプリ]に表示されません。スクリプトを再度実行すると、プロセスが繰り返されます。
誰かが私が間違ったことを指摘できますか?
アップデート
そのため、個々のAPI呼び出しを使用してこれを実装しようとしましたが、まだ成功していません。
function testOAuth() {
var timestamp = getTimestamp();
var nonce = getNonce(timestamp);
var authString = 'OAuth oauth_version="1.0", oauth_signature_method="PLAINTEXT", oauth_signature="' + encodeURIComponent(ScriptProperties.getProperty("dropboxSecret") + '&') + '", oauth_consumer_key="' + ScriptProperties.getProperty("dropboxKey") + '"';
Logger.log(authString)
var options = {
method : "POST",
headers : {"Authorization" : authString}
}
var response = UrlFetchApp.fetch("https://api.dropbox.com/1/oauth/request_token",options);
var params = response.getContentText().split("&");
var map = new Map;
for(i = 0; i < params.length; i++){
var param = params[i].split("=");
map.put(param[0],param[1]);
}
var authStringx = "https://www.dropbox.com/1/oauth/authorize?oauth_token=" + map.get("oauth_token");
Logger.log(authStringx);
var response2 = UrlFetchApp.fetch(authStringx);
Logger.log(response2.getContentText());
var authString2 = 'OAuth oauth_version="1.0", oauth_signature_method="PLAINTEXT", oauth_token="' + map.get("oauth_token") + '" , oauth_signature="' + encodeURIComponent(ScriptProperties.getProperty("dropboxSecret") + '&' + map.get("oauth_token_secret")) + '", oauth_consumer_key="' + ScriptProperties.getProperty("dropboxKey") + '",oauth_timestamp="'+ timestamp +'", oauth_nonce="' + nonce +'"';
Logger.log(authString2);
var options3 = {
"method" : "POST",
"Authorization" : authString2
}
var response3 = UrlFetchApp.fetch("https://api.dropbox.com/1/oauth/access_token", options3);
Logger.log(response3.getContentText());
}
var getTimestamp = function(){
return (Math.floor((new Date()).getTime() / 1000)).toString()
}
var getNonce = function(timestamp){
return timestamp + Math.floor( Math.random() * 100000000)
}
マップのコード実装はここにあります。私が見ることができる主な問題は、承認ステップがDropbox承認エンドポイントを呼び出さないことです(つまり、アプリケーションを承認するためのブラウザーのリダイレクトは行われません)。行の直後にブレークポイントを配置し、Logger.log(authStringx);
authStringxのコンテンツを貼り付けているWebページに手動でアクセスすると、アプリを承認するための画面が表示されます。私はそれを受け入れ、アプリが「マイアプリ」に登録されているというメッセージを受け取ります。プログラムを続行すると、メッセージが表示されます
何か案は?