001package org.hl7.fhir.instance.model.api;
002
003/*
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2021 Smile CDR, Inc.
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 *
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 *
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023import java.util.Date;
024import java.util.List;
025
026public interface IBaseMetaType extends ICompositeType {
027
028        IBaseMetaType addProfile(String theProfile);
029
030        IBaseCoding addSecurity();
031
032        IBaseCoding addTag();
033
034        Date getLastUpdated();
035
036        List<? extends IPrimitiveType<String>> getProfile();
037
038        List<? extends IBaseCoding> getSecurity();
039
040        List<? extends IBaseCoding> getTag();
041
042        String getVersionId();
043
044        IBaseMetaType setLastUpdated(Date theHeaderDateValue);
045        
046        IBaseMetaType setVersionId(String theVersionId);
047
048        /**
049         * Returns the first tag (if any) that has the given system and code, or returns
050         * <code>null</code> if none
051         */
052        IBaseCoding getTag(String theSystem, String theCode);
053
054        /**
055         * Returns the first security label (if any) that has the given system and code, or returns
056         * <code>null</code> if none
057         */
058        IBaseCoding getSecurity(String theSystem, String theCode);
059
060
061}