Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
C
console
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
MyCard
console
Commits
1685dac9
Commit
1685dac9
authored
Oct 26, 2022
by
nanahira
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
async middleware download support
parent
9f488f78
Pipeline
#17453
passed with stages
in 6 minutes and 47 seconds
Changes
3
Pipelines
1
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
50 additions
and
21 deletions
+50
-21
console-api/src/entities/Archive.entity.ts
console-api/src/entities/Archive.entity.ts
+1
-1
console-api/src/mirror/mirror.service.ts
console-api/src/mirror/mirror.service.ts
+48
-19
console-api/views/metalinks.mustache
console-api/views/metalinks.mustache
+1
-1
No files found.
console-api/src/entities/Archive.entity.ts
View file @
1685dac9
...
...
@@ -38,7 +38,7 @@ export class Archive extends TimeBase {
role
:
ArchiveType
;
// should not be a relation
mirrors
:
ArchiveMirror
[];
mirrors
:
string
[];
get
archiveFullPath
()
{
return
`
${
this
.
path
}
.tar.zst`
;
...
...
console-api/src/mirror/mirror.service.ts
View file @
1685dac9
...
...
@@ -11,14 +11,11 @@ import { PackageS3Service } from '../package-s3/package-s3.service';
import
_
from
'
lodash
'
;
import
delay
from
'
delay
'
;
export
interface
MiddlewareInfo
{
identifier
:
string
;
maxSize
?:
number
;
}
export
interface
Middleware
{
url
:
string
;
info
:
MiddlewareInfo
;
identifier
:
string
;
maxSize
?:
number
;
callback
?:
string
;
}
export
interface
UploadInfo
{
...
...
@@ -35,7 +32,7 @@ export interface UploadResult {
@
Injectable
()
export
class
MirrorService
extends
ConsoleLogger
{
private
middlewares
:
Middleware
[]
=
[]
;
private
middlewares
=
new
Map
<
string
,
Middleware
>
()
;
private
maximumMirroredSize
=
0xffffffff
;
constructor
(
@
InjectConnection
(
'
app
'
)
...
...
@@ -57,9 +54,9 @@ export class MirrorService extends ConsoleLogger {
for
(
const
url
of
middlewares
)
{
try
{
this
.
log
(
`Loading middleware
${
url
}
`
);
const
{
data
}
=
await
lastValueFrom
(
this
.
http
.
get
<
ReturnMessage
<
Middleware
Info
>>
(
url
,
{
responseType
:
'
json
'
}));
const
middleware
:
Middleware
=
{
url
,
info
:
data
.
data
};
this
.
middlewares
.
push
(
middleware
);
const
{
data
}
=
await
lastValueFrom
(
this
.
http
.
get
<
ReturnMessage
<
Middleware
>>
(
url
,
{
responseType
:
'
json
'
}));
const
middleware
:
Middleware
=
{
...
data
.
data
,
url
};
this
.
middlewares
.
set
(
data
.
data
.
identifier
,
middleware
);
if
(
data
.
data
.
maxSize
)
{
this
.
maximumMirroredSize
=
Math
.
min
(
this
.
maximumMirroredSize
,
data
.
data
.
maxSize
);
}
...
...
@@ -68,7 +65,7 @@ export class MirrorService extends ConsoleLogger {
this
.
log
(
`Loading middleware
${
url
}
failed:
${
e
.
toString
()}
`
);
}
}
if
(
this
.
middlewares
.
length
)
{
if
(
this
.
middlewares
.
size
)
{
this
.
mainLoop
().
then
();
}
}
...
...
@@ -83,14 +80,14 @@ export class MirrorService extends ConsoleLogger {
};
return
_
.
compact
(
await
Promise
.
all
(
this
.
middlewares
.
map
(
async
(
middleware
)
=>
{
Array
.
from
(
this
.
middlewares
.
values
())
.
map
(
async
(
middleware
)
=>
{
const
result
=
await
this
.
uploadWithMiddleware
(
uploadInfo
,
middleware
);
if
(
!
result
)
{
return
null
;
}
const
mirrorEnt
=
new
ArchiveMirror
();
mirrorEnt
.
path
=
archive
.
path
;
mirrorEnt
.
middleware
=
middleware
.
i
nfo
.
i
dentifier
;
mirrorEnt
.
middleware
=
middleware
.
identifier
;
mirrorEnt
.
url
=
result
.
url
;
return
mirrorEnt
;
})
...
...
@@ -156,7 +153,7 @@ export class MirrorService extends ConsoleLogger {
private
async
uploadWithMiddleware
(
uploadInfo
:
UploadInfo
,
middleware
:
Middleware
):
Promise
<
UploadResult
>
{
try
{
this
.
log
(
`Uploading
${
uploadInfo
.
url
}
with middleware
${
middleware
.
i
nfo
.
i
dentifier
}
.`
);
this
.
log
(
`Uploading
${
uploadInfo
.
url
}
with middleware
${
middleware
.
identifier
}
.`
);
const
{
data
}
=
await
lastValueFrom
(
this
.
http
.
post
<
ReturnMessage
<
string
>>
(
middleware
.
url
,
uploadInfo
,
{
responseType
:
'
json
'
,
timeout
:
60
*
60
*
1000
})
);
...
...
@@ -166,12 +163,12 @@ export class MirrorService extends ConsoleLogger {
middleware
,
};
}
catch
(
e
)
{
this
.
error
(
`Failed uploading
${
uploadInfo
.
url
}
with middleware
${
middleware
.
i
nfo
.
i
dentifier
}
:
${
e
.
toString
()}
${
e
.
data
}
`
);
this
.
error
(
`Failed uploading
${
uploadInfo
.
url
}
with middleware
${
middleware
.
identifier
}
:
${
e
.
toString
()}
${
e
.
data
}
`
);
return
null
;
}
}
async
uploadWithRandomMiddleware
(
uploadInfo
:
UploadInfo
,
middlewares
=
this
.
middlewares
)
{
async
uploadWithRandomMiddleware
(
uploadInfo
:
UploadInfo
,
middlewares
=
Array
.
from
(
this
.
middlewares
.
values
())
)
{
if
(
!
middlewares
.
length
)
{
return
null
;
}
...
...
@@ -182,17 +179,49 @@ export class MirrorService extends ConsoleLogger {
}
return
this
.
uploadWithRandomMiddleware
(
uploadInfo
,
middlewares
.
filter
((
m
)
=>
m
.
i
nfo
.
identifier
!==
middleware
.
info
.
identifier
)
middlewares
.
filter
((
m
)
=>
m
.
i
dentifier
!==
middleware
.
identifier
)
);
}
async
getMirrorUrl
(
mirror
:
ArchiveMirror
):
Promise
<
string
>
{
const
middleware
=
this
.
middlewares
.
get
(
mirror
.
middleware
);
if
(
!
middleware
)
{
return
;
}
if
(
!
middleware
.
callback
)
{
return
mirror
.
url
;
}
try
{
const
{
data
}
=
await
lastValueFrom
(
this
.
http
.
patch
<
{
url
:
string
}
>
(
middleware
.
url
,
mirror
,
{
responseType
:
'
json
'
,
timeout
:
30000
})
);
return
data
.
url
;
}
catch
(
e
)
{
this
.
error
(
`Failed getting mirror url for
${
mirror
.
path
}
with middleware
${
middleware
.
identifier
}
:
${
e
.
toString
()}
`
);
return
;
}
}
async
lookForArchiveMirror
(
archive
:
Archive
)
{
if
(
archive
.
size
>
this
.
maximumMirroredSize
)
{
return
;
}
const
mirrors
=
await
this
.
db
.
getRepository
(
ArchiveMirror
).
find
({
where
:
{
path
:
archive
.
path
,
disabled
:
false
},
select
:
[
'
url
'
]
});
const
mirrors
=
await
this
.
db
.
getRepository
(
ArchiveMirror
)
.
find
({
where
:
{
path
:
archive
.
path
,
disabled
:
false
},
select
:
[
'
url
'
,
'
middleware
'
,
'
path
'
]
});
if
(
mirrors
.
length
)
{
archive
.
mirrors
=
mirrors
;
const
urls
:
string
[]
=
[];
await
Promise
.
all
(
mirrors
.
map
(
async
(
m
)
=>
{
const
url
=
await
this
.
getMirrorUrl
(
m
);
if
(
url
)
{
urls
.
push
(
url
);
}
})
);
if
(
urls
.
length
)
{
archive
.
mirrors
=
urls
;
}
}
return
archive
;
}
...
...
console-api/views/metalinks.mustache
View file @
1685dac9
...
...
@@ -7,7 +7,7 @@
<hash
type=
"sha-256"
>
{{
.
}}
</hash>
{{/
hash
}}
{{#
mirrors
}}
<url
priority=
"1"
>
{{&
url
}}
</url>
<url
priority=
"1"
>
{{&
.
}}
</url>
{{/
mirrors
}}
<url
priority=
"2"
>
{{&
cdnUrl
}}
/
{{
path
}}
.tar.zst
</url>
</file>
...
...
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