Skip to content

tsealex/Robohash

 
 

Repository files navigation

RoboHash

The source code for RoboHash.org.

It basically copy/pastes various robot pictures together, using bits from the SHA hash. It's not perfect, and not entirely secure, but it gives a good gut-check to "Hey, this SHA is wrong."

Install

Just the library:

$ pip install robohash

Or if you also want the web frontend:

$ pip install robohash[web]

Usage

from robohash import Robohash

hash = "whatever-hash-you-want"
rh = Robohash(hash)
rh.assemble(roboset='any')
with open("path/to/new/file.png", "wb") as f:
    rh.img.save(f, format="png")

Robosets

RoboHash comes with five image sets, named "set1", "set2", "set3", "set4" and "set5". Specify which set you want in the assemble() method. Alternatively, specify the string "any", and RoboHash will pick an image set for you, based on the provided hash.

License

The Python Code is available under the MIT/Expat license. See the LICENSE.txt file for the full text of this license. Copyright (c) 2011, Colin Davis.

Feel free to embed the Robohash images, host your own instance of Robohash, or integrate them into your own project. If you do, please just mention where they came from :) Example wording might be "Robots lovingly delivered by Robohash.org" or similar.

The "set1" artwork (and robohash backgrounds) were created by Zikri Kader. They are available under CC-BY-3.0 or CC-BY-4.0 license.

The "set2" artwork was created by Hrvoje Novakovic. They are available under CC-BY-3.0 license.

The "set3" artwork was created by Julian Peter Arias. They are available under CC-BY-3.0 license.

The Cats/"set4" were created by David Revoy, used under CC-BY-4.0 https://www.peppercarrot.com/en/article391/cat-avatar-generator

The avatars used in "set5" were created by Pablo Stanley, for https://avataaars.com/ They are "Free for personal and commercial use. 😇"

Cloud Setup

  1. Set up service: https://cloud.google.com/build/docs/deploying-builds/deploy-cloud-run#required_iam_permissions https://cloud.google.com/build/docs/deploying-builds/deploy-cloud-run#continuous_deployment
  2. Set up load balancer + CDN + SSL https://cloud.google.com/cdn/docs/setting-up-cdn-with-serverless#creating_the_load_balancer Make sure to create a serverless NEG (network endpoint group) during LB configuration
  3. Go to Cloud CDN and create an A record to point to the load balancer's address

Disclaimer

OK, I'll admit I'm a crappy programmer. Compounding this, I wrote this code initially to be internal-only. It's ugly, and could be a LOT nicer.

Sorry about that.

About

RoboHash.org

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 33.4%
  • CSS 23.2%
  • Python 23.1%
  • HTML 19.9%
  • Other 0.4%