Skip to content

Commit

Permalink
Prompt user to change default history permissions...
Browse files Browse the repository at this point in the history
... if picking a private object store for that history.
  • Loading branch information
jmchilton committed Mar 18, 2024
1 parent aa8f85a commit 48e9697
Show file tree
Hide file tree
Showing 5 changed files with 77 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import { prependPath } from "@/utils/redirect";
import { errorMessageAsString } from "@/utils/simple-error";
import SelectObjectStore from "@/components/ObjectStore/SelectObjectStore.vue";
import { getPermissions, type PermissionsResponse, isHistoryPrivate, makePrivate } from "@/components/History/services";
const props = defineProps({
userPreferredObjectStoreId: {
Expand Down Expand Up @@ -48,7 +49,26 @@ const emit = defineEmits<{
(e: "updated", id: string | null): void;
}>();
async function handleSubmit(preferredObjectStoreId: string | null) {
async function handleSubmit(preferredObjectStoreId: string | null, isPrivate: boolean) {
if (isPrivate) {
const { data } = await getPermissions(props.history.id);
const permissionResponse = data as PermissionsResponse;
const historyPrivate = await isHistoryPrivate(permissionResponse);
if (!historyPrivate) {
if (
confirm(
"Your history is set to create sharable datasets, but the target object store is private? Change the history configuration so new datasets are private by default?"
)
) {
try {
await makePrivate(props.history.id, permissionResponse);
} catch {
error.value = "Failed to update default permissions for history.";
}
}
}
}
const payload = { preferred_object_store_id: preferredObjectStoreId };
const url = prependPath(`api/histories/${props.history.id}`);
try {
Expand Down
9 changes: 4 additions & 5 deletions client/src/components/History/HistoryDatasetPermissions.vue
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
<script lang="ts" setup>
import axios from "axios";
import { computed, ref } from "vue";

Check failure on line 2 in client/src/components/History/HistoryDatasetPermissions.vue

View workflow job for this annotation

GitHub Actions / client-unit-test (18)

Run autofix to sort these imports!
import { initRefs, updateRefs, useCallbacks } from "@/composables/datasetPermissions";
import { withPrefix } from "@/utils/redirect";
import DatasetPermissionsForm from "@/components/Dataset/DatasetPermissionsForm.vue";
import { getPermissionsUrl, getPermissions, setPermissions } from "./services";
interface HistoryDatasetPermissionsProps {
historyId: string;
Expand All @@ -24,7 +23,7 @@ const {
} = initRefs();
const inputsUrl = computed(() => {
return `/history/permissions?id=${props.historyId}`;
return getPermissionsUrl(props.historyId);
});
const title = "Change default dataset permissions for history";
Expand All @@ -48,11 +47,11 @@ async function change(value: unknown) {
DATASET_MANAGE_PERMISSIONS: [managePermissionValue],
DATASET_ACCESS: access,
};
axios.put(withPrefix(inputsUrl.value), formValue).then(onSuccess).catch(onError);
setPermissions(props.historyId, formValue).then(onSuccess).catch(onError);
}
async function init() {
const { data } = await axios.get(withPrefix(inputsUrl.value));
const { data } = await getPermissions(props.historyId);
updateRefs(data.inputs, managePermissionsOptions, accessPermissionsOptions, managePermissions, accessPermissions);
loading.value = false;
}
Expand Down
37 changes: 37 additions & 0 deletions client/src/components/History/services.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
import axios from "axios";

Check failure on line 1 in client/src/components/History/services.ts

View workflow job for this annotation

GitHub Actions / client-unit-test (18)

Run autofix to sort these imports!
import { fetcher } from "@/api/schema";
import { type Input, permissionInputParts } from "@/composables/datasetPermissions";
import type Filtering from "@/utils/filtering";
import { withPrefix } from "@/utils/redirect";

const publishedHistoriesFetcher = fetcher.path("/api/histories/published").method("get").create();
export async function getPublishedHistories(
Expand Down Expand Up @@ -27,3 +30,37 @@ export async function getPublishedHistories(

return data;
}

export function getPermissionsUrl(historyId: string) {
return `/history/permissions?id=${historyId}`;
}

export interface PermissionsResponse {
inputs: Input[];
}

export function getPermissions(historyId: string) {
const permissionsUrl = getPermissionsUrl(historyId);
return axios.get(withPrefix(permissionsUrl));
}

export function setPermissions(historyId: string, formContents: object) {
const permissionsUrl = getPermissionsUrl(historyId);
return axios.put(withPrefix(permissionsUrl), formContents);
}

export function makePrivate(historyId: string, permissionResponse: PermissionsResponse) {
const { manageInput } = permissionInputParts(permissionResponse.inputs);
const managePermissionValue: number = manageInput.value[0] as number;
const access = [managePermissionValue];
const formValue = {
DATASET_MANAGE_PERMISSIONS: [managePermissionValue],
DATASET_ACCESS: access,
};
return setPermissions(historyId, formValue);
}

export async function isHistoryPrivate(permissionResponse: PermissionsResponse) {
const { accessInput } = permissionInputParts(permissionResponse.inputs);
return accessInput.value.length >= 1;
}
11 changes: 7 additions & 4 deletions client/src/components/ObjectStore/SelectObjectStore.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import { storeToRefs } from "pinia";
import { computed, ref } from "vue";
import { ConcreteObjectStoreModel } from "@/api";
import { useObjectStoreStore } from "@/stores/objectStoreStore";
import ObjectStoreSelectButton from "./ObjectStoreSelectButton.vue";
Expand Down Expand Up @@ -44,15 +45,17 @@ function variant(objectStoreId: string) {
}
const emit = defineEmits<{
(e: "onSubmit", id: string | null): void;
(e: "onSubmit", id: string | null, isPrivate: boolean): void;
}>();
const error = computed(() => {
return props.parentError || loadErrorMessage.value;
});
async function handleSubmit(preferredObjectStoreId: string) {
emit("onSubmit", preferredObjectStoreId);
async function handleSubmit(preferredObjectStore: ConcreteObjectStoreModel | null) {
const id: string | null = (preferredObjectStore ? preferredObjectStore.object_store_id : null) as string | null;
const isPrivate: boolean = preferredObjectStore ? preferredObjectStore.private : false;
emit("onSubmit", id, isPrivate);
}
</script>

Expand Down Expand Up @@ -81,7 +84,7 @@ async function handleSubmit(preferredObjectStoreId: string) {
:object-store="objectStore"
:variant="variant(objectStore.object_store_id)"
class="preferred-object-store-select-button"
@click="handleSubmit(objectStore.object_store_id)" />
@click="handleSubmit(objectStore)" />
</b-button-group>
</b-col>
<b-col cols="5">
Expand Down
11 changes: 8 additions & 3 deletions client/src/composables/datasetPermissions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ interface InputOption {
roleValue: number;
}

interface Input {
export interface Input {
value: number[];
options: [string, number][];
}
Expand Down Expand Up @@ -46,15 +46,20 @@ export function initRefs() {
};
}

export function permissionInputParts(inputs: Input[]) {
const manageInput: Input = inputs[0] as Input;
const accessInput: Input = inputs[1] as Input;
return { manageInput, accessInput };
}

export function updateRefs(
inputs: Input[],
managePermissionsOptions: Ref<InputOption[]>,
accessPermissionsOptions: Ref<InputOption[]>,
managePermissions: Ref<number[]>,
accessPermissions: Ref<number[]>
) {
const manageInput: Input = inputs[0] as Input;
const accessInput: Input = inputs[1] as Input;
const { manageInput, accessInput } = permissionInputParts(inputs);
managePermissionsOptions.value = manageInput.options.map((v: [string, number]) => {
return <InputOption>{ roleName: v[0], roleValue: v[1] };
});
Expand Down

0 comments on commit 48e9697

Please sign in to comment.