Чтобы получить информацию о профиле пользователя в Google Script

Я хочу получить информацию о профиле пользователя моего домена.. Я использую профиль API для этого..

Профиль API дает только несколько полей, таких как (Фамилия, Имя, Электронная почта и т. Д.). Но я также хочу получить эти поля также: род занятий, отдел, Телефон [Работа], Телефон [Мобильный], Отношение [Менеджер]..,

Я не могу получить эти поля. Поэтому, пожалуйста, дайте мне предложение получить эти поля.

2 ответа

Решение

Я получил все свои поля с помощью Profile API.... На самом деле, если какое-либо поле пусто, то Profile API не дает это поле в качестве выходного сигнала... Таким образом, используя Profile API, мы можем получить полную информацию пользователя...,

Code :
    var username="user "
    var base = 'https://www.google.com/m8/feeds/'; 
    var fetchArgs = googleOAuth_('contacts', base);
    fetchArgs.method='GET'
    var url=base+'profiles/domain/'+domainName+'/full/'+username+'?v=3&alt=json'

    var name=""
    var occupation=""
    var department=""
    var email=""
    var contactNumber_1=""
    var contactNumber_2=""
    var relation=""
    var account=""
    var office=""
    var personal_account=""
    var current_account=""
    var language=""
    var blog=""
    var image=""
    try{
      var urlFetch = UrlFetchApp.fetch(url, fetchArgs)   
      var json=Utilities.jsonParse(urlFetch.getContentText())
      var profileInfo = json.entry
      try{
        name=profileInfo.gd$name.gd$fullName.$t
      }catch(err){}
      try{
        occupation=profileInfo.gContact$occupation.$t
      }catch(err){}
      try{
        department=profileInfo.gd$organization[0].gd$orgDepartment.$t
      }catch(err){}
      try{
        var emaillist=profileInfo.gd$email
        for(var i=0;i<emaillist.length;i++){
          if(emaillist[i].rel.split("#")[1]=='work')
            email=profileInfo.gd$email[i].address
        }
      }catch(err){}
      try{
        var phonelist=profileInfo.gd$phoneNumber
        for(var i=0;i<phonelist.length;i++){
          if(phonelist[i].rel.split("#")[1]=='work')
            contactNumber_1=phonelist[i].$t
          else if(phonelist[i].rel.split("#")[1]=='mobile')
            contactNumber_2=phonelist[i].$t
        }
      }catch(err){}
      try{   
        relation=profileInfo.gContact$relation[0].$t+" ["+profileInfo.gContact$relation[0].rel+"]"
      }catch(err){}  

    }catch(err){}

}


/*
  Oauth Authentication
*/

function googleOAuth_(name,scope) {
  var oAuthConfig = UrlFetchApp.addOAuthService(name);
  oAuthConfig.setRequestTokenUrl("https://www.google.com/accounts/OAuthGetRequestToken?scope="+scope);
  oAuthConfig.setAuthorizationUrl("https://www.google.com/accounts/OAuthAuthorizeToken");
  oAuthConfig.setAccessTokenUrl("https://www.google.com/accounts/OAuthGetAccessToken");
  oAuthConfig.setConsumerKey(consumerKey);
  oAuthConfig.setConsumerSecret(consumerSecret);
  return {oAuthServiceName:name, oAuthUseToken:"always"};
}

Если какое-либо поле пусто, этот тег не будет найден, поэтому все поля записываются в блок try - catch...

Нет встроенного API для этого непосредственно в скрипте приложений, но если вы используете Google Apps для бизнеса или для обучения, вы можете использовать Google Apps через UrlFetch и oAuth. Это должно раскрыть любую информацию профиля, которая хранится в Службах Google.

Другие вопросы по тегам