Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
e45b25ea
Unverified
Commit
e45b25ea
authored
Nov 18, 2022
by
Edward Thomson
Committed by
GitHub
Nov 18, 2022
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #6420 from derrickstolee/commit-graph-hashing
commit-graph: only verify csum on git_commit_graph_open().
parents
a3841af5
6de3221d
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
68 additions
and
10 deletions
+68
-10
src/libgit2/commit_graph.c
+24
-10
src/libgit2/commit_graph.h
+3
-0
tests/libgit2/graph/commitgraph.c
+41
-0
No files found.
src/libgit2/commit_graph.c
View file @
e45b25ea
...
@@ -200,8 +200,7 @@ int git_commit_graph_file_parse(
...
@@ -200,8 +200,7 @@ int git_commit_graph_file_parse(
const
unsigned
char
*
chunk_hdr
;
const
unsigned
char
*
chunk_hdr
;
struct
git_commit_graph_chunk
*
last_chunk
;
struct
git_commit_graph_chunk
*
last_chunk
;
uint32_t
i
;
uint32_t
i
;
off64_t
last_chunk_offset
,
chunk_offset
,
trailer_offset
;
uint64_t
last_chunk_offset
,
chunk_offset
,
trailer_offset
;
unsigned
char
checksum
[
GIT_HASH_SHA1_SIZE
];
size_t
checksum_size
;
size_t
checksum_size
;
int
error
;
int
error
;
struct
git_commit_graph_chunk
chunk_oid_fanout
=
{
0
},
chunk_oid_lookup
=
{
0
},
struct
git_commit_graph_chunk
chunk_oid_fanout
=
{
0
},
chunk_oid_lookup
=
{
0
},
...
@@ -234,16 +233,11 @@ int git_commit_graph_file_parse(
...
@@ -234,16 +233,11 @@ int git_commit_graph_file_parse(
return
commit_graph_error
(
"wrong commit-graph size"
);
return
commit_graph_error
(
"wrong commit-graph size"
);
memcpy
(
file
->
checksum
,
(
data
+
trailer_offset
),
checksum_size
);
memcpy
(
file
->
checksum
,
(
data
+
trailer_offset
),
checksum_size
);
if
(
git_hash_buf
(
checksum
,
data
,
(
size_t
)
trailer_offset
,
GIT_HASH_ALGORITHM_SHA1
)
<
0
)
return
commit_graph_error
(
"could not calculate signature"
);
if
(
memcmp
(
checksum
,
file
->
checksum
,
checksum_size
)
!=
0
)
return
commit_graph_error
(
"index signature mismatch"
);
chunk_hdr
=
data
+
sizeof
(
struct
git_commit_graph_header
);
chunk_hdr
=
data
+
sizeof
(
struct
git_commit_graph_header
);
last_chunk
=
NULL
;
last_chunk
=
NULL
;
for
(
i
=
0
;
i
<
hdr
->
chunks
;
++
i
,
chunk_hdr
+=
12
)
{
for
(
i
=
0
;
i
<
hdr
->
chunks
;
++
i
,
chunk_hdr
+=
12
)
{
chunk_offset
=
((
off
64_t
)
ntohl
(
*
((
uint32_t
*
)(
chunk_hdr
+
4
))))
<<
32
chunk_offset
=
((
uint
64_t
)
ntohl
(
*
((
uint32_t
*
)(
chunk_hdr
+
4
))))
<<
32
|
((
off
64_t
)
ntohl
(
*
((
uint32_t
*
)(
chunk_hdr
+
8
))));
|
((
uint
64_t
)
ntohl
(
*
((
uint32_t
*
)(
chunk_hdr
+
8
))));
if
(
chunk_offset
<
last_chunk_offset
)
if
(
chunk_offset
<
last_chunk_offset
)
return
commit_graph_error
(
"chunks are non-monotonic"
);
return
commit_graph_error
(
"chunks are non-monotonic"
);
if
(
chunk_offset
>=
trailer_offset
)
if
(
chunk_offset
>=
trailer_offset
)
...
@@ -331,9 +325,29 @@ error:
...
@@ -331,9 +325,29 @@ error:
return
error
;
return
error
;
}
}
int
git_commit_graph_validate
(
git_commit_graph
*
cgraph
)
{
unsigned
char
checksum
[
GIT_HASH_SHA1_SIZE
];
size_t
checksum_size
=
GIT_HASH_SHA1_SIZE
;
size_t
trailer_offset
=
cgraph
->
file
->
graph_map
.
len
-
checksum_size
;
if
(
cgraph
->
file
->
graph_map
.
len
<
checksum_size
)
return
commit_graph_error
(
"map length too small"
);
if
(
git_hash_buf
(
checksum
,
cgraph
->
file
->
graph_map
.
data
,
trailer_offset
,
GIT_HASH_ALGORITHM_SHA1
)
<
0
)
return
commit_graph_error
(
"could not calculate signature"
);
if
(
memcmp
(
checksum
,
cgraph
->
file
->
checksum
,
checksum_size
)
!=
0
)
return
commit_graph_error
(
"index signature mismatch"
);
return
0
;
}
int
git_commit_graph_open
(
git_commit_graph
**
cgraph_out
,
const
char
*
objects_dir
)
int
git_commit_graph_open
(
git_commit_graph
**
cgraph_out
,
const
char
*
objects_dir
)
{
{
return
git_commit_graph_new
(
cgraph_out
,
objects_dir
,
true
);
int
error
=
git_commit_graph_new
(
cgraph_out
,
objects_dir
,
true
);
if
(
!
error
)
{
return
git_commit_graph_validate
(
*
cgraph_out
);
}
return
error
;
}
}
int
git_commit_graph_file_open
(
git_commit_graph_file
**
file_out
,
const
char
*
path
)
int
git_commit_graph_file_open
(
git_commit_graph_file
**
file_out
,
const
char
*
path
)
...
...
src/libgit2/commit_graph.h
View file @
e45b25ea
...
@@ -106,6 +106,9 @@ struct git_commit_graph {
...
@@ -106,6 +106,9 @@ struct git_commit_graph {
/** Create a new commit-graph, optionally opening the underlying file. */
/** Create a new commit-graph, optionally opening the underlying file. */
int
git_commit_graph_new
(
git_commit_graph
**
cgraph_out
,
const
char
*
objects_dir
,
bool
open_file
);
int
git_commit_graph_new
(
git_commit_graph
**
cgraph_out
,
const
char
*
objects_dir
,
bool
open_file
);
/** Validate the checksum of a commit graph */
int
git_commit_graph_validate
(
git_commit_graph
*
cgraph
);
/** Open and validate a commit-graph file. */
/** Open and validate a commit-graph file. */
int
git_commit_graph_file_open
(
git_commit_graph_file
**
file_out
,
const
char
*
path
);
int
git_commit_graph_file_open
(
git_commit_graph_file
**
file_out
,
const
char
*
path
);
...
...
tests/libgit2/graph/commitgraph.c
View file @
e45b25ea
...
@@ -124,3 +124,44 @@ void test_graph_commitgraph__writer(void)
...
@@ -124,3 +124,44 @@ void test_graph_commitgraph__writer(void)
git_commit_graph_writer_free
(
w
);
git_commit_graph_writer_free
(
w
);
git_repository_free
(
repo
);
git_repository_free
(
repo
);
}
}
void
test_graph_commitgraph__validate
(
void
)
{
git_repository
*
repo
;
struct
git_commit_graph
*
cgraph
;
git_str
objects_dir
=
GIT_STR_INIT
;
cl_git_pass
(
git_repository_open
(
&
repo
,
cl_fixture
(
"testrepo.git"
)));
cl_git_pass
(
git_str_joinpath
(
&
objects_dir
,
git_repository_path
(
repo
),
"objects"
));
/* git_commit_graph_open() calls git_commit_graph_validate() */
cl_git_pass
(
git_commit_graph_open
(
&
cgraph
,
git_str_cstr
(
&
objects_dir
)));
git_commit_graph_free
(
cgraph
);
git_str_dispose
(
&
objects_dir
);
git_repository_free
(
repo
);
}
void
test_graph_commitgraph__validate_corrupt
(
void
)
{
git_repository
*
repo
;
struct
git_commit_graph
*
cgraph
;
int
fd
=
-
1
;
cl_fixture_sandbox
(
"testrepo.git"
);
cl_git_pass
(
git_repository_open
(
&
repo
,
cl_git_sandbox_path
(
1
,
"testrepo.git"
,
NULL
)));
/* corrupt commit graph checksum at the end of the file */
cl_assert
((
fd
=
p_open
(
cl_git_sandbox_path
(
0
,
"testrepo.git"
,
"objects"
,
"info"
,
"commit-graph"
,
NULL
),
O_WRONLY
))
>
0
);
cl_assert
(
p_lseek
(
fd
,
-
5
,
SEEK_END
)
>
0
);
cl_must_pass
(
p_write
(
fd
,
"
\0\0
"
,
2
));
cl_must_pass
(
p_close
(
fd
));
/* git_commit_graph_open() calls git_commit_graph_validate() */
cl_git_fail
(
git_commit_graph_open
(
&
cgraph
,
cl_git_sandbox_path
(
1
,
"testrepo.git"
,
"objects"
,
NULL
)));
git_commit_graph_free
(
cgraph
);
git_repository_free
(
repo
);
cl_fixture_cleanup
(
"testrepo.git"
);
}
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