引导 Strapi 角色权限

Eri*_*sen 7 javascript node.js graphql strapi

我是第一次做前端工作、trapi 和 javascript 的开发人员。我希望有人能同情我并提供一个如何通过 bootstrap.js 脚本设置公共角色权限的示例。node.js v10.16.0
Strapi v3.0.0-next.11
Graphql 14.3.1
MongoDB:3.6
全部在 Windows 10 上

在 Strapi UI 中,它是公共角色的角色和权限 公共角色 我想将这些框设置为 CHECKED 切换复选框

另一位开发人员使用 bootstrap.js 文件向我们创建的服务(菜单)添加项目。我不知道如何返回关于角色权限的最基本信息。我的函数被称为 test() 我搜索了一些例子,我在stackoverflow上找到了最好的: Strapi Plugin Route Default Permission

strapi.plugins['users-permissions'].models.role.find 
Run Code Online (Sandbox Code Playgroud)

但我不知道如何使用它:

WORKING
function add_widgets_from_sheet(sheet_name, model_object){
  console.log(`adding ${sheet_name}`)
  let xlsxSheet = Sheets[sheet_name]
  const widgets = XLSX.utils.sheet_to_json(xlsxSheet)

  widgets.forEach(function (widget) {
    //See if the object is already in the db before adding it
    model_object.count(widget)
      .then(result => {
        if (result == 0) {
          console.log('Adding '+sheet_name+': ' + JSON.stringify(widget))
          return model_object.add(widget)
        }
      })
  })
}

NOT WORKING
function test(){
  console.log(`Testing ${strapi.plugins['users-permissions'].models.role.find}`)
}

module.exports = next => {

  console.log('Starting Strapi bootstrap')
  add_widgets_from_sheet('Menus', strapi.services.menu) //adding menus
  test() // Returning nothing
  console.log('Ending Strapi bootstrap')
  next()
}
Run Code Online (Sandbox Code Playgroud)

我想将这些复选框切换为 TRUE、CHECKED 或其他任何名称。这样我们就不必每次转储数据库时都通过 UI 手动执行此操作。

我从例子中学习得最好......我希望你能帮上忙。谢谢!

Eri*_*sen 5

因此,下面的代码来自一个名为 PROJECT/STRAPI/config/functions/bootstrap.js 的文件。这会自动使用我们保存在 Excel 电子表格中的信息创建内容类型和内容。但是为了使用这些内容类型,必须激活角色和权限,以便 web ui 可以访问它们。基本上,我们不想手动进入 Strapi UI 来创建您的用户、创建内容类型、创建内容或更新权限。我们想要一个脚本来完成所有这些。

'use strict'
Run Code Online (Sandbox Code Playgroud)

我们的环境变量

require('dotenv').config({ path:'../.env' })
Run Code Online (Sandbox Code Playgroud)

保存我们的数据的 Excel 电子表格(附后)

const XLSX = require('xlsx')
const BOOTSTRAP_DATA = XLSX.readFile(process.env.BOOTSTRAP_DATA).Sheets
Run Code Online (Sandbox Code Playgroud)

从 .env 中提取的变量

const ADMIN_USERNAME = process.env.ADMIN_USERNAME
const ADMIN_PASSWORD = process.env.ADMIN_PASSWORD
const ADMIN_EMAIL    = process.env.ADMIN_EMAIL
Run Code Online (Sandbox Code Playgroud)

在 XLSX 中阅读

async function bootstrap_resource(resource_type, resource_service) {
  strapi.log.info(`Bootstrapping ${resource_type}`)

  const resources = XLSX.utils.sheet_to_json(BOOTSTRAP_DATA[resource_type])

  for (let resource of resources) {

    if (await resource_service.count(resource) === 0) {
      strapi.log.warn(`Bootstrapping ${resource_type}: ${JSON.stringify(resource)}`)

      await resource_service.create(resource)
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

为 Strapi 创建初始用户

async function bootstrap_admin() {
  strapi.log.info(`Bootstrapping Admin`)

  const admin_orm = strapi.admin.queries('administrator', 'admin')

  const admins = await admin_orm.find({username: ADMIN_USERNAME})

  if ( admins.length === 0) {
    const blocked  = false
    const username = ADMIN_USERNAME
    const password = await strapi.admin.services.auth.hashPassword(ADMIN_PASSWORD)
    const email    = ADMIN_EMAIL
    const user     = { blocked, username, password, email }

    const data = await admin_orm.create(user)

    strapi.log.warn(`Bootstrapped Admin User: ${JSON.stringify(user)}`)
  }
}
Run Code Online (Sandbox Code Playgroud)

下面是 get_roles() - get_permissions() 需要,get_permissions() 是 enable_permissions() 需要的。这是我们打开这些内容类型的地方,以便 web ui 可以看到它。

async function get_roles() {
  const role_orm = strapi.plugins['users-permissions'].queries('role', 'users-permissions')

  const role_list = await role_orm.find({}, [])

  const roles = {}

  for (let role of role_list) {
    roles[ role._id ] = role
    roles[ role.name ] = role
  }

  return roles
}

async function get_permissions( selected_role, selected_type, selected_controller ) {
  const roles          = await get_roles()
  const permission_orm = strapi.plugins['users-permissions'].queries('permission', 'users-permissions')

  let permission_list  = await permission_orm.find({_limit: 999}, [])

  if ( selected_role       ) permission_list = permission_list.filter( ({ role       }) => `${role}`       === `${roles[selected_role]._id}` )
  if ( selected_type       ) permission_list = permission_list.filter( ({ type       }) => `${type}`       === `${selected_type}`            )
  if ( selected_controller ) permission_list = permission_list.filter( ({ controller }) => `${controller}` === `${selected_controller}`      )

  return permission_list
}

async function enable_permissions(role, type, controller) {
  strapi.log.info(`Setting '${controller}' permissions for '${role}'`)

  const permission_orm = strapi.plugins['users-permissions'].queries('permission', 'users-permissions')

  const permissions = await get_permissions(role, type, controller)

  for (let { _id } of permissions) {
    permission_orm.update({ _id }, { enabled: true })
  }
}
Run Code Online (Sandbox Code Playgroud)

最后,我们运行程序

module.exports = async next => {

  await bootstrap_admin()

  await bootstrap_resource( 'Clients', strapi.services.client )
  await bootstrap_resource( 'Menus',   strapi.services.menu   )

  enable_permissions('Public', 'application', 'client'     )
  enable_permissions('Public', 'application', 'github'     )
  enable_permissions('Public', 'application', 'menu'       )
  enable_permissions('Public', 'application', 'confluence' )

  next()
}
Run Code Online (Sandbox Code Playgroud)

去掉我的评论,你就有了整个 bootstrap.js 文件。下图显示了用于填充所有内容的 demo.xlsx 工作簿的 3 个选项卡。 客户选项卡 菜单选项卡 用户标签

最后,展示结果。菜单(内容)、权限设置和使用 Nuxt 的公共网站。 菜单列表 公共用户的权限 Nuxt 利用 Strapi 生成网页