Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
K
koishi-plugin-xff
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
3rdeye
koishi-plugin-xff
Commits
40b413db
Commit
40b413db
authored
Jul 25, 2022
by
nanahira
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bump to Koishi 4.8
parent
c21fcc7f
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
1022 additions
and
388 deletions
+1022
-388
dev/index.ts
dev/index.ts
+5
-5
package-lock.json
package-lock.json
+997
-371
package.json
package.json
+6
-6
src/index.ts
src/index.ts
+2
-2
tests/sample.spec.ts
tests/sample.spec.ts
+4
-4
webpack.config.js
webpack.config.js
+8
-0
No files found.
dev/index.ts
View file @
40b413db
import
{
App
}
from
'
koishi
'
;
import
{
Context
}
from
'
koishi
'
;
import
TargetPlugin
from
'
../src
'
;
import
TargetPlugin
from
'
../src
'
;
import
ConsolePlugin
from
'
@koishijs/plugin-console
'
;
import
ConsolePlugin
from
'
@koishijs/plugin-console
'
;
import
SandboxPlugin
from
'
@koishijs/plugin-sandbox
'
;
import
SandboxPlugin
from
'
@koishijs/plugin-sandbox
'
;
import
*
as
DatabasePlugin
from
'
@koishijs/plugin-database-memory
'
;
import
DatabasePlugin
from
'
@koishijs/plugin-database-memory
'
;
import
CachePlugin
from
'
@koishijs/plugin-cache-lru
'
;
//
import CachePlugin from '@koishijs/plugin-cache-lru';
import
ExtrasInDev
from
'
./extras
'
;
import
ExtrasInDev
from
'
./extras
'
;
const
app
=
new
App
({
const
app
=
new
Context
({
port
:
14514
,
port
:
14514
,
host
:
'
localhost
'
,
host
:
'
localhost
'
,
prefix
:
'
.
'
,
prefix
:
'
.
'
,
...
@@ -19,7 +19,7 @@ app.plugin(ConsolePlugin, {
...
@@ -19,7 +19,7 @@ app.plugin(ConsolePlugin, {
});
});
// Some services
// Some services
app
.
plugin
(
CachePlugin
);
//
app.plugin(CachePlugin);
app
.
plugin
(
DatabasePlugin
);
app
.
plugin
(
DatabasePlugin
);
// Some extras
// Some extras
...
...
package-lock.json
View file @
40b413db
This diff is collapsed.
Click to expand it.
package.json
View file @
40b413db
...
@@ -45,21 +45,21 @@
...
@@ -45,21 +45,21 @@
},
},
"dependencies"
:
{
"dependencies"
:
{
"
koa-trust-proxy
"
:
"
^0.1.4
"
,
"
koa-trust-proxy
"
:
"
^0.1.4
"
,
"
koishi-thirdeye
"
:
"
^1
0.3.2
"
"
koishi-thirdeye
"
:
"
^1
1.0.6
"
},
},
"peerDependencies"
:
{
"peerDependencies"
:
{
"koishi"
:
"^4.
7.5
"
"koishi"
:
"^4.
8.2
"
},
},
"devDependencies"
:
{
"devDependencies"
:
{
"
@koishijs/plugin-cache-lru
"
:
"
^1.0.0-rc.0
"
,
"
@koishijs/plugin-console
"
:
"
^4.1.1
"
,
"
@koishijs/plugin-console
"
:
"
^3.3.2
"
,
"
@koishijs/plugin-database-memory
"
:
"
^1.4.1
"
,
"
@koishijs/plugin-database-memory
"
:
"
^1.3.0
"
,
"
@koishijs/plugin-sandbox
"
:
"
^2.0.1
"
,
"
@koishijs/plugin-sandbox
"
:
"
^1.1.3
"
,
"
@types/jest
"
:
"
^27.4.1
"
,
"
@types/jest
"
:
"
^27.4.1
"
,
"
@types/node
"
:
"
^17.0.23
"
,
"
@types/node
"
:
"
^17.0.23
"
,
"
@types/supertest
"
:
"
^2.0.12
"
,
"
@types/supertest
"
:
"
^2.0.12
"
,
"
@typescript-eslint/eslint-plugin
"
:
"
^4.33.0
"
,
"
@typescript-eslint/eslint-plugin
"
:
"
^4.33.0
"
,
"
@typescript-eslint/parser
"
:
"
^4.33.0
"
,
"
@typescript-eslint/parser
"
:
"
^4.33.0
"
,
"
esbuild-loader
"
:
"
^2.19.0
"
,
"
eslint
"
:
"
^7.32.0
"
,
"
eslint
"
:
"
^7.32.0
"
,
"
eslint-config-prettier
"
:
"
^8.5.0
"
,
"
eslint-config-prettier
"
:
"
^8.5.0
"
,
"
eslint-plugin-prettier
"
:
"
^3.4.1
"
,
"
eslint-plugin-prettier
"
:
"
^3.4.1
"
,
...
...
src/index.ts
View file @
40b413db
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
import
{
XffPluginConfig
}
from
'
./config
'
;
import
{
XffPluginConfig
}
from
'
./config
'
;
import
{
import
{
DefinePlugin
,
DefinePlugin
,
Base
Plugin
,
Starter
Plugin
,
LifecycleEvents
,
LifecycleEvents
,
Inject
,
Inject
,
}
from
'
koishi-thirdeye
'
;
}
from
'
koishi-thirdeye
'
;
...
@@ -11,7 +11,7 @@ import { Router } from 'koishi';
...
@@ -11,7 +11,7 @@ import { Router } from 'koishi';
@
DefinePlugin
({
name
:
'
xff
'
,
schema
:
XffPluginConfig
})
@
DefinePlugin
({
name
:
'
xff
'
,
schema
:
XffPluginConfig
})
export
default
class
XffPlugin
export
default
class
XffPlugin
extends
BasePlugin
<
XffPluginConfig
>
extends
StarterPlugin
(
XffPluginConfig
)
implements
LifecycleEvents
implements
LifecycleEvents
{
{
@
Inject
(
true
)
@
Inject
(
true
)
...
...
tests/sample.spec.ts
View file @
40b413db
import
{
App
}
from
'
koishi
'
;
import
{
Context
}
from
'
koishi
'
;
import
TargetPlugin
from
'
../src
'
;
import
TargetPlugin
from
'
../src
'
;
import
request
from
'
supertest
'
;
import
request
from
'
supertest
'
;
describe
(
'
Test of plugin.
'
,
()
=>
{
describe
(
'
Test of plugin.
'
,
()
=>
{
let
app
:
App
;
let
app
:
Context
;
beforeEach
(
async
()
=>
{
beforeEach
(
async
()
=>
{
app
=
new
App
();
app
=
new
Context
();
app
.
plugin
(
TargetPlugin
);
app
.
plugin
(
TargetPlugin
);
await
app
.
start
();
await
app
.
start
();
});
});
...
@@ -16,7 +16,7 @@ describe('Test of plugin.', () => {
...
@@ -16,7 +16,7 @@ describe('Test of plugin.', () => {
ctx
.
status
=
200
;
ctx
.
status
=
200
;
ctx
.
body
=
ctx
.
ip
;
ctx
.
body
=
ctx
.
ip
;
});
});
return
request
(
app
.
_httpServer
)
return
request
(
app
.
router
.
_http
)
.
get
(
'
/ip
'
)
.
get
(
'
/ip
'
)
.
set
(
'
x-forwarded-for
'
,
'
1.1.1.1,11.4.51.4
'
)
.
set
(
'
x-forwarded-for
'
,
'
1.1.1.1,11.4.51.4
'
)
.
expect
(
200
)
.
expect
(
200
)
...
...
webpack.config.js
View file @
40b413db
const
path
=
require
(
'
path
'
);
const
path
=
require
(
'
path
'
);
const
packgeInfo
=
require
(
'
./package.json
'
);
const
packgeInfo
=
require
(
'
./package.json
'
);
const
{
ESBuildMinifyPlugin
}
=
require
(
'
esbuild-loader
'
);
function
externalsFromDep
()
{
function
externalsFromDep
()
{
return
Object
.
fromEntries
(
return
Object
.
fromEntries
(
...
@@ -43,4 +44,11 @@ module.exports = {
...
@@ -43,4 +44,11 @@ module.exports = {
koishi
:
'
koishi
'
,
koishi
:
'
koishi
'
,
...(
packAll
?
{}
:
externalsFromDep
()),
...(
packAll
?
{}
:
externalsFromDep
()),
},
},
optimization
:
{
minimizer
:
[
new
ESBuildMinifyPlugin
({
keepNames
:
true
,
}),
],
},
};
};
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