JaversException TYPE_NAME_NOT_FOUND: type name contains '$$EnhancerByCGLIB$$'











up vote
0
down vote

favorite












Calling Javers.findChanges() results in the mentioned exception. It looks like my Pojo was somehow proxied or generated by CGLIB. Strange, because I am not using JPA/Hibernate but MongoDB. Two questions,




  1. is there a way to prevent this in the future?

  2. is there a way to "fix" the jv_snapshots table or extend Javers somehow to deserialize this Pojos correctly?


Thank your










share|improve this question


























    up vote
    0
    down vote

    favorite












    Calling Javers.findChanges() results in the mentioned exception. It looks like my Pojo was somehow proxied or generated by CGLIB. Strange, because I am not using JPA/Hibernate but MongoDB. Two questions,




    1. is there a way to prevent this in the future?

    2. is there a way to "fix" the jv_snapshots table or extend Javers somehow to deserialize this Pojos correctly?


    Thank your










    share|improve this question
























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      Calling Javers.findChanges() results in the mentioned exception. It looks like my Pojo was somehow proxied or generated by CGLIB. Strange, because I am not using JPA/Hibernate but MongoDB. Two questions,




      1. is there a way to prevent this in the future?

      2. is there a way to "fix" the jv_snapshots table or extend Javers somehow to deserialize this Pojos correctly?


      Thank your










      share|improve this question













      Calling Javers.findChanges() results in the mentioned exception. It looks like my Pojo was somehow proxied or generated by CGLIB. Strange, because I am not using JPA/Hibernate but MongoDB. Two questions,




      1. is there a way to prevent this in the future?

      2. is there a way to "fix" the jv_snapshots table or extend Javers somehow to deserialize this Pojos correctly?


      Thank your







      javers






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 8 at 22:22









      Jörg Hälker

      11




      11
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote













          Your application should not commit CGLIB proxies to JaVers. When you are using JPA/Hibernate, JaVers automatically unproxies your entities (see https://javers.org/documentation/spring-integration/#hibernate-unproxy-hook).



          I don't know why your application generates those proxies, maybe some AOP framework? It doesn't happen in typical Spring configuration for Mongo.
          It's not clear why you have jv_snapshots table since you said that you are using MongoDB.






          share|improve this answer





















          • OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
            – Jörg Hälker
            Nov 11 at 12:20










          • If you have jv_snapshots collection (not table), that's fine :).
            – Bartek Walacik
            Nov 11 at 19:21










          • There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
            – Bartek Walacik
            Nov 11 at 19:22












          • I made a pull request: github.com/javers/javers/pull/738
            – Jörg Hälker
            Nov 11 at 22:23











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














           

          draft saved


          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53217046%2fjaversexception-type-name-not-found-type-name-contains-enhancerbycglib%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          0
          down vote













          Your application should not commit CGLIB proxies to JaVers. When you are using JPA/Hibernate, JaVers automatically unproxies your entities (see https://javers.org/documentation/spring-integration/#hibernate-unproxy-hook).



          I don't know why your application generates those proxies, maybe some AOP framework? It doesn't happen in typical Spring configuration for Mongo.
          It's not clear why you have jv_snapshots table since you said that you are using MongoDB.






          share|improve this answer





















          • OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
            – Jörg Hälker
            Nov 11 at 12:20










          • If you have jv_snapshots collection (not table), that's fine :).
            – Bartek Walacik
            Nov 11 at 19:21










          • There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
            – Bartek Walacik
            Nov 11 at 19:22












          • I made a pull request: github.com/javers/javers/pull/738
            – Jörg Hälker
            Nov 11 at 22:23















          up vote
          0
          down vote













          Your application should not commit CGLIB proxies to JaVers. When you are using JPA/Hibernate, JaVers automatically unproxies your entities (see https://javers.org/documentation/spring-integration/#hibernate-unproxy-hook).



          I don't know why your application generates those proxies, maybe some AOP framework? It doesn't happen in typical Spring configuration for Mongo.
          It's not clear why you have jv_snapshots table since you said that you are using MongoDB.






          share|improve this answer





















          • OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
            – Jörg Hälker
            Nov 11 at 12:20










          • If you have jv_snapshots collection (not table), that's fine :).
            – Bartek Walacik
            Nov 11 at 19:21










          • There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
            – Bartek Walacik
            Nov 11 at 19:22












          • I made a pull request: github.com/javers/javers/pull/738
            – Jörg Hälker
            Nov 11 at 22:23













          up vote
          0
          down vote










          up vote
          0
          down vote









          Your application should not commit CGLIB proxies to JaVers. When you are using JPA/Hibernate, JaVers automatically unproxies your entities (see https://javers.org/documentation/spring-integration/#hibernate-unproxy-hook).



          I don't know why your application generates those proxies, maybe some AOP framework? It doesn't happen in typical Spring configuration for Mongo.
          It's not clear why you have jv_snapshots table since you said that you are using MongoDB.






          share|improve this answer












          Your application should not commit CGLIB proxies to JaVers. When you are using JPA/Hibernate, JaVers automatically unproxies your entities (see https://javers.org/documentation/spring-integration/#hibernate-unproxy-hook).



          I don't know why your application generates those proxies, maybe some AOP framework? It doesn't happen in typical Spring configuration for Mongo.
          It's not clear why you have jv_snapshots table since you said that you are using MongoDB.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 9 at 23:46









          Bartek Walacik

          1,6641512




          1,6641512












          • OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
            – Jörg Hälker
            Nov 11 at 12:20










          • If you have jv_snapshots collection (not table), that's fine :).
            – Bartek Walacik
            Nov 11 at 19:21










          • There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
            – Bartek Walacik
            Nov 11 at 19:22












          • I made a pull request: github.com/javers/javers/pull/738
            – Jörg Hälker
            Nov 11 at 22:23


















          • OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
            – Jörg Hälker
            Nov 11 at 12:20










          • If you have jv_snapshots collection (not table), that's fine :).
            – Bartek Walacik
            Nov 11 at 19:21










          • There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
            – Bartek Walacik
            Nov 11 at 19:22












          • I made a pull request: github.com/javers/javers/pull/738
            – Jörg Hälker
            Nov 11 at 22:23
















          OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
          – Jörg Hälker
          Nov 11 at 12:20




          OK, I think I am having proxies because I am using this mongo-Annotation: @DBRef(lazy = true). Is there something like an unproxy hook for lazy dbrefs? I am having a jv_snapshots collection and another collection called jv_head_id. Is this wrong? Where should this things be stored in MongoDB?
          – Jörg Hälker
          Nov 11 at 12:20












          If you have jv_snapshots collection (not table), that's fine :).
          – Bartek Walacik
          Nov 11 at 19:21




          If you have jv_snapshots collection (not table), that's fine :).
          – Bartek Walacik
          Nov 11 at 19:21












          There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
          – Bartek Walacik
          Nov 11 at 19:22






          There are no automatic unproxy hook for Mongo DBRef, looks like a missing feature in JaVars, you are encouraged to contribute a PR.
          – Bartek Walacik
          Nov 11 at 19:22














          I made a pull request: github.com/javers/javers/pull/738
          – Jörg Hälker
          Nov 11 at 22:23




          I made a pull request: github.com/javers/javers/pull/738
          – Jörg Hälker
          Nov 11 at 22:23


















           

          draft saved


          draft discarded



















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53217046%2fjaversexception-type-name-not-found-type-name-contains-enhancerbycglib%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Guess what letter conforming each word

          Run scheduled task as local user group (not BUILTIN)

          Port of Spain