blob: cd46a65db25f8d13b7f7d0228ad62a17a39ae8cd [file] [log] [blame]
/**
* @file ManipulateArchive.h
* ManipulateArchive class declaration
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef LIBMINIFI_INCLUDE_PROCESSORS_MANIPULATEARCHIVE_H_
#define LIBMINIFI_INCLUDE_PROCESSORS_MANIPULATEARCHIVE_H_
#include <list>
#include <string>
#include "FlowFileRecord.h"
#include "ArchiveMetadata.h"
#include "core/Processor.h"
#include "core/ProcessSession.h"
#include "FocusArchiveEntry.h"
#include "UnfocusArchiveEntry.h"
namespace org {
namespace apache {
namespace nifi {
namespace minifi {
namespace processors {
using logging::Logger;
class ManipulateArchive : public core::Processor {
public:
ManipulateArchive(std::string name, utils::Identifier uuid = utils::Identifier())
: core::Processor(name, uuid),
logger_(logging::LoggerFactory<ManipulateArchive>::getLogger()) {
}
virtual ~ManipulateArchive() = default;
static constexpr char const* ProcessorName = "ManipulateArchive";
// Supported operations
static char const* OPERATION_REMOVE;
static char const* OPERATION_COPY;
static char const* OPERATION_MOVE;
static char const* OPERATION_TOUCH;
// Supported Properties
static core::Property Operation;
static core::Property Target;
static core::Property Destination;
static core::Property Before;
static core::Property After;
// Supported Relationships
static core::Relationship Success;
static core::Relationship Failure;
// OnTrigger method, implemented by NiFi ManipulateArchive
void onTrigger(core::ProcessContext *context, core::ProcessSession *session);
void onSchedule(core::ProcessContext *context, core::ProcessSessionFactory *sessionFactory);
// Initialize, over write by NiFi ManipulateArchive
void initialize(void);
protected:
private:
// Logger
std::shared_ptr<Logger> logger_;
std::string before_, after_, operation_, destination_, targetEntry_;
};
REGISTER_RESOURCE(ManipulateArchive, "Performs an operation which manipulates an archive without needing to split the archive into multiple FlowFiles.");
} /* namespace processors */
} /* namespace minifi */
} /* namespace nifi */
} /* namespace apache */
} /* namespace org */
#endif // LIBMINIFI_INCLUDE_PROCESSORS_MANIPULATEARCHIVE_H_