Sto utilizzando "Google.Apis.Bigquery.v2 Libreria client" con C#.È possibile utilizzare la chiave json invece del tasto p12 per le credenziali dell'account di servizio?
Autorizzo Google BigQuery utilizzando "Account servizio" (vedere http://www.afterlogic.com/mailbee-net/docs/OAuth2GoogleServiceAccounts.html). Per creare il certificato X509, utilizzo la chiave p12 dalla Google Developers Console. Tuttavia, in questo momento la chiave JSON è l'impostazione predefinita. Posso usarlo invece il tasto p12?
Ho il codice seguente:
string serviceAccountEmail = "[email protected]";
X509Certificate2 certificate;
using (Stream stream = new FileStream(@"C:\key.p12", FileMode.Open, FileAccess.Read, FileShare.Read))
{
using (MemoryStream ms = new MemoryStream())
{
stream.CopyTo(ms);
certificate = new X509Certificate2(ms.ToArray(), "notasecret", X509KeyStorageFlags.Exportable);
}
}
// Create credentials
ServiceAccountCredential credential = new ServiceAccountCredential(
new ServiceAccountCredential.Initializer(serviceAccountEmail)
{
Scopes = new[] {
BigqueryService.Scope.Bigquery,
BigqueryService.Scope.CloudPlatform,
},
}.FromCertificate(certificate));
// Create the service
BaseClientService.Initializer initializer = new BaseClientService.Initializer()
{
HttpClientInitializer = credential,
ApplicationName = "My Application",
GZipEnabled = true,
};
BigqueryService service = new BigqueryService(initializer);
var projects = service.Projects.List().Execute();
La domanda simile (senza risposta) è qui http://stackoverflow.com/questions/30884184 –
Hai provato a utilizzare questo flusso: http://stackoverflow.com/questions/19977864/nativeapplicationclient-is-not-supported-any ma per BQ? – Ryan
Questo è in realtà molto vicino. Hai un esempio simile per ServiceAccountCredential (non UserCredential)? –