0

ドメインユーザーをGoogleスクリプトで更新しようとしていますが、Google Profile APIを介してユーザーを正常に取得していますが、更新操作を呼び出す必要があり、変更を加えたXMLを送信する必要があります。

私はXmlサービスを使用していますが、xmlを読み取るためだけのもののようです。

Xmlオブジェクトを更新して、プロファイルAPIの更新操作に送信するにはどうすればよいですか?

これはコードです:

/**
 * Script configuration
 */
var SCOPE = 'http://www.google.com/m8/feeds/';
var APPNAME = "profile";
var GET_URL = 'https://www.google.com/m8/feeds/profiles/domain/{domainName}/full/{userName}?v=3.0';

function updateContact(e) {
  var domain = UserManager.getDomain();
  GET_URL = GET_URL.replace("{domainName}", domain);
  var user = UserManager.getUser(Session.getActiveUser());
  var userName = user.getUserLoginId();

  var user = getUser(userName);

  if(user !== null)
  {
    //Update
    updateUser(user, '344343','432432423','test','test');
  }
}

function getUser(userName)
{
  try
  {
    var response = UrlFetchApp.fetch(GET_URL.replace("{userName}",userName) , googleOAuth_('GET'));
    var jsonObj = Xml.parse(response.getContentText())
    var text = response.getContentText();
    var entry = jsonObj.entry;

    if(typeof(entry) !== 'undefined' && entry !== null)
    {
      return entry;
    }
  }
  catch(ex)
  {
  }
  return null;
}

function updateUser(userEntry, phone, mobile, position, city)
{
  var editLink = '';
  var linksLength = userEntry.link.length;
  for(var i=0; i<linksLength; i++)
  {
    if(userEntry.link[i].rel === "edit") editLink = userEntry.link[i].href;
  }

  //This is where I don't know what to do, how to edit the user entry

  var response = UrlFetchApp.fetch(editLink,googleOAuth_('PUT', xml.toString()));
}
4

1 に答える 1

1

申し訳ありません@ Escobar5、あなたの更新を取得できませんでした。Romain Vialard (および私からのビット) によるオープン ソースの ProfilesApp ライブラリがここにあります https://sites.google.com/site/scriptsexamples/new-connectors-to-google-services/profiles-services

于 2013-05-06T05:55:56.890 に答える