SkillAgentSearch skills...

Myip

(A better) What's My IP Address web application

Install / Use

/learn @bramp/Myip
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

MyIP License Build Status Report card

by Andrew Brampton (bramp.net)

<!-- Add these when available: [![Coverage](https://img.shields.io/coveralls/bramp/myip.svg)](https://coveralls.io/github/bramp/myip) [![GoDoc](https://godoc.org/github.com/bramp/myip?status.svg)](https://godoc.org/github.com/bramp/myip) -->

(A better) What's My IP Address web application. Determines both your IPv4 and IPv6 addresses, issues WHOIS and reverse DNS lookups, and shows all your HTTP headers.

Check it in action: ip.bramp.net or read about it on my blog.

ip.bramp.net screenshot

This project was quite literally hacked out in one weekend, and was my first App Engine project.

Install

Prerequisites

  • Google Cloud SDK

  • AppEngine Go SDK

    $ gcloud components install app-engine-go
    
  • Make (which comes on Linux or Mac)

  • npm

Domains

As designed, this Go application will run on the Standard Google App Engine. It requires two to three host names. One that is IPv4 only, and one that is IPv6 only. In my configuration I have ip.bramp.net that has both A and AAAA records, ip4.bramp.net that has only A records, and ip6.bramp.net that only has AAAA records. These all point to the same App Engine instance.

$ dig ip.bramp.net
ip.bramp.net.		300	IN	A	216.239.32.21
ip.bramp.net.		300	IN	AAAA	2001:4860:4802:32::15

$ dig ip4.bramp.net
ip4.bramp.net.		300	IN	A	216.239.32.21

$ dig AAAA ip6.bramp.net
ip6.bramp.net.		300	IN	AAAA	2001:4860:4802:32::15

All three domain names should be configured in main.go (find the prodConfig var).

Deployment

Deployment to Google App Engine is carried out by a Github Action - but to do it manually.

make stage  # Deploys to a new version but does NOT promote it (useful for testing)

This will show you which files will be included, and allow a staged version to become available. You can view the various staged versions on the cloud console.

If you see unexpected files in the list, update .gcloudignore accordingly.

Once ready use:

make deploy # Deploys to production and promotes the version

Development

To run locally we use the addresses, localhost:8080, 127.0.0.1:8080, and http://[::1]:8080. The first can be either, and the latter are IPv4 and IPv6 respectively.

To start up a local instance, just execute:

make serve

When running locally, the server runs in debug mode. Since your local IP address (e.g 127.0.0.1) won't return useful RDAP or WHOIS results, you can override the IP address by passing a host query parameter:

http://localhost:8080/?host=8.8.8.8

This also works with the JSON API:

http://localhost:8080/json?host=8.8.8.8

Note: The host parameter is only available in debug mode and is disabled in production.

To test:

make test

Libraries

To keep libraries up to date run:

make check-updates
make veryclean
make test

TODO

  • [ ] Add rate limiting of requests
  • [ ] Add caching of DNS and WHOIS records (including the iana IP ranges)
  • [ ] Add configuration file, so can be hosted on different domains
  • [ ] Add a favicon.ico
  • [ ] Add Make test (which checks with different build tags, e.g macos,appengine linux,appengine)
  • [ ] Implement a App Engine Flex, and other PaaS environments
  • [ ] Minify all css and js and combine into one file
  • [ ] Do better at determining the root cause errors. e.g If both IPv4/IPv6 fail, then perhaps problem with the site. If IPv6 fails after 30 seconds, perhaps problem with IPv6 connectivity.
  • [ ] Refactor the app. We don't need to seperate appengine and not appengine anymore. The code is almost identical.

Licence (Apache 2)

This is not an official Google product (experimental or otherwise), it is just code that happens to be owned by Google.

Copyright 2017,2020 Google Inc. All Rights Reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
View on GitHub
GitHub Stars63
CategoryDevelopment
Updated2d ago
Forks20

Languages

Go

Security Score

100/100

Audited on Mar 26, 2026

No findings