Google.Cloud.WebRisk.V1Beta1
Google.Cloud.WebRisk.V1Beta1
is a.NET client library for the Google Cloud Web Risk API.
Note:
This documentation is for version 3.0.0-beta03
of the library.
Some samples may not work with other versions.
Installation
Install the Google.Cloud.WebRisk.V1Beta1
package from NuGet. Add it to
your project in the normal way (for example by right-clicking on the
project in Visual Studio and choosing "Manage NuGet Packages...").
Please ensure you enable pre-release packages (for example, in the
Visual Studio NuGet user interface, check the "Include prerelease"
box). Some of the following samples might only work with the latest
pre-release version (3.0.0-beta03
) of Google.Cloud.WebRisk.V1Beta1
.
Authentication
When running on Google Cloud, no action needs to be taken to authenticate.
Otherwise, the simplest way of authenticating your API calls is to set up Application Default Credentials. The credentials will automatically be used to authenticate. See Set up Application Default Credentials for more details.
Getting started
All operations are performed through WebRiskServiceV1Beta1Client.
Create a client instance by calling the static Create
or CreateAsync
methods. Alternatively,
use the builder class associated with each client class (e.g. WebRiskServiceV1Beta1ClientBuilder for WebRiskServiceV1Beta1Client)
as an easy way of specifying custom credentials, settings, or a custom endpoint. Clients are thread-safe,
and we recommend using a single instance across your entire application unless you have a particular need
to configure multiple client objects separately.
Using the REST (HTTP/1.1) transport
This library defaults to performing RPCs using gRPC using the binary Protocol Buffer wire format.
However, it also supports HTTP/1.1 and JSON, for situations where gRPC doesn't work as desired. (This is typically due to an incompatible proxy
or other network issue.) To create a client using HTTP/1.1, specify a RestGrpcAdapter
reference for the GrpcAdapter
property in the client builder.
Sample code:
var client = new WebRiskServiceV1Beta1ClientBuilder
{
GrpcAdapter = RestGrpcAdapter.Default
}.Build();
For more details, see the transport selection page.
Samples
Searching for threats by URL
WebRiskServiceV1Beta1Client client = WebRiskServiceV1Beta1Client.Create();
SearchUrisResponse response = client.SearchUris(
"http://testsafebrowsing.appspot.com/s/malware.html",
new[] { ThreatType.Malware, ThreatType.SocialEngineering });
ThreatUri threat = response.Threat;
if (threat == null)
{
Console.WriteLine("No threat detected");
}
else
{
Console.WriteLine($"Threat types: {string.Join(", ", threat.ThreatTypes)}");
Console.WriteLine($"Cache lifetime expiry: {threat.ExpireTime}");
}
Searching for threats by hash prefix
WebRiskServiceV1Beta1Client client = WebRiskServiceV1Beta1Client.Create();
ByteString hashPrefix = ByteString.CopyFrom(new byte[] { 0x5b, 0x0b, 0x89, 0x75 });
SearchHashesResponse response = client.SearchHashes(
hashPrefix,
new[] { ThreatType.Malware, ThreatType.SocialEngineering });
if (response.NegativeExpireTime != null)
{
Console.WriteLine($"Cache expiry for negative response: {response.NegativeExpireTime}");
}
foreach (ThreatHash threat in response.Threats)
{
string hexHash = BitConverter.ToString(threat.Hash.ToByteArray()).Replace("-", "");
Console.WriteLine($"Hash {hexHash}");
Console.WriteLine($"Threat types: {string.Join(", ", threat.ThreatTypes)}");
Console.WriteLine($"Cache lifetime expiry: {threat.ExpireTime}");
}