"git@ustchcs.com:wwwanlingxiao/mall.git" did not exist on "e63f19f819cf996cd26abdb1f56c19f02d3de0d4"
Unverified Commit c4855765 authored by Evgeny Blokhin's avatar Evgeny Blokhin Committed by GitHub
Browse files

Merge branch 'master' into patch-1

parents 6db368cd ec027b3f
...@@ -4,6 +4,8 @@ ...@@ -4,6 +4,8 @@
opened to market company APIs that offer paid solutions. This API list is not a marketing tool, but a tool to help the opened to market company APIs that offer paid solutions. This API list is not a marketing tool, but a tool to help the
community build applications and use free, public APIs quickly and easily. Pull requests that are identified as marketing attempts will not be accepted. community build applications and use free, public APIs quickly and easily. Pull requests that are identified as marketing attempts will not be accepted.
> >
> Please make sure the API you want to add has a full free access or at least a free tier before submitting.
>
> Thanks for understanding! :) > Thanks for understanding! :)
## Formatting ## Formatting
...@@ -12,7 +14,7 @@ Current API entry format: ...@@ -12,7 +14,7 @@ Current API entry format:
| API | Description | Auth | HTTPS | CORS | | API | Description | Auth | HTTPS | CORS |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- | --- |
| API Title(Link to API webpage) | Description of API | Does this API require authentication? * | Does the API support HTTPS? | Does the API support [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS)? * | | API Title(Link to API documentation) | Description of API | Does this API require authentication? * | Does the API support HTTPS? | Does the API support [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS)? * |
Example entry: Example entry:
...@@ -33,6 +35,8 @@ Example entry: ...@@ -33,6 +35,8 @@ Example entry:
* `No` - _the API does not support CORS_ * `No` - _the API does not support CORS_
* `Unknown` - _it is unknown if the API supports CORS_ * `Unknown` - _it is unknown if the API supports CORS_
_Without proper [CORS configuration](https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS) an API will only be usable server side._
Please continue to follow the alphabetical ordering that is in place per section. Each table column should be padded with one space on either side. Please continue to follow the alphabetical ordering that is in place per section. Each table column should be padded with one space on either side.
If an API seems to fall into multiple categories, please place the listing within the section most in line with the services offered through the API. For example, the Instagram API is listed under `Social` since it is mainly a social network, even though it could also apply to `Photography`. If an API seems to fall into multiple categories, please place the listing within the section most in line with the services offered through the API. For example, the Instagram API is listed under `Social` since it is mainly a social network, even though it could also apply to `Photography`.
......
Thank you for taking the time to work on a Pull Request for this project! <!-- Thank you for taking the time to work on a Pull Request for this project! -->
<!-- To ensure your PR is dealt with swiftly please check the following: -->
To ensure your PR is dealt with swiftly please check the following: - [ ] My submission is formatted according to the guidelines in the [contributing guide](CONTRIBUTING.md)
- [ ] My addition is ordered alphabetically
- [ ] Your submissions are formatted according to the guidelines in the [contributing guide](CONTRIBUTING.md) - [ ] My submission has a useful description
- [ ] Your additions are ordered alphabetically
- [ ] Your submission has a useful description
- [ ] The description does not end with punctuation - [ ] The description does not end with punctuation
- [ ] Each table column should be padded with one space on either side - [ ] Each table column is padded with one space on either side
- [ ] You have searched the repository for any relevant issues or pull requests - [ ] I have searched the repository for any relevant issues or pull requests
- [ ] Any category you are creating has the minimum requirement of 3 items - [ ] Any category I am creating has the minimum requirement of 3 items
- [ ] All changes have been [squashed][squash-link] into a single commit - [ ] All changes have been [squashed][squash-link] into a single commit
[squash-link]: <https://github.com/todotxt/todo.txt-android/wiki/Squash-All-Commits-Related-to-a-Single-Issue-into-a-Single-Commit> [squash-link]: <https://github.com/todotxt/todo.txt-android/wiki/Squash-All-Commits-Related-to-a-Single-Issue-into-a-Single-Commit>
name: "Run tests" name: "Run tests"
on: on:
- push schedule:
- pull_request - cron: '0 0 * * *'
push:
branches:
- master
pull_request:
branches:
- master
env: env:
FORMAT_FILE: README.md FORMAT_FILE: README.md
......
name: "Validate links"
on:
schedule:
- cron: '0 0 * * *'
push:
branches:
- master
env:
FORMAT_FILE: README.md
jobs:
test:
name: 'Validate links'
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v2
- name: Validate all links from README.md
run: build/validate_links.py ${FORMAT_FILE}
This diff is collapsed.
flake8>=3.5.0 flake8>=3.5.0
httplib2==0.9.2 httplib2==0.18.0
...@@ -11,38 +11,53 @@ def parse_links(filename): ...@@ -11,38 +11,53 @@ def parse_links(filename):
with open(filename) as fp: with open(filename) as fp:
data = fp.read() data = fp.read()
raw_links = re.findall( raw_links = re.findall(
'http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+', '((?:https?://|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'\".,<>?«»“”‘’]))',
data) data)
links = [raw_link.replace(')', '') for raw_link in raw_links] links = [raw_link[0] for raw_link in raw_links]
return links return links
def validate_links(links): def validate_links(links):
"""Checks each entry in JSON file for live link""" """Checks each entry in JSON file for live link"""
print('Validating {} links...'.format(len(links))) print(f'Validating {len(links)} links...')
errors = [] hasError = False
for link in links: for link in links:
h = httplib2.Http(disable_ssl_certificate_validation=True, timeout=5) h = httplib2.Http(disable_ssl_certificate_validation=True, timeout=25)
try: try:
resp = h.request(link, 'HEAD') resp = h.request(link, headers={
# Faking user agent as some hosting services block not-whitelisted UA
'user-agent': 'Mozilla/5.0'
})
code = int(resp[0]['status']) code = int(resp[0]['status'])
# check if status code is a client or server error # Checking status code errors
if code >= 404: if (code >= 300):
errors.append('{}: {}'.format(code, link)) hasError = True
print(f"ERR:CLT:{code} : {link}")
except TimeoutError: except TimeoutError:
errors.append("TMO: " + link) hasError = True
print(f"ERR:TMO: {link}")
except socket.error as socketerror: except socket.error as socketerror:
errors.append("SOC: {} : {}".format(socketerror, link)) hasError = True
return errors print(f"ERR:SOC: {socketerror} : {link}")
except Exception as e:
hasError = True
# Ignore some exceptions which are not actually errors.
# The list below should be extended with other exceptions in the future if needed
if (-1 != str(e).find("[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:852)")):
print(f"ERR:SSL: {e} : {link}")
elif (-1 != str(e).find("Content purported to be compressed with gzip but failed to decompress.")):
print(f"ERR:GZP: {e} : {link}")
elif (-1 != str(e).find("Unable to find the server at")):
print(f"ERR:SRV: {e} : {link}")
else:
print(f"ERR:UKN: {e} : {link}")
return hasError
if __name__ == "__main__": if __name__ == "__main__":
num_args = len(sys.argv) num_args = len(sys.argv)
if num_args < 2: if num_args < 2:
print("No .md file passed") print("No .md file passed")
sys.exit(1) sys.exit(1)
errors = validate_links(parse_links(sys.argv[1])) hasError = validate_links(parse_links(sys.argv[1]))
if len(errors) > 0: if hasError:
for err in errors:
print(err)
sys.exit(1) sys.exit(1)
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment