Permission.java
/*
* onedrive-java-sdk - A Java SDK to access OneDrive drives and files.
* Copyright © 2023-2025 Andy Miles (andy.miles@amilesend.com)
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.amilesend.onedrive.resource.item.type;
import com.amilesend.client.parse.strategy.GsonExclude;
import com.amilesend.onedrive.connection.OneDriveConnection;
import com.amilesend.onedrive.resource.identity.IdentitySet;
import lombok.Builder;
import lombok.Data;
import java.util.List;
import static com.amilesend.onedrive.resource.item.DriveItem.DRIVE_ITEM_BASE_URL_PATH;
/**
* Describes sharing permissions granted for a drive item.
* <p>
* <a href="https://learn.microsoft.com/en-us/onedrive/developer/rest-api/resources/permission">
* API Documentation</a>.
* @see com.amilesend.onedrive.resource.item.DriveItem
*/
@Builder
@Data
public class Permission {
/** The permission identifier. */
private final String id;
/** Describes the users and applications for this permission. */
private final IdentitySet grantedTo;
/** Details of users to whom permission was granted for links. */
private final List<IdentitySet> grantedToIdentities;
/** Sharing invitation for this permission. */
private final SharingInvitation invitation;
/** Reference to the parent permission (if applicable). */
private final ItemReference inheritedFrom;
/** Link type permission details. */
private final SharingLink link;
/**
* The type of permission. Valid values include:
* <ul>
* <li>{@literal read}</li>
* <li>{@literal write}</li>
* <li>{@literal owner} - For SharePoint and Business</li>
* <li>{@literal member} - For SharePoint and Business</li>
* </ul>
*/
private final List<String> roles;
/** The token that can be used to access the shared item. */
private final String shareId;
/** The associated drive item identifier that this permission applies to. */
@GsonExclude
private final String driveItemId;
@GsonExclude
private final OneDriveConnection connection;
/**
* Deletes this permission.
*/
public void deletePermission() {
connection.execute(
connection.newRequestBuilder()
.url(new StringBuilder(connection.getBaseUrl())
.append(DRIVE_ITEM_BASE_URL_PATH)
.append(driveItemId)
.append("/permissions/")
.append(getId())
.toString())
.delete()
.build());
}
}