mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-24 14:56:15 +02:00
2aa9cf34dd
It is a property of the configuration of a store --- how a store URL is parsed into a store config, not a store itself. Progress towards #10766
127 lines
3.2 KiB
C++
127 lines
3.2 KiB
C++
#pragma once
|
||
///@file
|
||
|
||
#include "binary-cache-store.hh"
|
||
|
||
#include <atomic>
|
||
|
||
namespace nix {
|
||
|
||
struct S3BinaryCacheStoreConfig : virtual BinaryCacheStoreConfig
|
||
{
|
||
std::string bucketName;
|
||
|
||
using BinaryCacheStoreConfig::BinaryCacheStoreConfig;
|
||
|
||
S3BinaryCacheStoreConfig(std::string_view uriScheme, std::string_view bucketName, const Params & params);
|
||
|
||
const Setting<std::string> profile{
|
||
this,
|
||
"",
|
||
"profile",
|
||
R"(
|
||
The name of the AWS configuration profile to use. By default
|
||
Nix will use the `default` profile.
|
||
)"};
|
||
|
||
protected:
|
||
|
||
constexpr static const char * defaultRegion = "us-east-1";
|
||
|
||
public:
|
||
|
||
const Setting<std::string> region{
|
||
this,
|
||
defaultRegion,
|
||
"region",
|
||
R"(
|
||
The region of the S3 bucket. If your bucket is not in
|
||
`us–east-1`, you should always explicitly specify the region
|
||
parameter.
|
||
)"};
|
||
|
||
const Setting<std::string> scheme{
|
||
this,
|
||
"",
|
||
"scheme",
|
||
R"(
|
||
The scheme used for S3 requests, `https` (default) or `http`. This
|
||
option allows you to disable HTTPS for binary caches which don't
|
||
support it.
|
||
|
||
> **Note**
|
||
>
|
||
> HTTPS should be used if the cache might contain sensitive
|
||
> information.
|
||
)"};
|
||
|
||
const Setting<std::string> endpoint{
|
||
this,
|
||
"",
|
||
"endpoint",
|
||
R"(
|
||
The URL of the endpoint of an S3-compatible service such as MinIO.
|
||
Do not specify this setting if you're using Amazon S3.
|
||
|
||
> **Note**
|
||
>
|
||
> This endpoint must support HTTPS and will use path-based
|
||
> addressing instead of virtual host based addressing.
|
||
)"};
|
||
|
||
const Setting<std::string> narinfoCompression{
|
||
this, "", "narinfo-compression", "Compression method for `.narinfo` files."};
|
||
|
||
const Setting<std::string> lsCompression{this, "", "ls-compression", "Compression method for `.ls` files."};
|
||
|
||
const Setting<std::string> logCompression{
|
||
this,
|
||
"",
|
||
"log-compression",
|
||
R"(
|
||
Compression method for `log/*` files. It is recommended to
|
||
use a compression method supported by most web browsers
|
||
(e.g. `brotli`).
|
||
)"};
|
||
|
||
const Setting<bool> multipartUpload{this, false, "multipart-upload", "Whether to use multi-part uploads."};
|
||
|
||
const Setting<uint64_t> bufferSize{
|
||
this, 5 * 1024 * 1024, "buffer-size", "Size (in bytes) of each part in multi-part uploads."};
|
||
|
||
const std::string name() override
|
||
{
|
||
return "S3 Binary Cache Store";
|
||
}
|
||
|
||
static std::set<std::string> uriSchemes()
|
||
{
|
||
return {"s3"};
|
||
}
|
||
|
||
std::string doc() override;
|
||
};
|
||
|
||
class S3BinaryCacheStore : public virtual BinaryCacheStore
|
||
{
|
||
protected:
|
||
|
||
S3BinaryCacheStore(const Params & params);
|
||
|
||
public:
|
||
|
||
struct Stats
|
||
{
|
||
std::atomic<uint64_t> put{0};
|
||
std::atomic<uint64_t> putBytes{0};
|
||
std::atomic<uint64_t> putTimeMs{0};
|
||
std::atomic<uint64_t> get{0};
|
||
std::atomic<uint64_t> getBytes{0};
|
||
std::atomic<uint64_t> getTimeMs{0};
|
||
std::atomic<uint64_t> head{0};
|
||
};
|
||
|
||
virtual const Stats & getS3Stats() = 0;
|
||
};
|
||
|
||
}
|