应用程序

Application(应用程序)

Application 类承担了将 AdonisJS 应用程序各个部分连接在一起的重任。你可以使用此类来了解应用程序运行的环境、获取应用程序的当前状态或创建指向特定目录的路径。

另请参阅:应用程序生命周期

环境

环境指的是应用程序运行时环境。应用程序总是在以下已知环境之一中启动。

  • web 环境指的是为 HTTP 服务器启动的进程。

  • console 环境指的是 Ace 命令(除了 REPL 命令)。

  • repl 环境指的是使用 node ace repl 命令启动的进程。

  • 最后,test 环境指的是使用 node ace test 命令启动的进程。

你可以使用 getEnvironment 方法访问应用程序环境。

import app from '@adonisjs/core/services/app'
console.log(app.getEnvironment())

你还可以在应用程序启动之前切换应用程序环境。一个很好的例子是 REPL 命令。

node ace repl 命令在 console 环境中启动应用程序,但该命令在呈现 REPL 提示符之前,会将环境内部切换为 repl

if (!app.isBooted) {
app.setEnvironment('repl')
}

Node 环境

你可以使用 nodeEnvironment 属性访问 Node.js 环境。该值是对 NODE_ENV 环境变量的引用。不过,该值会进一步规范化以保持一致性。

import app from '@adonisjs/core/services/app'
console.log(app.nodeEnvironment)
NODE_ENV规范化为
devdevelopment
developdevelopment
stagestaging
prodproduction
testingtest

此外,你可以使用以下属性作为简写来了解当前环境。

  • inProduction:检查应用程序是否在生产环境中运行。
  • inDev:检查应用程序是否在开发环境中运行。
  • inTest:检查应用程序是否在测试环境中运行。
import app from '@adonisjs/core/services/app'
// 是否在生产环境中
app.inProduction
app.nodeEnvironment === 'production'
// 是否在开发环境中
app.inDev
app.nodeEnvironment === 'development'
// 是否在测试环境中
app.inTest
app.nodeEnvironment === 'test'

状态

状态指的是应用程序的当前状态。你可以访问的框架功能在很大程度上取决于应用程序的当前状态。例如,在应用程序处于 booted 状态之前,你无法访问容器绑定容器服务

应用程序总是处于以下已知状态之一。

  • created:这是应用程序的默认状态。

  • initiated:在此状态下,我们解析/验证环境变量并处理 adonisrc.ts 文件。

  • booted:在此状态下,应用程序服务提供者已注册并启动。

  • ready:就绪状态在不同的环境中有所不同。例如,在 web 环境中,就绪状态意味着应用程序已准备好接受新的 HTTP 请求。

  • terminated:应用程序已终止,进程将很快退出。在 web 环境中,应用程序将不再接受新的 HTTP 请求。

import app from '@adonisjs/core/services/app'
console.log(app.getState())

你还可以使用以下简写属性来了解应用程序是否处于给定状态。

import app from '@adonisjs/core/services/app'
// 应用程序已启动
app.isBooted
app.getState() !== 'created' && app.getState() !== 'initiated'
// 应用程序已就绪
app.isReady
app.getState() === 'ready'
// 正在尝试优雅地终止应用程序
app.isTerminating
// 应用程序已终止
app.isTerminated
app.getState() === 'terminated'

监听进程信号

你可以使用 app.listenapp.listenOnce 方法监听 POSIX 信号。在底层,我们将监听器注册到 Node.js 的 process 对象。

import app from '@adonisjs/core/services/app'
// 监听 SIGTERM 信号
app.listen('SIGTERM', () => {
})
// 一次性监听 SIGTERM 信号
app.listenOnce('SIGTERM', () => {
})

有时,你可能希望有条件地注册监听器。例如,在 pm2 环境中运行时监听 SIGINT 信号。

你可以使用 listenIflistenOnceIf 方法有条件地注册监听器。仅当第一个参数的值为真时,才会注册监听器。

import app from '@adonisjs/core/services/app'
app.listenIf(app.managedByPm2, 'SIGTERM', () => {
})
app.listenOnceIf(app.managedByPm2, 'SIGTERM', () => {
})

通知父进程

如果你的应用程序作为子进程启动,你可以使用 app.notify 方法向父进程发送消息。在底层,我们使用 process.send 方法。

import app from '@adonisjs/core/services/app'
app.notify('ready')
app.notify({
isReady: true,
port: 3333,
host: 'localhost'
})

创建项目文件的 URL 和路径

我们强烈建议你使用以下辅助方法,而不是自行构建项目文件的绝对 URL 或路径。

makeURL

make URL 方法返回项目根目录中给定文件或目录的文件 URL。例如,你可以在导入文件时生成 URL。

