しばらくの間、Google Apps ドメインのユーザーを一覧表示しようとしています。Python では問題ありませんが、C# ではエラー メッセージが表示されます: An error has occurred: Google.Apis.Requests.RequestError Bad Request [400] Errors [ Message[Bad Request] Location[ - ] Reason[badRequest] Domain[global] ]
私は C# の第一人者ではありませんが、Google.Apis.Admin.directory_v1.cs ファイルを調べたところ、UserResource ListRequest が間違っているように見えましたか??? ファイルの 7349-7352 行にあります。APIにまだ実装されていないかどうか知っている人はいますか?
編集: Google.Apis.Admin.directory_v1.cs のコードが間違っていると思う理由から始めます(前述のとおり、私は C# の達人ではありません)。
コード:
/// <summary>Retrieve either deleted users or all users in a domain (paginated)</summary>
public virtual ListRequest List() {
return new ListRequest(service);
}
奇妙だと思う理由:
このリクエストの引数として customerid または domain を渡す場所はわかりますが、API Explorer ではそれが必要です (それ以外の場合、元の投稿で上記と同じエラー メッセージが表示されます)。
編集:ファイルをもう少し下に調べたところ、8904行目以降が以前に探していたものを実行していると思います。私の悪い!
しかし、それでもコードを動作させることができません?!?!?
そして、動作しない私のコード:
static void Main(string[] args)
{
// Display the header and initialize the sample.
CommandLine.EnableExceptionHandling();
Console.WriteLine("List users in a google apps domain!");
Console.WriteLine("by Jonas Bergstedt 2013");
// Get the domainname
Console.Write("Domain: ");
string domain = Console.ReadLine();
// Register the authenticator.
var provider = new NativeApplicationClient(GoogleAuthenticationServer.Description)
{
ClientIdentifier = <myClientId>,
ClientSecret = <myClientSecret>",
};
var auth = new OAuth2Authenticator<NativeApplicationClient>(provider, GetAuthorization);
// Create the service.
var service = new DirectoryService(new BaseClientService.Initializer()
{
Authenticator = auth,
ApplicationName = "List Users",
ApiKey = <myApiKey>
});
// Trying to add the domain
service.Users.List().Domain = domain;
Users results = service.Users.List().Execute();
foreach (User list in results.UsersValue)
{
Console.WriteLine("- " + list.Name);
}
}
private static IAuthorizationState GetAuthorization(NativeApplicationClient arg)
{
// Get the auth URL:
IAuthorizationState state = new AuthorizationState(new[] { DirectoryService.Scopes.AdminDirectoryUser.GetStringValue() });
state.Callback = new Uri(NativeApplicationClient.OutOfBandCallbackUrl);
Uri authUri = arg.RequestUserAuthorization(state);
// Request authorization from the user (by opening a browser window):
Process.Start(authUri.ToString());
Console.WriteLine();
Console.Write("Authorization Code: ");
string authCode = Console.ReadLine();
// Retrieve the access token by using the authorization code:
return arg.ProcessUserAuthorization(authCode, state);
}
}