-
Notifications
You must be signed in to change notification settings - Fork 551
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
Setting up the v3 endpoint (503 error) #294
Comments
I'm having the same issue. I noticed that another site who has a currently working Staticman configuration is using the endpoint https://api.staticman.net/v3/... rather than https://dev.staticman.net/v3/... |
Yeah, I'm just adding staticman into my jekyll blog and am having the same experience. Wasn't able to get it to work with v2, so trying v3 and just getting back the 500 This is the post body that gets sent:
I do have the Staticman app added to my repo: It would be super helpful if the json response returned another |
When using api.staticman.net, sometimes I'd get the error:
I switched to dev.staticman.net and now everything seem to work fine. Also make sure that the correct form prams are being sent, because the error responses being sent back from staticman, sometimes are not accurate. |
I have same issue. I've tired both of https://api.staticman.net/v3 and https://dev.staticman.net/v3. And still, I got 500 error. |
@gayanW , the static comments on your site (for example this blog post (https://www.linuxdeveloper.space/install-windows-after-linux) are not working anymore. |
@gayanW Switching to the official development instance is contrary to what the project owner suggests in #278 (comment). Anyways, I suggest using alternative instance (i.e. anything but official) to avoid unexpectation service disruption due to unnotified updates in the official instance. Here's a hosting guide on Data Science Blog. You may also refer to some successful examples running Staticman v3 like
P.S. Having recommended an alternative instance, I have to mention that I maintain @staticmanlab, a public GitLab instance which you're free to use. In this case, you won't need to self-host an API instance. |
@VincentTam You mentioned that @staticmanlab is a Gitlab instance, will it cause troubles if used with a Github repo? |
It's the contrarary: it provides freedom for users, espeicall those suffering from the official instances' API limits, to choose between GitHub & GitLab. This provides convenience for those spending hours on "invitation not found" and/or "too many requests". For some GitHub Pages served by @staticmanlab, you may click on the bot's user page and consult its activities. You may also see the homologous GitLab user profile. Some of my minimal working demo on GitHub: P.S. Due to a Framagit user's unsuccessful trial to add Staticman support, I've created another instance served by @staticmanlab1. |
@VincentTam You have made lots of changes in your staticman instance compared to the original one. Should I clone your instance and try to host it on Heroku and see if it works? |
@sachin10101998 From the user profile of @staticmanlab, you can see that my instance works. My |
Hey @VincentTam I forked and deployed your The Heroku logs only show this:
And this is the response I get in PostMan. Should I maybe try using a different branch? I've been trying to get staticman to work for 2 months now, and it's very frustrating. Jumping from GitHub issue to issue trying to piece together various bits of info is very time consuming. I feel it would be worth updating the official documentation with instructions about the new recommended practice (deploying your own instance instead of using the shared public one), and which branches are stable and should be used. I appreciate any insight you can give into this issue. Thanks! |
The linked instructions are written by @matdoering. Perhaps he can also provide you insights. I can spot out two errors in your previous message: repo config error and testing error.Have you read my article about Staticman errors? I've listed different kind of possible errors along with their causes. The 500 error code with simply "success: false" is possibly due to reCAPTCHA error.
No, it works fine, as you can see from the activities of @staticmanlab.
As a non-developer for the moment, the only way I know is the most primitive one: It would be more helpful to provide more details of your instance and the link of your target repo https://github.com/deadlydog/deadlydog.github.io, so that we can look into it and try reproducing the error, like some important API parameters ( Let's take a look at your repo config file: https://github.com/deadlydog/deadlydog.github.io/blob/1b2bf011716c045affe8b0e697e45fb4a44b233e/staticman.yml#L97-L104 # reCaptcha
# Register your domain at https://www.google.com/recaptcha/ and choose reCAPTCHA V2
reCaptcha:
enabled: true
siteKey: "6LexzqgUAAAAACjnxAhDpsymtZKy3ymJFRbVNWKU"
# Encrypt reCaptcha secret key using Staticman /encrypt endpoint
# For more information, https://staticman.net/docs/encryption
secret: "6LexzqgUAAAAAJjkczlwT888oWg48CeU8x3MrNlc" You've enabled reCAPTCHA in your target repo, so the API server is expecting reCAPTCHA parameter from the POST request.It's clear from your screenshot that this 500 error is due to the lack of reCAPTCHA parameters.
|
if ( | |
reCaptchaOptions.siteKey !== siteConfig.get('reCaptcha.siteKey') || | |
decryptedSecret !== siteConfig.get('reCaptcha.secret') | |
) { | |
return reject(errorHandler('RECAPTCHA_CONFIG_MISMATCH')) | |
} |
Encrypted secret
should look like the following.
reCaptcha:
enabled: false
# siteKey: "6Lcv8G8UAAAAAEqV1Y-XEPum00C_DxhD6O--qkFo"
# ENCRYPT reCaptcha secret key using Staticman /encrypt endpoint
# i.e. https://{STATICMAN API INSTANCE}/v3/encrypt/{your-site-secret}
# For more information, visit https://staticman.net/docs/encryption
# secret: "p5uHlH9hCqpMJaGKXdt5MEWFo7K6fX8hoYUwR3aIafOI6rtItLauaDCkGOucysJtrVZy+sHffioGzMsOU64JFDSyPQgrXujegcOHFRXHhD4fOUuBXSvV+OZ8JhSPTGWaRcQcoiGX4pT5hlebLddOl59b6sn6kU1ODQcEbhP83xVLZlaTWOrNrF5Wvy3TMXpH5gyl1tZEORxADAShMYyUbNR7XZYLEg1DfgIBHfIg3cKwdFt7KVLejFGKIiBYRAZDE2JuHItNmzJ2x9JgSK3E+XnShV5tuWpncnyFonJVHGEky/zRfUVLHobDMcJ/u9nlZqE8u47W+833F1WaIYuwNw=="
The Heroku logs only show this:
2019-08-02T06:54:01.792329+00:00 heroku[router]: at=info method=POST path="/v3/entry/github/deadlydog/deadlydog.github.io/master/comments?fields%5Bmessage%5D=Testing+comments&fields%5Bname%5D=Dan&fields%5Bemail%5D=deadlydog%40hotmail.com&fields%5Burl%5D=&options%5Bslug%5D=powershell-log-levels-included-in-tfs-2017-and-vsts-build-and-release-logs&fields%5Bhidden%5D=" host=dansblog-staticman.herokuapp.com request_id=8b3e4f93-3a6c-46b0-a477-2ad6abb99aa2 fwd="71.17.152.95" dyno=web.1 connect=1ms service=329ms status=500 bytes=353 protocol=https
Your test procedures might not be correct, from my experience in #219 (comment).
@ ntsim Thank you so much for your patience and help! 😀 It finally worked on my forked project.
If I start the project from scratch, do I need to manually create comments folder?
During my testing last year, the form key and values didn't show up in the POST URL.
Should I maybe try using a different branch?
Yes and no.
- Yes: try my PR Multiline field markdowntable for Staticman v3 #301, which fixed Fix line-break formatting in pull requests #90. 😄
- No: in case you get tired of testing, and you want to stick with your working version.
I've been trying to get staticman to work for 2 months now, and it's very frustrating. Jumping from GitHub issue to issue trying to piece together various bits of info is very time consuming.
However, learning from Stack Overflow involves jumping from questions to questions, and research requires reading from different pieces of info. Links to issues are a means for reference and supporting one's ideas. The past experience described in the issues helps other future users. If you feel that jumping from issues to issues are tiring, then just skip reading and learn from your own errors, until you're so tired with errors that you've the patience to read issues 😈.
I feel it would be worth updating the official documentation with instructions about the new recommended practice (deploying your own instance instead of using the shared public one), and which branches are stable and should be used.
Documentation requests like #291, #293 are inactive. Recent attempts to update the README in #232 and #256 don't receive response from the project owner. Even #298 doesn't get a direct response (despite @staticmanapp responded with its disappearance). Given the status of these issue, I would better save my effort in testing and writing guides and documentation for other repo. Here's a non-exhausive list of references that provide info about setting up Staticman:
- 🍖 Barebone example by Nicolas Tsim, the author of Add GitLab support #219 and Allow auth identity provider selection using
provider
query parameter #231: https://gitlab.com/nstim/test-staticman (requires internal access). The info at the top of Add GitLab support #219 is extremely useful. It's the reference for Staticman v3 API endpoints. - 📓 Beautiful Jekyll's README.
- 📖 Minimal Mistake's docs page
- 🔢 My upvoted answer on Math.Meta.SE
- Docs on my Minimo + Framagit + Staticman demo site
- Hugo Swift Theme's README
- README in my improved version of Hugo Theme Huginn
- And last, but not least, Staticman's outdated docs page
As the name "Lab" in "Staticman Lab" suggest, it's supposed to be a laboratory for testing. That's why I feel no guilt using a Heroku free dyno. That's no obligations about testing, in which we found out the errors, discuss and correct them so that things work.
I appreciate any insight you can give into this issue. Thanks!
Give me 👍 or ❤️ if you appreciate it. 🔊 Sharing Staticman guides and helping future users in return are even better.
Thanks so much for the detailed reply @VincentTam and the Issues/PRs on my personal blog :) I had not seen your blog with staticman errors, and it looks like it does have something to do with the Recaptcha settings. I still have not been able to completely figure it out; if I disable Recaptcha completely then comments work, but when enabled (using an encrypted site key and Recaptcha v2, or v3) it still fails. I don't understand why when I use the exact same request from PostMan to my personal staticman instance that it succeeds when I have my blog settings set to not use Recaptcha, but fails when it is set to use Recaptcha. That is a setting set in my blog GitHub repo (jekyll site), not my heroku staticman instance, so I find it weird that a different client's setting affects the server response. That is, my PostMan request is the exact same all the time, and is making a request to my staticman instance, so why does my blog GitHub setting affect the response returned by the staticman instance? Or does my staticman instance somehow check that setting in my GitHub repo before opening the PR against it? Thanks again for all your help! At the very least you've helped me get comments working without Recaptcha enabled, and made some good suggestions in your PRs 👍 I truly appreciate it :) |
The root-level Staticman config file
According to #264 (comment), Staticman shouldn't care whether GitHub Pages are used or not. See my list of Staticman demo sites on Framagit for Hugo &/or Jekyll examples.
Credits to Nicholas Tsim, the author Staticman's GitLab integration, who guided me through testing his PR.
You may consult my demos on Framagit to get reCAPTCHA works, especially Minimal Mistakes: |
Thank you for the reply again @VincentTam . Consulting that demo and it's source code helped me get everything working. Essentially I had 2 problems that were preventing me from getting ReCaptcha working:
Thanks so much for your help. I'm going to spend a bit of time to see if I can edit the code to have it return back the actual error message in the web response to make troubleshooting these issues easier for others in the future. Thanks so much for your help! |
░░░░░░░░░░░░▄▄ |
Duplicate of #318 |
Hello! I've been reading most of the issues because I couldn't connect my repository with the v2 endpoint. Figured out it was maybe already overloaded or didn't accept new user's request anymore.
So I found out the about the new Staticman app on Github, connected it to my repo, and set everything for a post request to "https://dev.staticman.net/v3/entry/github/felixdb/inbeat-website/master/comments", but keep getting a 503 from Heroku. I also tried "https://dev.staticman.net/v3/entry/github/felixdb/inbeat-website/master" and tried to post vit Postman.
You can see my repo here and my settings here. Anything I'm doing wrong? You can also test here, the form is hidden with CSS but you should find it easily with inspect tool and unhide it.
Thanks for helping out, this project is awesome and I've been looking forward to try it :)
The text was updated successfully, but these errors were encountered: