Field Errors after using keystone-storage-adapter-s3












0














I am looking for help debugging the message "Field Errors" I receive as a browser popup when trying to upload an image through the Keystone CMS.
enter image description here



I am using the npm package keystone-storage-adapter-s3. For some context, I am trying to upload images to an AWS S3 bucket and later retrieve them as part of a website's content using the Keystone CMS. I am pretty new to AWS S3, but trying.



Here is the image model in question.



const keystone = require('keystone');
const Types = keystone.Field.Types;

const Image = new keystone.List('Image');

const storage = new keystone.Storage({
adapter: require('keystone-storage-adapter-s3'),
s3: {
key: process.env.S3_KEY, // required; defaults to process.env.S3_KEY
secret: process.env.S3_SECRET, // required; defaults to process.env.S3_SECRET
bucket: process.env.S3_BUCKET, // required; defaults to process.env.S3_BUCKET
region: process.env.S3_REGION, // optional; defaults to process.env.S3_REGION, or if that's not specified, us-east-1
uploadParams: { // optional; add S3 upload params; see below for details
ACL: 'public-read',
},
},
schema: {
bucket: true, // optional; store the bucket the file was uploaded to in your db
etag: true, // optional; store the etag for the resource
path: true, // optional; store the path of the file in your db
url: true, // optional; generate & store a public URL
},
});

Image.add({
name: { type: String },
file: { type: Types.File, storage: storage },
});

Image.register();


I believe I've filled out the region, bucket name, secret (random secure string), and even created a new key that's stored securely as well in a .env file.



Here is the error I receive in the browser console.



packages.js:33 POST http://localhost:3000/keystone/api/images/5bf2c27e05ba79178cd7d2be 500 (Internal Server Error)
a @ packages.js:33
i @ packages.js:33
List.updateItem @ admin.js:22863
updateItem @ admin.js:15021
r @ packages.js:16
a @ packages.js:14
s @ packages.js:14
d @ packages.js:14
v @ packages.js:14
r @ packages.js:17
processEventQueue @ packages.js:14
r @ packages.js:16
handleTopLevel @ packages.js:16
i @ packages.js:16
perform @ packages.js:17
batchedUpdates @ packages.js:16
i @ packages.js:16
dispatchEvent @ packages.js:16


These are the permission settings of my S3 bucket.




  • Block new public ACLs and uploading public objects: False

  • Remove public access granted through public ACLs: False

  • Block new public bucket policies: True

  • Block public and cross-account access if bucket has public policies: True


These are similar questions, but I believe have to do with Keystone's previous implementation of Knox.




  • "Field errors"

  • Field errors in s3 file upload


I found the debug package in use within node_modules/keystone/fields/types/file/FileType.js and enabled it. I received the following debug messages when attempting to upload an image.



$ DEBUG=keystone:fields:file node keystone.js

------------------------------------------------
KeystoneJS v4.0.0 started:
keystone-s3 is ready on http://0.0.0.0:3000
------------------------------------------------

GET /keystone/images/5bf2c27e05ba79178cd7d2be 200 17.446 ms
GET /keystone/api/images/5bf2c27e05ba79178cd7d2be?drilldown=true 304 3.528 ms
keystone:fields:file [Image.file] Validating input: upload:File-file-1001 +0ms
keystone:fields:file [Image.file] Validation result: true +1ms
keystone:fields:file [Image.file] Uploading file for item 5bf2c27e05ba79178cd7d2be: { fieldname: 'File-file-1001',
originalname: 'oof.PNG',
encoding: '7bit',
mimetype: 'image/png',
destination: 'C:\Users\Dylan\AppData\Local\Temp',
filename: '42c161c1c36a84a244a2cf09d327afd4',
path:
'C:\Users\Dylan\AppData\Local\Temp\42c161c1c36a84a244a2cf09d327afd4',
size: 6684 } +0ms
POST /keystone/api/images/5bf2c27e05ba79178cd7d2be 500 225.027 ms


This message looks promising, so I will keep looking through this to see if I can debug any more information.



Edit: Progress! I searched the Keystone package for "Field errors" and found where the error message is set. Debugging that location revealed another error.



"InvalidAccessKeyId: The AWS Access Key Id you provided does not exist in our records."



