Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update documentation with information how to plug in UI to view/edit custom fields added to User and Profile #24

Open
JohnM1991 opened this issue Sep 16, 2013 · 9 comments
Assignees

Comments

@JohnM1991
Copy link

I've added custom fields to Profile (extending grails.plugin.nimble.core.ProfileBase) and User (extending grails.plugin.nimble.core.UserBase) classes (which were created by jack-be-nimble script), however I cannot quite figure out what is the right way to make these fields viewable and editable in the Nimble admin screens.

I'd like to reuse the Nimble admin screens to the degree possible, just adding the extra fields to them where applicable (some are references to other tables, to be presented as drop-downs), as I quite like the Nimble admin screens.

Probably some templates need to be copied from somewhere and overridden, or added to, but I cannot quite find where this approach is documented.

@ghost ghost assigned snimavat Sep 17, 2013
@snimavat
Copy link
Owner

@JohnMurdoch Extended information tab on view user screen is intended to display additional fields for user and profiles. The template used is /templates/nimble/user/extendedinformation You can copy and modify the template to display additional fields, or create forms for additional fields.

@JohnM1991
Copy link
Author

Thanks, I managed to override /views/templates/nimble/user/_extendedinformation.gsp to show the fields and also /views/user/edit.gsp to add edit controls.

I haven't quite figured out what to do to make these new fields save to the database.

I did my own UserController which extends grails.plugin.nimble.core.UserController so I could just override the update(Long) method, but it seems it would be more proper to somehow add my custom fields to "nimbleConfig.fields.admin.user", but I don't see such config items in /conf/NimbleConfig.groovy.

@snimavat
Copy link
Owner

Look at DefaultNimbleConfig

fields {
    admin {
        user = [
            'username',
            'external',
            'federated'
        ]
    }
    enduser {
        user = [
            'username',
            'pass',
            'passConfirm'
        ]
        profile = ['fullName', 'email']
    }
}

This are the fields that nimble will update.. all other form fields will not considered when saving/updating users and profiles from within nimble.

You can override this configuration, and add your extra field names in nimble.fields.enduser.user / nimble.fields.enduser.profile - if you want to allow this fields to update for admin users as well, put them in nimble.fields.admin.user as well.

@JohnM1991
Copy link
Author

Thanks, actually got some of this to work now if I put it under nimble.fields.admin.user !

nimble.fields.enduser.user seems to be ignored as UserController line 88 only considers the admin fields (at least in my version of the plugin).

Also, it would seem to make sense for the default edit screen to include full name and e-mail but it seems only the _extendedInformation.gsp includes it.

Apologies if I've missed something.

@snimavat
Copy link
Owner

Right, nimble.fields.enduser.user is used only while creating new user

@snimavat
Copy link
Owner

@JohnMurdoch Do you think plugin can updated in some way that can make it easier for you.

put fields in nimble.fields.enduser.user - these fields are used while creating new user
put fields in nimble.fields.admin.user - this fields are used for updating, that means only these fields will be able to be updated.

@JohnM1991
Copy link
Author

Well, to me it seems that there would need need to be two sets of fields - those for all users, and those only for admins, where if you add the fields to the relevant configuration properties then they would appear both in create user and edit user screens.

Also probably provide override functionality for editing complex fields (e.g., dropdowns) even if simple ones (with String or Integer values) are working out of the box just from being added to the configuration.

Apologies if I've misunderstood your question.

@JohnM1991
Copy link
Author

Ideally the Nimble user documentation would include a description of the steps needed to:
a) Add a String property to every user, both in edit and create screens
b) Add a reference to another entity (e.g., Company the user works for, assuming each user works for one Company and each Company employs many users), as a drop-down, in both edit and create screens (assume creation/etc. of Company entity happens in other non-Nimble admin screens)

I think both are very common use cases for using Nimble.

P.S. Also which of the fields added belong in User and which in Profile? Perhaps I wasn't reading carefully enough, but I don't think this is explained by Nimble documentation, or even why we need both. That's a different, though related, topic.

@dhax
Copy link

dhax commented Sep 30, 2013

Hi to all,

@JohnMurdoch The nimble UserBase class contains all authentication and authorization related information like username, realm, the encrypted password-hash, password history, assigned roles and groups and booleans about account state. It is required to store and verify the user's account information for the underlying Apache Shiro Security Framework. The ProfileBase instead holds the basic application user data like Full Name, Nickname, Email and creationDate. The purpose is to keep the user's authentication profile separated from the user's application profile I guess.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants