Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix several issues when setting image and readme for spaces #6898

Merged
merged 3 commits into from
May 9, 2022
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions changelog/unreleased/bugfix-set-space-image-and-readme
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
Bugfix: Setting image and readme for spaces

* An issue where setting a space-image or -readme would corrupt the file list has been fixed.
* Setting images from within the `.space` folder has been fixed.
* Setting images and readme files with specials characters in their names has been fixed.

https://github.com/owncloud/web/pull/6898
https://github.com/owncloud/web/issues/6875
14 changes: 6 additions & 8 deletions packages/web-app-files/src/mixins/spaces/actions/setImage.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import { isLocationSpacesActive } from '../../../router'
import { clientService } from 'web-pkg/src/services'
import { mapMutations, mapActions, mapGetters, mapState } from 'vuex'
import { buildResource } from '../../../helpers/resources'
import { bus } from 'web-pkg/src/instance'
import { thumbnailService } from '../../../services'

export default {
Expand Down Expand Up @@ -54,19 +53,18 @@ export default {
}
},
methods: {
...mapMutations('Files', ['UPDATE_RESOURCE_FIELD']),
...mapMutations('Files', ['UPDATE_SPACE_FIELD']),
...mapActions(['showMessage']),
async $_setSpaceImage_trigger({ resources }) {
const graphClient = clientService.graphAuthenticated(this.configuration.server, this.getToken)
const storageId = this.$route.params.storageId
const sourcePath = resources[0].webDavPath
const destinationPath = `/spaces/${storageId}/.space/${resources[0].name}`

if (sourcePath === destinationPath) {
return
}
try {
await this.$client.files.copy(sourcePath, destinationPath)
if (sourcePath !== destinationPath) {
await this.$client.files.copy(sourcePath, destinationPath)
}
const fileInfo = await this.$client.files.fileInfo(destinationPath)
const file = buildResource(fileInfo)
const { data } = await graphClient.drives.updateDrive(
Expand All @@ -83,7 +81,8 @@ export default {
},
{}
)
this.UPDATE_RESOURCE_FIELD({

this.UPDATE_SPACE_FIELD({
id: storageId,
field: 'spaceImageData',
value: data.special.find((special) => special.specialFolder.name === 'image')
Expand All @@ -92,7 +91,6 @@ export default {
this.showMessage({
title: this.$gettext('Space image was set successfully')
})
bus.publish('app.files.list.load')
} catch (error) {
console.error(error)
this.showMessage({
Expand Down
16 changes: 6 additions & 10 deletions packages/web-app-files/src/mixins/spaces/actions/setReadme.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { isLocationSpacesActive } from '../../../router'
import { mapMutations, mapState, mapActions } from 'vuex'
import { bus } from 'web-pkg/src/instance'

export default {
inject: {
Expand All @@ -9,7 +8,7 @@ export default {
}
},
computed: {
...mapState('Files', ['currentFolder']),
...mapState('Files', ['currentFolder', 'spaces']),
...mapState(['user']),
$_setSpaceReadme_items() {
return [
Expand Down Expand Up @@ -48,26 +47,23 @@ export default {
}
},
methods: {
...mapMutations('Files', ['UPDATE_RESOURCE_FIELD']),
...mapMutations('Files', ['UPDATE_SPACE_FIELD']),
...mapActions(['showMessage']),
async $_setSpaceReadme_trigger({ resources }) {
const space = this.currentFolder

try {
const fileContent = await this.$client.files.getFileContents(resources[0].webDavPath)
const fileMetaData = await this.$client.files.putFileContents(
`/spaces/${space.id}/.space/readme.md`,
`/spaces/${this.space.id}/.space/readme.md`,
fileContent
)
this.UPDATE_RESOURCE_FIELD({
id: space.id,
this.UPDATE_SPACE_FIELD({
kulmann marked this conversation as resolved.
Show resolved Hide resolved
id: this.space.id,
field: 'spaceReadmeData',
value: { ...space.spaceReadmeData, ...{ etag: fileMetaData?.ETag } }
value: { ...this.space.spaceReadmeData, ...{ etag: fileMetaData?.ETag } }
})
this.showMessage({
title: this.$gettext('Space description was set successfully')
})
bus.publish('app.files.list.load')
} catch (error) {
console.error(error)
this.showMessage({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ export class FolderLoaderSpacesProject implements FolderLoader {
})

if (!sameRoute) {
ref.UPSERT_SPACE(space)
JammingBen marked this conversation as resolved.
Show resolved Hide resolved
ref.space = space
}
})
Expand Down
3 changes: 3 additions & 0 deletions packages/web-app-files/src/store/getters.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ export default {
files: (state) => {
return state.files
},
spaces: (state) => {
return state.spaces
},
filesAll: (state) => state.filesSearched || state.files,
currentFolder: (state) => {
return state.currentFolder
Expand Down
14 changes: 13 additions & 1 deletion packages/web-app-files/src/store/mutations.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,16 @@ export default {
Vue.set(spaceSource, index, newResource)
},
UPSERT_SPACE(state, space) {
state.spaces.push(space)
const spaces = [...state.spaces]
const index = spaces.findIndex((r) => r.id === space.id)
const found = index > -1

if (found) {
spaces.splice(index, 1, space)
} else {
spaces.push(space)
}
state.spaces = spaces
},
REMOVE_SPACE(state, space) {
state.spaces = state.spaces.filter((s) => s.id !== space.id)
Expand All @@ -51,6 +60,9 @@ export default {
SET_CURRENT_FOLDER(state, currentFolder) {
state.currentFolder = currentFolder
},
SET_CURRENT_SPACE(state, currentSpace) {
state.currentSpace = currentSpace
},
CLEAR_FILES(state) {
state.files = []
},
Expand Down
29 changes: 16 additions & 13 deletions packages/web-app-files/src/views/spaces/Project.vue
Original file line number Diff line number Diff line change
Expand Up @@ -265,19 +265,21 @@ export default defineComponent({
.slice(webDavPathComponents.indexOf(this.space.id) + 1)
.join('/')

this.$client.files.fileInfo(buildWebDavSpacesPath(this.space.id, path)).then((data) => {
const resource = buildResource(data)
loadPreview({
resource,
isPublic: false,
dimensions: ImageDimension.Preview,
server: this.configuration.server,
userId: this.user.id,
token: this.getToken
}).then((imageBlob) => {
this.imageContent = imageBlob
this.$client.files
.fileInfo(buildWebDavSpacesPath(this.space.id, decodeURIComponent(path)))
.then((data) => {
const resource = buildResource(data)
loadPreview({
resource,
isPublic: false,
dimensions: ImageDimension.Preview,
server: this.configuration.server,
userId: this.user.id,
token: this.getToken
}).then((imageBlob) => {
this.imageContent = imageBlob
})
})
})
},
deep: true
},
Expand All @@ -292,7 +294,7 @@ export default defineComponent({
.join('/')

this.$client.files
.getFileContents(buildWebDavSpacesPath(this.space.id, path))
.getFileContents(buildWebDavSpacesPath(this.space.id, decodeURIComponent(path)))
.then((fileContents) => {
if (this.markdownResizeObserver && this.$refs.markdownContainer) {
this.markdownResizeObserver.unobserve(this.$refs.markdownContainer)
Expand Down Expand Up @@ -338,6 +340,7 @@ export default defineComponent({
...mapMutations('Files', [
'SET_CURRENT_FOLDER',
'LOAD_FILES',
'UPSERT_SPACE',
'CLEAR_CURRENT_FILES_LIST',
'REMOVE_FILE',
'REMOVE_FILE_FROM_SEARCHED',
Expand Down
10 changes: 5 additions & 5 deletions packages/web-app-files/tests/unit/mixins/spaces/setImage.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import mockAxios from 'jest-mock-axios'
// eslint-disable-next-line jest/no-mocks-import
import sdkMock from '@/__mocks__/sdk'
import fileFixtures from '__fixtures__/files'
import { bus } from 'web-pkg/src/instance'
import { thumbnailService } from '../../../../src/services'
import { buildSpace } from '../../../../src/helpers/resources'

Expand Down Expand Up @@ -73,7 +72,7 @@ describe('setImage', () => {
Files: {
namespaced: true,
mutations: {
UPDATE_RESOURCE_FIELD: jest.fn()
UPDATE_SPACE_FIELD: jest.fn()
}
}
}
Expand Down Expand Up @@ -162,7 +161,6 @@ describe('setImage', () => {

const wrapper = getWrapper()
const showMessageStub = jest.spyOn(wrapper.vm, 'showMessage')
bus.publish = jest.fn((path) => path)
await wrapper.vm.$_setSpaceImage_trigger({
resources: [
{
Expand All @@ -173,7 +171,6 @@ describe('setImage', () => {
})

expect(showMessageStub).toHaveBeenCalledTimes(1)
expect(bus.publish).toHaveBeenCalledTimes(1)
})

it('should show message on error', async () => {
Expand All @@ -196,7 +193,10 @@ describe('setImage', () => {
expect(showMessageStub).toHaveBeenCalledTimes(1)
})

it('should not set the image if source and destination path are the same', async () => {
it('should not copy the image if source and destination path are the same', async () => {
mockAxios.request.mockImplementationOnce(() => {
return Promise.resolve({ data: { special: [{ specialFolder: { name: 'image' } }] } })
})
const wrapper = getWrapper()
await wrapper.vm.$_setSpaceImage_trigger({
resources: [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,7 @@ import setReadme from '@files/src/mixins/spaces/actions/setReadme.js'
import { createLocationSpaces } from '../../../../src/router'
// eslint-disable-next-line jest/no-mocks-import
import sdkMock from '@/__mocks__/sdk'
import { bus } from 'web-pkg/src/instance'
import { buildSpace } from '../../../../src/helpers/resources'

const localVue = createLocalVue()
localVue.use(Vuex)

Expand Down Expand Up @@ -36,6 +34,9 @@ describe('setReadme', () => {
.mockImplementation(() => Promise.resolve({ ETag: '60c7243c2e7f1' }))
}
},
$route: {
params: { storageId: 1 }
},
$router: {
currentRoute: createLocationSpaces('files-spaces-projects'),
resolve: (r) => {
Expand Down Expand Up @@ -72,7 +73,7 @@ describe('setReadme', () => {
Files: {
namespaced: true,
mutations: {
UPDATE_RESOURCE_FIELD: jest.fn()
UPDATE_SPACE_FIELD: jest.fn()
},
state: {
currentFolder: {
Expand Down Expand Up @@ -134,9 +135,8 @@ describe('setReadme', () => {
})
describe('method "$_setSpaceReadme_trigger"', () => {
it('should show message on success', async () => {
const wrapper = getWrapper()
const wrapper = getWrapper(true, { id: 1 })
const showMessageStub = jest.spyOn(wrapper.vm, 'showMessage')
bus.publish = jest.fn((path) => path)
await wrapper.vm.$_setSpaceReadme_trigger({
resources: [
{
Expand All @@ -147,12 +147,11 @@ describe('setReadme', () => {
})

expect(showMessageStub).toHaveBeenCalledTimes(1)
expect(bus.publish).toHaveBeenCalledTimes(1)
})

it('should show message on error', async () => {
jest.spyOn(console, 'error').mockImplementation(() => {})
const wrapper = getWrapper(false)
const wrapper = getWrapper(false, { id: 1 })
const showMessageStub = jest.spyOn(wrapper.vm, 'showMessage')
await wrapper.vm.$_setSpaceReadme_trigger({
resources: [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -280,6 +280,7 @@ function getMountedWrapper(spaceResources = [], spaceItem = null, imageContent =
mutations: {
CLEAR_CURRENT_FILES_LIST: jest.fn(),
CLEAR_FILES_SEARCHED: jest.fn(),
UPSERT_SPACE: jest.fn(),
LOAD_FILES: jest.fn()
},
actions: {
Expand Down