import app from '@adonisjs/core/services/app'
const files = [
'./tests/welcome.spec.ts',
'./tests/maths.spec.ts'
]
await Promise.all(files.map((file) => {
return import(app.makeURL(file).href)
}))

makePath

makePath 方法返回项目根目录中给定文件或目录的绝对路径。

import app from '@adonisjs/core/services/app'
app.makePath('app/middleware/auth.ts')

configPath

返回项目配置目录中文件的路径。

app.configPath('shield.ts')
// /project_root/config/shield.ts
app.configPath()
// /project_root/config

publicPath

返回项目公共目录中文件的路径。

app.publicPath('style.css')
// /project_root/public/style.css
app.publicPath()
// /project_root/public

providersPath

返回提供者目录中文件的路径。

app.providersPath('app_provider')
// /project_root/providers/app_provider.ts
app.providersPath()
// /project_root/providers

factoriesPath

返回数据库工厂目录中文件的路径。

app.factoriesPath('user.ts')
// /project_root/database/factories/user.ts
app.factoriesPath()
// /project_root/database/factories

migrationsPath

返回数据库迁移目录中文件的路径。

app.migrationsPath('user.ts')
// /project_root/database/migrations/user.ts
app.migrationsPath()
// /project_root/database/migrations

seedersPath

返回数据库填充器目录中文件的路径。

app.seedersPath('user.ts')
// /project_root/database/seeders/users.ts
app.seedersPath()
// /project_root/database/seeders

languageFilesPath

返回语言目录中文件的路径。

app.languageFilesPath('en/messages.json')
// /project_root/resources/lang/en/messages.json
app.languageFilesPath()
// /project_root/resources/lang

viewsPath

返回视图目录中文件的路径。

app.viewsPath('welcome.edge')
// /project_root/resources/views/welcome.edge
app.viewsPath()
// /project_root/resources/views

startPath

返回启动目录中文件的路径。

app.startPath('routes.ts')
// /project_root/start/routes.ts
app.startPath()
// /project_root/start

tmpPath

返回项目根目录下 tmp 目录中的文件路径。

app.tmpPath('logs/mail.txt')
// /项目根目录/tmp/logs/mail.txt
app.tmpPath()
// /项目根目录/tmp

httpControllersPath

返回 HTTP 控制器目录中的文件路径。

app.httpControllersPath('users_controller.ts')
// /项目根目录/app/controllers/users_controller.ts
app.httpControllersPath()
// /项目根目录/app/controllers

modelsPath

返回模型目录中的文件路径。

app.modelsPath('user.ts')
// /项目根目录/app/models/user.ts
app.modelsPath()
// /项目根目录/app/models

servicesPath

返回服务目录中的文件路径。

app.servicesPath('user.ts')
// /项目根目录/app/services/user.ts
app.servicesPath()
// /项目根目录/app/services

exceptionsPath

返回异常目录中的文件路径。

app.exceptionsPath('handler.ts')
// /项目根目录/app/exceptions/handler.ts
app.exceptionsPath()
// /项目根目录/app/exceptions

mailsPath

返回邮件目录中的文件路径。

app.mailsPath('verify_email.ts')
// /项目根目录/app/mails/verify_email.ts
app.mailsPath()
// /项目根目录/app/mails

middlewarePath

返回中间件目录中的文件路径。

app.middlewarePath('auth.ts')
// /项目根目录/app/middleware/auth.ts
app.middlewarePath()
// /项目根目录/app/middleware

policiesPath

返回策略目录中的文件路径。

app.policiesPath('posts.ts')
// /项目根目录/app/policies/posts.ts
app.policiesPath()
// /项目根目录/app/policies

validatorsPath

返回验证器目录中的文件路径。

app.validatorsPath('create_user.ts')
// /项目根目录/app/validators/create_user.ts
app.validatorsPath()
// /项目根目录/app/validators

commandsPath

返回命令目录中的文件路径。

app.commandsPath('greet.ts')
// /项目根目录/commands/greet.ts
app.commandsPath()
// /项目根目录/commands

eventsPath

返回事件目录中的文件路径。

app.eventsPath('user_created.ts')
// /项目根目录/app/events/user_created.ts
app.eventsPath()
// /项目根目录/app/events

listenersPath

返回监听器目录中的文件路径。

app.listenersPath('send_invoice.ts')
// /项目根目录/app/listeners/send_invoice.ts
app.listenersPath()
// /项目根目录/app/listeners

生成器

生成器用于为不同的实体创建类名和文件名。例如,你可以使用 generators.controllerFileName 方法来生成控制器的文件名。

import app from '@adonisjs/core/services/app'
app.generators.controllerFileName('user')
// 输出 - users_controller.ts
app.generators.controllerName('user')
// 输出 - UsersController

参考 generators.ts 源代码以查看可用的生成器列表。