如何在Grails Bootstrap中添加审计跟踪的用户?

时间:2013-10-20 16:48:23

标签: grails spring-security bootstrapping audit-trail

嗨,我很难在grails bootstrap中添加第一个用户。我尝试了很多不同的方法,但都失败了,因为Audit Trail插件希望用户标记createdBy和EditedBy字段,但第一个字段尚未退出。

这是我的审计跟踪配置,基本上它与默认配置相同,只是我在User.id上使用User.username:

grails {
    plugin {
        audittrail { 
            createdBy.field = "createdBy"
            createdBy.type   = "java.lang.String" //Long is the default
            editedBy.field = "editedBy"
            editedBy.type   = "java.lang.String" //Long is the default
            createdDate.field = "createdDate"
            editedDate.field = "editedDate"

            currentUserClosure = {ctx->
                def authPrincipal = ctx.springSecurityService.principal
                if(authPrincipal && authPrincipal != "anonymousUser"){
                    return authPrincipal.username
                } else {
                    return null //fall back
                }
            }
        }
    }
}

这是我的User类的样子,即。我只是添加了插件的注释:

@gorm.AuditStamp
class User {
  //... basic Spring Security Generated User File with minor changes
}

以下是我的bootstrap文件的内容:

def adminUser = new User(
    username: 'admin',
    enabled: true,
    password: 'password',
    firstName: 'ADMIN',
    lastName: 'ADMIN'
).save(flush: true)

// The below will work if I take off the annotation on User class.
SpringSecurityUtils.doWithAuth('admin') {
    def adminRole = new Role(authority: 'ROLE_ADMIN').save(flush: true)
    UserRole.create adminUser, adminRole, true
}

那么现在我该如何添加第一个用户?我试过了:

- Using annonymousUser
    - Failed, plugin prevents it
- Hardcoding the createdBy and editedby to "admin"
    - Failed get's overridden 
- Use executeUpdate to insert the user directly in the DB
    - Failed: in bootstrap
- Delay the save of the first user until the doWithAuth
    - Failed: couldn't find the user

任何帮助都会很棒!谢谢!

1 个答案:

答案 0 :(得分:2)

我遇到了同样的问题,正在寻找解决方案。我设法通过以下方式使其工作:

grails {
plugin {
audittrail {
createdBy.field = "createdBy"
createdBy.type   = "java.lang.String" //Long is the default
editedBy.field = "modifiedBy"
editedBy.type   = "java.lang.String" //Long is the default
createdDate.field = "createdDate"
editedDate.field = "modifiedDate"

//custom closure to return the current user who is logged in
currentUserClosure = {ctx->
//ctx is the applicationContext
def userName = ctx.springSecurityService.principal?.username
return userName != null ? userName : "System"
}
}
}
}

在Bootstrap.groovy文件中,只需执行以下保存:

def adminUser = new User(username: 'admin', enabled: true, password: 'password',
firstName: 'ADMIN', lastName: 'ADMIN').save(flush: true)
def adminRole = new Role(authority: 'ROLE_ADMIN').save(flush: true)
UserRole.create adminUser, adminRole, true

新创建的第一个用户将加盖用户" System" (createdBy和modifiedBy列)。