001/*
002 * Licensed to DuraSpace under one or more contributor license agreements.
003 * See the NOTICE file distributed with this work for additional information
004 * regarding copyright ownership.
005 *
006 * DuraSpace licenses this file to you under the Apache License,
007 * Version 2.0 (the "License"); you may not use this file except in
008 * compliance with the License.  You may obtain a copy of the License at
009 *
010 *     http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018package org.fcrepo.kernel.api.operations;
019
020import org.fcrepo.kernel.api.identifiers.FedoraId;
021
022import static org.fcrepo.kernel.api.operations.ResourceOperationType.CREATE;
023
024/**
025 * Operation for creating a resource
026 *
027 * @author bbpennel
028 */
029public interface CreateResourceOperation extends ResourceOperation {
030
031    /**
032     * Get the identifier of the parent of the resource being created
033     *
034     * @return identifer of parent
035     */
036    FedoraId getParentId();
037
038    /**
039     * Get the interaction model of the resource being created
040     *
041     * @return interaction model
042     */
043    String getInteractionModel();
044
045    @Override
046    public default ResourceOperationType getType() {
047        return CREATE;
048    }
049
050    /**
051     * A flag indicating whether or the new resource should be created as an archival group.
052     * @return true if archival group
053     */
054    boolean isArchivalGroup();
055}