/** * 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 Terms of Use Access Requirement, used for a 'tier 2' Access Requirement * @export * @interface SelfSignAccessRequirement */ export interface SelfSignAccessRequirement { /** * The version number issued to this version on the object. * @type {number} * @memberof SelfSignAccessRequirement */ versionNumber?: number; /** * The unique immutable ID. Provided by the system, the user may not set this field. * @type {number} * @memberof SelfSignAccessRequirement */ id?: number; /** * Depricated. Replaced by name. * @type {string} * @memberof SelfSignAccessRequirement */ description?: string; /** * Name of the AR. Limited to 50 characters and must be unique. Required. * @type {string} * @memberof SelfSignAccessRequirement */ 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 SelfSignAccessRequirement */ etag?: string; /** * The date this object was created. Provided by the system, the user may not set this field. * @type {string} * @memberof SelfSignAccessRequirement */ createdOn?: string; /** * The date this object was last modified. Provided by the system, the user may not set this field. * @type {string} * @memberof SelfSignAccessRequirement */ modifiedOn?: string; /** * The user that created this object. Provided by the system, the user may not set this field. * @type {string} * @memberof SelfSignAccessRequirement */ createdBy?: string; /** * The user that last modified this object. Provided by the system, the user may not set this field. * @type {string} * @memberof SelfSignAccessRequirement */ 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 SelfSignAccessRequirement */ 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 SelfSignAccessRequirement */ subjectIds?: Array; /** * The enumeration of possible permission. * @type {string} * @memberof SelfSignAccessRequirement */ accessType?: SelfSignAccessRequirementAccessTypeEnum; /** * Indicates which type of AccessRequirement this object represents. Provided by the system, the user may not set this field. * @type {string} * @memberof SelfSignAccessRequirement */ concreteType: SelfSignAccessRequirementConcreteTypeEnum; /** * If true, then accessor needs to be a Synapse Certified User to gain access. * @type {boolean} * @memberof SelfSignAccessRequirement */ isCertifiedUserRequired?: boolean; /** * If true, then accessor needs to have their Synapse Profile validated to gain access. * @type {boolean} * @memberof SelfSignAccessRequirement */ isValidatedProfileRequired?: boolean; } /** * @export */ export declare const SelfSignAccessRequirementAccessTypeEnum: { 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 SelfSignAccessRequirementAccessTypeEnum = typeof SelfSignAccessRequirementAccessTypeEnum[keyof typeof SelfSignAccessRequirementAccessTypeEnum]; /** * @export */ export declare const SelfSignAccessRequirementConcreteTypeEnum: { readonly org_sagebionetworks_repo_model_SelfSignAccessRequirement: "org.sagebionetworks.repo.model.SelfSignAccessRequirement"; }; export type SelfSignAccessRequirementConcreteTypeEnum = typeof SelfSignAccessRequirementConcreteTypeEnum[keyof typeof SelfSignAccessRequirementConcreteTypeEnum]; /** * Check if a given object implements the SelfSignAccessRequirement interface. */ export declare function instanceOfSelfSignAccessRequirement(value: object): value is SelfSignAccessRequirement; export declare function SelfSignAccessRequirementFromJSON(json: any): SelfSignAccessRequirement; export declare function SelfSignAccessRequirementFromJSONTyped(json: any, ignoreDiscriminator: boolean): SelfSignAccessRequirement; export declare function SelfSignAccessRequirementToJSON(json: any): SelfSignAccessRequirement; export declare function SelfSignAccessRequirementToJSONTyped(value?: SelfSignAccessRequirement | null, ignoreDiscriminator?: boolean): any;