39 params.
stratum0 = *args.find(
'w')->second;
44 params.
repo_name = *args.find(
'N')->second;
46 if (args.find(
'T') != args.end()) {
47 params.
tar_file = *args.find(
'T')->second;
49 if (args.find(
'B') != args.end()) {
52 if (args.find(
'D') != args.end()) {
53 params.
to_delete = *args.find(
'D')->second;
56 if (args.find(
'O') != args.end()) {
60 if (args.find(
'e') != args.end()) {
63 PrintError(
"Swissknife Ingest: unknown hash algorithm");
67 if (args.find(
'Z') != args.end()) {
71 if (args.find(
'U') != args.end()) {
74 if (args.find(
'G') != args.end()) {
78 bool create_catalog = args.find(
'C') != args.end();
86 if (args.find(
'P') != args.end()) {
90 if (args.find(
'H') != args.end()) {
91 params.
key_file = *args.find(
'H')->second;
94 const bool upload_statsdb = (args.count(
'I') > 0);
117 params.
spooler = upload::Spooler::Construct(spooler_definition,
118 &publish_statistics);
119 if (NULL == params.
spooler)
return 3;
121 upload::Spooler::Construct(spooler_definition_catalogs,
122 &publish_statistics));
123 if (!spooler_catalogs.
IsValid())
return 3;
125 const bool follow_redirects = (args.count(
'L') > 0);
126 const string proxy = (args.count(
'@') > 0) ? *args.find(
'@')->second :
"";
158 const std::string old_root_hash = manifest->catalog_hash().ToString(
true);
166 catalog_manager.
Init();
177 "Swissknife Ingest: Initialization of the synchronisation "
186 "Swissknife Ingest: Adding contents of authz file %s to"
189 int fd = open(params.
authz_file.c_str(), O_RDONLY);
192 "Swissknife Ingest: Unable to open authz file (%s)"
193 "from the publication process: %s",
198 std::string new_authz;
202 if (!read_successful) {
204 "Swissknife Ingest: Failed to read authz file (%s): %s",
209 catalog_manager.SetVOMSAuthz(new_authz);
213 PrintError(
"Swissknife Ingest: something went wrong during sync");
215 if (upload_statsdb) {
222 "Published revision number");
223 revision_counter->
Set(catalog_manager.GetRootCatalog()->revision());
227 "Swissknife Ingest: Wait for all uploads to finish");
228 params.
spooler->WaitForUpload();
229 spooler_catalogs->WaitForUpload();
230 params.
spooler->FinalizeSession(
false);
233 "Swissknife Ingest: Exporting repository manifest");
239 const std::string new_root_hash = manifest->catalog_hash().ToString(
true);
241 if (!spooler_catalogs->FinalizeSession(
true, old_root_hash, new_root_hash,
243 PrintError(
"Swissknife Ingest: Failed to commit the transaction.");
245 if (upload_statsdb) {
252 if (upload_statsdb) {
259 PrintError(
"Swissknife Ingest: Failed to create new repository");
Counter * Register(const std::string &name, const std::string &desc)
Algorithms ParseCompressionAlgorithm(const std::string &algorithm_option)
size_t avg_file_chunk_size
const manifest::Manifest * manifest() const
DriverType driver_type
the type of the spooler driver
std::string GetGMTimestamp(const std::string &format)
bool UploadStatistics(upload::Spooler *spooler, std::string local_path="")
SpoolerDefinition Dup2DefaultCompression() const
bool generate_legacy_bulk_chunks
unsigned file_mbyte_limit
uint64_t max_concurrent_write_jobs
static const unsigned kDefaultFileMbyteLimit
virtual bool Initialize()
static const unsigned kDefaultNestedKcatalogLimit
static const unsigned kDefaultRootKcatalogLimit
size_t min_file_chunk_size
std::string spooler_definition
std::string manifest_path
zlib::Algorithms compression_alg
unsigned nested_kcatalog_limit
int Main(const ArgumentList &args)
unsigned int number_of_concurrent_uploads
int64_t String2Int64(const string &value)
std::string base_directory
void Set(const int64_t val)
const char kSuffixCatalog
upload::Spooler * spooler
static StatisticsDatabase * OpenStandardDB(const std::string repo_name)
bool SafeReadToString(int fd, std::string *final_result)
unsigned root_kcatalog_limit
size_t max_file_chunk_size
bool StorePublishStatistics(const perf::Statistics *statistics, const std::string &start_time, const bool success)
std::string session_token_file
bool ObtainDacReadSearchCapability()
virtual void Traverse()=0
std::map< char, SharedPtr< std::string > > ArgumentList
Algorithms ParseHashAlgorithm(const string &algorithm_option)
std::string TrimString(const std::string &path, const std::string &toTrim, const int trimMode)
Any MkFromHexPtr(const HexPtr hex, const char suffix)
std::string MakeCanonicalPath(const std::string &path)
void PrintError(const string &message)
const upload::Spooler * spooler_catalogs() const
CVMFS_EXPORT void LogCvmfs(const LogSource source, const int mask, const char *format,...)