Как исправить атрибут sn, не объявленный в объектных классах записи

Я пытаюсь создать запись с помощью Spring-Data-LDAP, и когда я пытаюсь сохранить запись, он дает мне Атрибут sn, не объявленный в объектных классах записи ou = users, dc = example, dc = com. Я новичок в LDAP.

Я создал класс модели, который содержит основные атрибуты, и у меня автоматически подключен LdapRepository.

Проблема в том, что я могу получить записи из Apache DS ldap, но не могу сохранить запись с моей моделью.

Ниже представлен класс модели.


@Entry(
          base = "ou=users", 
          objectClasses = { "inetOrgPerson","organizationalPerson","person", "top" })
public class User {

    private static final String BASE_DN = "dc=example,dc=com";

    @JsonIgnore
    @Id
    private Name id;
    @JsonProperty("userName")

    private @Attribute(name="uid")  String uid;
    @JsonProperty("firstName")
    private @Attribute(name = "cn") String firstName;
    @JsonIgnore
    private @Attribute(name = "displayname") String displayName;
    @JsonProperty("lastName")

    private  @Attribute(name = "sn") String lastName;

    public User() {

    }

    public User(String uid, String firstName, String displayName, String lastName) {
        this.uid = uid;
        this.firstName = firstName;
        this.displayName = displayName;
        this.lastName = lastName;
    }
    public User(String userName, String firstName, String lastName) {       
         Name dn = LdapNameBuilder.newInstance()
                 .add("ou", "users")                 
                 .build();
        this.id = dn;       
        this.uid = userName;
        this.firstName = firstName;
        this.lastName = lastName;
    }

    // Setter and Getter
}

Ниже находится файл ldif,

dn: dc=example,dc=com
objectclass: top
objectclass: domain
dc: example

dn: ou=users,dc=example,dc=com
objectClass: organizationalUnit
objectClass: top
ou: users

Ниже приведен журнал ошибок

There was an unexpected error (type=Internal Server Error, status=500).
[LDAP: error code 65 - OBJECT_CLASS_VIOLATION: failed for MessageType : MODIFY_REQUEST Message ID : 2 Modify Request Object : 'ou=users,dc=example,dc=com' Modification[0] Operation : add Modification uid: abc Modification[1] Operation : add Modification cn: Abc Modification[2] Operation : add Modification sn: Xyzsorg.apache.directory.api.ldap.model.message.ModifyRequestImpl@1b7e931e ManageDsaITImpl Control Type OID : '2.16.840.1.113730.3.4.2' Criticality : 'false' ' : ERR_277 Attribute sn not declared in objectClasses of entry ou=users,dc=example,dc=com]

Заранее спасибо


person Keval Bhatt    schedule 30.09.2019    source источник


Ответы (1)


Не уверен в коде, но похоже, что вы создаете DN для пользователя в этой строке:

Name dn = LdapNameBuilder.newInstance()
                 .add("ou", "users")                 
                 .build();

Которая НЕ содержит uid пользователя.

AddRequest должен быть:

AddRequest ::= [APPLICATION 8] SEQUENCE 
{
    entry           LDAPDN,
    attributes      AttributeList 
} 

Где LDAPDN - это полное отличительное имя записи.

person jwilleke    schedule 30.09.2019
comment
Привет Большое спасибо за ответ, я решил проблему. Я изменил аннотацию репозитория на CrudRepository ‹T, Name›, которая работает с созданием объекта. Я использую предложенный вами LDAPDN для поиска / обновления объекта. Большое спасибо - person Keval Bhatt; 02.10.2019