/** * Synapse REST API * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator) * * The version of the OpenAPI document: v1 * * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ import type { RestrictableObjectDescriptor } from './RestrictableObjectDescriptor'; /** * JSON schema for Lock Access Requirement, used to lock down the entity while waiting for ACT to review. * @export * @interface LockAccessRequirement */ export interface LockAccessRequirement { /** * The version number issued to this version on the object. * @type {number} * @memberof LockAccessRequirement */ versionNumber?: number; /** * The unique immutable ID. Provided by the system, the user may not set this field. * @type {number} * @memberof LockAccessRequirement */ id?: number; /** * Depricated. Replaced by name. * @type {string} * @memberof LockAccessRequirement */ description?: string; /** * Name of the AR. Limited to 50 characters and must be unique. Required. * @type {string} * @memberof LockAccessRequirement */ name?: string; /** * Synapse employs an Optimistic Concurrency Control (OCC) scheme to handle concurrent updates. Since the E-Tag changes every time an entity is updated it is used to detect when a client's current representation of an object is out-of-date. * @type {string} * @memberof LockAccessRequirement */ etag?: string; /** * The date this object was created. Provided by the system, the user may not set this field. * @type {string} * @memberof LockAccessRequirement */ createdOn?: string; /** * The date this object was last modified. Provided by the system, the user may not set this field. * @type {string} * @memberof LockAccessRequirement */ modifiedOn?: string; /** * The user that created this object. Provided by the system, the user may not set this field. * @type {string} * @memberof LockAccessRequirement */ createdBy?: string; /** * The user that last modified this object. Provided by the system, the user may not set this field. * @type {string} * @memberof LockAccessRequirement */ modifiedBy?: string; /** * Defaults to 'false'. When 'true', the subjects controlled by this AR are defined by the the'_accessRequirementIds' annotations on individual entities. This property is mutually exclusive with 'subjectIds'. If this is set to 'true' then 'subjectIds' must be excluded or empty. * @type {boolean} * @memberof LockAccessRequirement */ subjectsDefinedByAnnotations?: boolean; /** * The IDs of the items controlled by this Access Requirement when 'subjectsDefinedByAnnotations=false'. This property is mutually exclusive with 'subjectsDefinedByAnnotations'. When 'subjectsDefinedByAnnotations=true' then this property must be empty or excluded. Required when creating or updating and 'subjectsDefinedByAnnotations=false' or 'subjectsDefinedByAnnotations' is excluded. * @type {Array} * @memberof LockAccessRequirement */ subjectIds?: Array; /** * The enumeration of possible permission. * @type {string} * @memberof LockAccessRequirement */ accessType?: LockAccessRequirementAccessTypeEnum; /** * Indicates which type of AccessRequirement this object represents. Provided by the system, the user may not set this field. * @type {string} * @memberof LockAccessRequirement */ concreteType: LockAccessRequirementConcreteTypeEnum; /** * The key of the jira issue created for this Access Requirement. * @type {string} * @memberof LockAccessRequirement */ jiraKey?: string; } /** * @export */ export declare const LockAccessRequirementAccessTypeEnum: { readonly CREATE: "CREATE"; readonly READ: "READ"; readonly UPDATE: "UPDATE"; readonly DELETE: "DELETE"; readonly CHANGE_PERMISSIONS: "CHANGE_PERMISSIONS"; readonly DOWNLOAD: "DOWNLOAD"; readonly UPLOAD: "UPLOAD"; readonly PARTICIPATE: "PARTICIPATE"; readonly SUBMIT: "SUBMIT"; readonly READ_PRIVATE_SUBMISSION: "READ_PRIVATE_SUBMISSION"; readonly UPDATE_SUBMISSION: "UPDATE_SUBMISSION"; readonly DELETE_SUBMISSION: "DELETE_SUBMISSION"; readonly TEAM_MEMBERSHIP_UPDATE: "TEAM_MEMBERSHIP_UPDATE"; readonly SEND_MESSAGE: "SEND_MESSAGE"; readonly CHANGE_SETTINGS: "CHANGE_SETTINGS"; readonly MODERATE: "MODERATE"; readonly REVIEW_SUBMISSIONS: "REVIEW_SUBMISSIONS"; readonly EXEMPTION_ELIGIBLE: "EXEMPTION_ELIGIBLE"; }; export type LockAccessRequirementAccessTypeEnum = typeof LockAccessRequirementAccessTypeEnum[keyof typeof LockAccessRequirementAccessTypeEnum]; /** * @export */ export declare const LockAccessRequirementConcreteTypeEnum: { readonly org_sagebionetworks_repo_model_LockAccessRequirement: "org.sagebionetworks.repo.model.LockAccessRequirement"; }; export type LockAccessRequirementConcreteTypeEnum = typeof LockAccessRequirementConcreteTypeEnum[keyof typeof LockAccessRequirementConcreteTypeEnum]; /** * Check if a given object implements the LockAccessRequirement interface. */ export declare function instanceOfLockAccessRequirement(value: object): value is LockAccessRequirement; export declare function LockAccessRequirementFromJSON(json: any): LockAccessRequirement; export declare function LockAccessRequirementFromJSONTyped(json: any, ignoreDiscriminator: boolean): LockAccessRequirement; export declare function LockAccessRequirementToJSON(json: any): LockAccessRequirement; export declare function LockAccessRequirementToJSONTyped(value?: LockAccessRequirement | null, ignoreDiscriminator?: boolean): any;