The search continues.










share|improve this question





























    0














    I am looking for help debugging the message "Field Errors" I receive as a browser popup when trying to upload an image through the Keystone CMS.
    enter image description here



    I am using the npm package keystone-storage-adapter-s3. For some context, I am trying to upload images to an AWS S3 bucket and later retrieve them as part of a website's content using the Keystone CMS. I am pretty new to AWS S3, but trying.



    Here is the image model in question.



    const keystone = require('keystone');
    const Types = keystone.Field.Types;

    const Image = new keystone.List('Image');

    const storage = new keystone.Storage({
    adapter: require('keystone-storage-adapter-s3'),
    s3: {
    key: process.env.S3_KEY, // required; defaults to process.env.S3_KEY
    secret: process.env.S3_SECRET, // required; defaults to process.env.S3_SECRET
    bucket: process.env.S3_BUCKET, // required; defaults to process.env.S3_BUCKET
    region: process.env.S3_REGION, // optional; defaults to process.env.S3_REGION, or if that's not specified, us-east-1
    uploadParams: { // optional; add S3 upload params; see below for details
    ACL: 'public-read',
    },
    },
    schema: {
    bucket: true, // optional; store the bucket the file was uploaded to in your db
    etag: true, // optional; store the etag for the resource
    path: true, // optional; store the path of the file in your db
    url: true, // optional; generate & store a public URL
    },
    });

    Image.add({
    name: { type: String },
    file: { type: Types.File, storage: storage },
    });

    Image.register();


    I believe I've filled out the region, bucket name, secret (random secure string), and even created a new key that's stored securely as well in a .env file.



    Here is the error I receive in the browser console.



    packages.js:33 POST http://localhost:3000/keystone/api/images/5bf2c27e05ba79178cd7d2be 500 (Internal Server Error)
    a @ packages.js:33
    i @ packages.js:33
    List.updateItem @ admin.js:22863
    updateItem @ admin.js:15021
    r @ packages.js:16
    a @ packages.js:14
    s @ packages.js:14
    d @ packages.js:14
    v @ packages.js:14
    r @ packages.js:17
    processEventQueue @ packages.js:14
    r @ packages.js:16
    handleTopLevel @ packages.js:16
    i @ packages.js:16
    perform @ packages.js:17
    batchedUpdates @ packages.js:16
    i @ packages.js:16
    dispatchEvent @ packages.js:16


    These are the permission settings of my S3 bucket.




    • Block new public ACLs and uploading public objects: False

    • Remove public access granted through public ACLs: False

    • Block new public bucket policies: True

    • Block public and cross-account access if bucket has public policies: True


    These are similar questions, but I believe have to do with Keystone's previous implementation of Knox.




    • "Field errors"

    • Field errors in s3 file upload


    I found the debug package in use within node_modules/keystone/fields/types/file/FileType.js and enabled it. I received the following debug messages when attempting to upload an image.



    $ DEBUG=keystone:fields:file node keystone.js

    ------------------------------------------------
    KeystoneJS v4.0.0 started:
    keystone-s3 is ready on http://0.0.0.0:3000
    ------------------------------------------------

    GET /keystone/images/5bf2c27e05ba79178cd7d2be 200 17.446 ms
    GET /keystone/api/images/5bf2c27e05ba79178cd7d2be?drilldown=true 304 3.528 ms
    keystone:fields:file [Image.file] Validating input: upload:File-file-1001 +0ms
    keystone:fields:file [Image.file] Validation result: true +1ms
    keystone:fields:file [Image.file] Uploading file for item 5bf2c27e05ba79178cd7d2be: { fieldname: 'File-file-1001',
    originalname: 'oof.PNG',
    encoding: '7bit',
    mimetype: 'image/png',
    destination: 'C:\Users\Dylan\AppData\Local\Temp',
    filename: '42c161c1c36a84a244a2cf09d327afd4',
    path:
    'C:\Users\Dylan\AppData\Local\Temp\42c161c1c36a84a244a2cf09d327afd4',
    size: 6684 } +0ms
    POST /keystone/api/images/5bf2c27e05ba79178cd7d2be 500 225.027 ms


    This message looks promising, so I will keep looking through this to see if I can debug any more information.



    Edit: Progress! I searched the Keystone package for "Field errors" and found where the error message is set. Debugging that location revealed another error.



    "InvalidAccessKeyId: The AWS Access Key Id you provided does not exist in our records."



    The search continues.










    share|improve this question



























      0












      0








      0







      I am looking for help debugging the message "Field Errors" I receive as a browser popup when trying to upload an image through the Keystone CMS.
      enter image description here



      I am using the npm package keystone-storage-adapter-s3. For some context, I am trying to upload images to an AWS S3 bucket and later retrieve them as part of a website's content using the Keystone CMS. I am pretty new to AWS S3, but trying.



      Here is the image model in question.



      const keystone = require('keystone');
      const Types = keystone.Field.Types;

      const Image = new keystone.List('Image');

      const storage = new keystone.Storage({
      adapter: require('keystone-storage-adapter-s3'),
      s3: {
      key: process.env.S3_KEY, // required; defaults to process.env.S3_KEY
      secret: process.env.S3_SECRET, // required; defaults to process.env.S3_SECRET
      bucket: process.env.S3_BUCKET, // required; defaults to process.env.S3_BUCKET
      region: process.env.S3_REGION, // optional; defaults to process.env.S3_REGION, or if that's not specified, us-east-1
      uploadParams: { // optional; add S3 upload params; see below for details
      ACL: 'public-read',
      },
      },
      schema: {
      bucket: true, // optional; store the bucket the file was uploaded to in your db
      etag: true, // optional; store the etag for the resource
      path: true, // optional; store the path of the file in your db
      url: true, // optional; generate & store a public URL
      },
      });

      Image.add({
      name: { type: String },
      file: { type: Types.File, storage: storage },
      });

      Image.register();


      I believe I've filled out the region, bucket name, secret (random secure string), and even created a new key that's stored securely as well in a .env file.



      Here is the error I receive in the browser console.



      packages.js:33 POST http://localhost:3000/keystone/api/images/5bf2c27e05ba79178cd7d2be 500 (Internal Server Error)
      a @ packages.js:33
      i @ packages.js:33
      List.updateItem @ admin.js:22863
      updateItem @ admin.js:15021
      r @ packages.js:16
      a @ packages.js:14
      s @ packages.js:14
      d @ packages.js:14
      v @ packages.js:14
      r @ packages.js:17
      processEventQueue @ packages.js:14
      r @ packages.js:16
      handleTopLevel @ packages.js:16
      i @ packages.js:16
      perform @ packages.js:17
      batchedUpdates @ packages.js:16
      i @ packages.js:16
      dispatchEvent @ packages.js:16


      These are the permission settings of my S3 bucket.




      • Block new public ACLs and uploading public objects: False

      • Remove public access granted through public ACLs: False

      • Block new public bucket policies: True

      • Block public and cross-account access if bucket has public policies: True


      These are similar questions, but I believe have to do with Keystone's previous implementation of Knox.




      • "Field errors"

      • Field errors in s3 file upload


      I found the debug package in use within node_modules/keystone/fields/types/file/FileType.js and enabled it. I received the following debug messages when attempting to upload an image.



      $ DEBUG=keystone:fields:file node keystone.js

      ------------------------------------------------
      KeystoneJS v4.0.0 started:
      keystone-s3 is ready on http://0.0.0.0:3000
      ------------------------------------------------

      GET /keystone/images/5bf2c27e05ba79178cd7d2be 200 17.446 ms
      GET /keystone/api/images/5bf2c27e05ba79178cd7d2be?drilldown=true 304 3.528 ms
      keystone:fields:file [Image.file] Validating input: upload:File-file-1001 +0ms
      keystone:fields:file [Image.file] Validation result: true +1ms
      keystone:fields:file [Image.file] Uploading file for item 5bf2c27e05ba79178cd7d2be: { fieldname: 'File-file-1001',
      originalname: 'oof.PNG',
      encoding: '7bit',
      mimetype: 'image/png',
      destination: 'C:\Users\Dylan\AppData\Local\Temp',
      filename: '42c161c1c36a84a244a2cf09d327afd4',
      path:
      'C:\Users\Dylan\AppData\Local\Temp\42c161c1c36a84a244a2cf09d327afd4',
      size: 6684 } +0ms
      POST /keystone/api/images/5bf2c27e05ba79178cd7d2be 500 225.027 ms


      This message looks promising, so I will keep looking through this to see if I can debug any more information.



      Edit: Progress! I searched the Keystone package for "Field errors" and found where the error message is set. Debugging that location revealed another error.



      "InvalidAccessKeyId: The AWS Access Key Id you provided does not exist in our records."



      The search continues.










      share|improve this question















      I am looking for help debugging the message "Field Errors" I receive as a browser popup when trying to upload an image through the Keystone CMS.
      enter image description here



      I am using the npm package keystone-storage-adapter-s3. For some context, I am trying to upload images to an AWS S3 bucket and later retrieve them as part of a website's content using the Keystone CMS. I am pretty new to AWS S3, but trying.



      Here is the image model in question.



      const keystone = require('keystone');
      const Types = keystone.Field.Types;

      const Image = new keystone.List('Image');

      const storage = new keystone.Storage({
      adapter: require('keystone-storage-adapter-s3'),
      s3: {
      key: process.env.S3_KEY, // required; defaults to process.env.S3_KEY
      secret: process.env.S3_SECRET, // required; defaults to process.env.S3_SECRET
      bucket: process.env.S3_BUCKET, // required; defaults to process.env.S3_BUCKET
      region: process.env.S3_REGION, // optional; defaults to process.env.S3_REGION, or if that's not specified, us-east-1
      uploadParams: { // optional; add S3 upload params; see below for details
      ACL: 'public-read',
      },
      },
      schema: {
      bucket: true, // optional; store the bucket the file was uploaded to in your db
      etag: true, // optional; store the etag for the resource
      path: true, // optional; store the path of the file in your db
      url: true, // optional; generate & store a public URL
      },
      });

      Image.add({
      name: { type: String },
      file: { type: Types.File, storage: storage },
      });

      Image.register();


      I believe I've filled out the region, bucket name, secret (random secure string), and even created a new key that's stored securely as well in a .env file.



      Here is the error I receive in the browser console.



      packages.js:33 POST http://localhost:3000/keystone/api/images/5bf2c27e05ba79178cd7d2be 500 (Internal Server Error)
      a @ packages.js:33
      i @ packages.js:33
      List.updateItem @ admin.js:22863
      updateItem @ admin.js:15021
      r @ packages.js:16
      a @ packages.js:14
      s @ packages.js:14
      d @ packages.js:14
      v @ packages.js:14
      r @ packages.js:17
      processEventQueue @ packages.js:14
      r @ packages.js:16
      handleTopLevel @ packages.js:16
      i @ packages.js:16
      perform @ packages.js:17
      batchedUpdates @ packages.js:16
      i @ packages.js:16
      dispatchEvent @ packages.js:16


      These are the permission settings of my S3 bucket.




      • Block new public ACLs and uploading public objects: False

      • Remove public access granted through public ACLs: False

      • Block new public bucket policies: True

      • Block public and cross-account access if bucket has public policies: True


      These are similar questions, but I believe have to do with Keystone's previous implementation of Knox.




      • "Field errors"

      • Field errors in s3 file upload


      I found the debug package in use within node_modules/keystone/fields/types/file/FileType.js and enabled it. I received the following debug messages when attempting to upload an image.



      $ DEBUG=keystone:fields:file node keystone.js

      ------------------------------------------------
      KeystoneJS v4.0.0 started:
      keystone-s3 is ready on http://0.0.0.0:3000
      ------------------------------------------------

      GET /keystone/images/5bf2c27e05ba79178cd7d2be 200 17.446 ms
      GET /keystone/api/images/5bf2c27e05ba79178cd7d2be?drilldown=true 304 3.528 ms
      keystone:fields:file [Image.file] Validating input: upload:File-file-1001 +0ms
      keystone:fields:file [Image.file] Validation result: true +1ms
      keystone:fields:file [Image.file] Uploading file for item 5bf2c27e05ba79178cd7d2be: { fieldname: 'File-file-1001',
      originalname: 'oof.PNG',
      encoding: '7bit',
      mimetype: 'image/png',
      destination: 'C:\Users\Dylan\AppData\Local\Temp',
      filename: '42c161c1c36a84a244a2cf09d327afd4',
      path:
      'C:\Users\Dylan\AppData\Local\Temp\42c161c1c36a84a244a2cf09d327afd4',
      size: 6684 } +0ms
      POST /keystone/api/images/5bf2c27e05ba79178cd7d2be 500 225.027 ms


      This message looks promising, so I will keep looking through this to see if I can debug any more information.



      Edit: Progress! I searched the Keystone package for "Field errors" and found where the error message is set. Debugging that location revealed another error.



      "InvalidAccessKeyId: The AWS Access Key Id you provided does not exist in our records."



      The search continues.







      javascript amazon-s3 keystonejs






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 19 '18 at 15:18

























      asked Nov 19 '18 at 15:03









      Dylan Landry

      759




      759
























          1 Answer
          1






          active

          oldest

          votes


















          1














          I was mixing up my "key" and "secret".



          As per the keystone-storage-adapter-s3 package, required are your "key" and "secret". Having inexperience with AWS, and some with web development, I thought the secret was a random secure string (like you would sign a cookie with) and the key was my secret key.



          wrong




          • "key" : Secret Key

          • "secret" : Random secure key.


          correct




          • "key": Key ID

          • "secret": Secret key.


          Turns out I was wrong. The "key" is my key id, and the "secret" is my secret key. Settings those correctly in my .env file allowed me to upload a file to the S3 bucket.






          share|improve this answer





















            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',
            autoActivateHeartbeat: false,
            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%2f53377387%2ffield-errors-after-using-keystone-storage-adapter-s3%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









            1














            I was mixing up my "key" and "secret".



            As per the keystone-storage-adapter-s3 package, required are your "key" and "secret". Having inexperience with AWS, and some with web development, I thought the secret was a random secure string (like you would sign a cookie with) and the key was my secret key.



            wrong




            • "key" : Secret Key

            • "secret" : Random secure key.


            correct




            • "key": Key ID

            • "secret": Secret key.


            Turns out I was wrong. The "key" is my key id, and the "secret" is my secret key. Settings those correctly in my .env file allowed me to upload a file to the S3 bucket.






            share|improve this answer


























              1














              I was mixing up my "key" and "secret".



              As per the keystone-storage-adapter-s3 package, required are your "key" and "secret". Having inexperience with AWS, and some with web development, I thought the secret was a random secure string (like you would sign a cookie with) and the key was my secret key.



              wrong




              • "key" : Secret Key

              • "secret" : Random secure key.


              correct




              • "key": Key ID

              • "secret": Secret key.


              Turns out I was wrong. The "key" is my key id, and the "secret" is my secret key. Settings those correctly in my .env file allowed me to upload a file to the S3 bucket.






              share|improve this answer
























                1












                1








                1






                I was mixing up my "key" and "secret".



                As per the keystone-storage-adapter-s3 package, required are your "key" and "secret". Having inexperience with AWS, and some with web development, I thought the secret was a random secure string (like you would sign a cookie with) and the key was my secret key.



                wrong




                • "key" : Secret Key

                • "secret" : Random secure key.


                correct




                • "key": Key ID

                • "secret": Secret key.


                Turns out I was wrong. The "key" is my key id, and the "secret" is my secret key. Settings those correctly in my .env file allowed me to upload a file to the S3 bucket.






                share|improve this answer












                I was mixing up my "key" and "secret".



                As per the keystone-storage-adapter-s3 package, required are your "key" and "secret". Having inexperience with AWS, and some with web development, I thought the secret was a random secure string (like you would sign a cookie with) and the key was my secret key.



                wrong




                • "key" : Secret Key

                • "secret" : Random secure key.


                correct




                • "key": Key ID

                • "secret": Secret key.


                Turns out I was wrong. The "key" is my key id, and the "secret" is my secret key. Settings those correctly in my .env file allowed me to upload a file to the S3 bucket.







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Nov 19 '18 at 15:38









                Dylan Landry

                759




                759






























                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.





                    Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                    Please pay close attention to the following guidance:


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53377387%2ffield-errors-after-using-keystone-storage-adapter-s3%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

                    MongoDB - Not Authorized To Execute Command

                    Npm cannot find a required file even through it is in the searched directory

                    in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith