Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wiki-js
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jacklull
wiki-js
Commits
2e858547
Unverified
Commit
2e858547
authored
Jan 29, 2023
by
Eric Knibbe
Committed by
GitHub
Jan 29, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix(git): handle file renames between folders (#6020)
* git storage: handle file renames between folders --------- Co-authored-by:
Nicolas Giard
<
github@ngpixel.com
>
parent
8fa771c4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
21 additions
and
6 deletions
+21
-6
db.js
server/core/db.js
+0
-0
pages.js
server/models/pages.js
+2
-1
storage.js
server/modules/storage/disk/storage.js
+0
-0
storage.js
server/modules/storage/git/storage.js
+19
-5
No files found.
server/core/db.js
View file @
2e858547
server/models/pages.js
View file @
2e858547
...
...
@@ -725,7 +725,7 @@ module.exports = class Page extends Model {
const
destinationHash
=
pageHelper
.
generateHash
({
path
:
opts
.
destinationPath
,
locale
:
opts
.
destinationLocale
,
privateNS
:
opts
.
isPrivate
?
'TODO'
:
''
})
// -> Move page
const
destinationTitle
=
(
page
.
title
===
page
.
path
?
opts
.
destinationPath
:
page
.
title
)
const
destinationTitle
=
(
page
.
title
===
_
.
last
(
page
.
path
.
split
(
'/'
))
?
_
.
last
(
opts
.
destinationPath
.
split
(
'/'
))
:
page
.
title
)
await
WIKI
.
models
.
pages
.
query
().
patch
({
path
:
opts
.
destinationPath
,
localeCode
:
opts
.
destinationLocale
,
...
...
@@ -745,6 +745,7 @@ module.exports = class Page extends Model {
...
page
,
destinationPath
:
opts
.
destinationPath
,
destinationLocaleCode
:
opts
.
destinationLocale
,
title
:
destinationTitle
,
destinationHash
})
...
...
server/modules/storage/disk/storage.js
View file @
2e858547
server/modules/storage/git/storage.js
View file @
2e858547
...
...
@@ -146,10 +146,24 @@ module.exports = {
const
diff
=
await
this
.
git
.
diffSummary
([
'-M'
,
currentCommitLog
.
hash
,
latestCommitLog
.
hash
])
if
(
_
.
get
(
diff
,
'files'
,
[]).
length
>
0
)
{
let
filesToProcess
=
[]
const
filePattern
=
/
(
.*
?)(?:
{
(
.*
?))?
=>
(?:(
.*
?)
}
)?(
.*
)
/
for
(
const
f
of
diff
.
files
)
{
const
fMoved
=
f
.
file
.
split
(
' => '
)
const
fName
=
fMoved
.
length
===
2
?
fMoved
[
1
]
:
fMoved
[
0
]
const
fPath
=
path
.
join
(
this
.
repoPath
,
fName
)
const
fMatch
=
f
.
file
.
match
(
filePattern
)
const
fNames
=
{
old
:
null
,
new
:
null
}
if
(
!
fMatch
)
{
fNames
.
old
=
f
.
file
fNames
.
new
=
f
.
file
}
else
if
(
!
fMatch
[
2
]
&&
!
fMatch
[
3
])
{
fNames
.
old
=
fMatch
[
1
]
fNames
.
new
=
fMatch
[
4
]
}
else
{
fNames
.
old
=
(
fMatch
[
1
]
+
fMatch
[
2
]
+
fMatch
[
4
]).
replace
(
'//'
,
'/'
),
fNames
.
new
=
(
fMatch
[
1
]
+
fMatch
[
3
]
+
fMatch
[
4
]).
replace
(
'//'
,
'/'
)
}
const
fPath
=
path
.
join
(
this
.
repoPath
,
fNames
.
new
)
let
fStats
=
{
size
:
0
}
try
{
fStats
=
await
fs
.
stat
(
fPath
)
...
...
@@ -166,8 +180,8 @@ module.exports = {
path
:
fPath
,
stats
:
fStats
},
oldPath
:
f
Moved
[
0
]
,
relPath
:
fName
oldPath
:
f
Names
.
old
,
relPath
:
fName
s
.
new
})
}
await
this
.
processFiles
(
filesToProcess
,
rootUser
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment