![]() |
VOOZH | about |
dotnet add package SweetMeSoft.GCP --version 1.10.105
NuGet\Install-Package SweetMeSoft.GCP -Version 1.10.105
<PackageReference Include="SweetMeSoft.GCP" Version="1.10.105" />
<PackageVersion Include="SweetMeSoft.GCP" Version="1.10.105" />Directory.Packages.props
<PackageReference Include="SweetMeSoft.GCP" />Project file
paket add SweetMeSoft.GCP --version 1.10.105
#r "nuget: SweetMeSoft.GCP, 1.10.105"
#:package SweetMeSoft.GCP@1.10.105
#addin nuget:?package=SweetMeSoft.GCP&version=1.10.105Install as a Cake Addin
#tool nuget:?package=SweetMeSoft.GCP&version=1.10.105Install as a Cake Tool
Library with tools to interact with Google Cloud Platform (GCP) services.
SweetMeSoft.GCP is a library for .NET Standard 2.1 that simplifies interaction with Google Cloud services, specifically with BigQuery and Cloud Storage. It provides two main classes, BigQueryRepo and GCPStorage, which act as repositories to facilitate common operations.
BigQueryRepo is a generic repository for performing CRUD (Create, Read, Update, Delete) operations on Google BigQuery.
To use BigQueryRepo, you must first configure the credentials and project ID. You can do this in three ways:
By credentials file (JSON):
BigQueryRepo.CredentialsFileName = "path/to/your/credentials-file.json";
BigQueryRepo.ProjectId = "your-gcp-project-id";
By JSON content of credentials:
BigQueryRepo.CredentialsJson = "{ \"type\": \"service_account\", ... }";
BigQueryRepo.ProjectId = "your-gcp-project-id";
By Access Token:
BigQueryRepo.CredentialsToken = "your-access-token";
BigQueryRepo.ProjectId = "your-gcp-project-id";
Once configured, you can get the repository instance:
var repo = BigQueryRepo.Instance;
The repository uses a generic class T that must be decorated with the BigQueryTable attribute.
[BigQueryTable("my_dataset")]
public class MyEntity
{
public Guid Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
Insert an item:
await repo.InsertItem(new MyEntity { ... });
Get all items:
var all = await repo.GetAll<MyEntity>();
Query with conditions (LINQ):
var result = await repo.GetByField<MyEntity>(e => e.Age > 18);
Update:
await repo.Update(myEditedEntity, e => e.Id == myEditedEntity.Id);
Delete:
await repo.Delete<MyEntity>(e => e.Name == "John");
GCPStorage is a class for managing files in Google Cloud Storage.
To use GCPStorage, you must provide the path to the credentials file:
GCPStorage.CredentialsFileName = "path/to/your/credentials-file.json";
var storage = GCPStorage.Instance;
Upload a file:
var streamFile = new StreamFile("myfile.txt", memoryStream, ContentType.txt);
await storage.UploadFile("my-bucket", "path/inside/bucket", streamFile);
Download a file:
var downloadedFile = await storage.DownloadFile("my-bucket", "path/inside/bucket", "myfile.txt");
Delete a file:
await storage.DeleteFile("my-bucket", "path/inside/bucket", "myfile.txt");
Move a file:
await storage.MoveFile("source-bucket", "source/path", "destination-bucket", "destination/path", streamFile);
This project is under the MIT license.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 was computed. net5.0-windows net5.0-windows was computed. net6.0 net6.0 was computed. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 was computed. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
| .NET Core | netcoreapp3.0 netcoreapp3.0 was computed. netcoreapp3.1 netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.1 netstandard2.1 is compatible. |
| MonoAndroid | monoandroid monoandroid was computed. |
| MonoMac | monomac monomac was computed. |
| MonoTouch | monotouch monotouch was computed. |
| Tizen | tizen60 tizen60 was computed. |
| Xamarin.iOS | xamarinios xamarinios was computed. |
| Xamarin.Mac | xamarinmac xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos xamarinwatchos was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.