Skip to main content

Ask is a modern open-source transpiled programming language, designed for building backend services and APIs. Ask reduces the amount of needed boilerplate code for setting up things like database connections and authentication to virtually zero lines.

Project description

Ask

Ask

CircleCI

Introduction.

Ask is an open source, dynamic, and transpiled programming language built for building backends and APIs. Ask directly transpiles to Python, more specifically Flask.

Feature Highlights

  • Built-in JWT Authentication.
  • Super Simple Database Management.
  • Syntax Inspired by Python.
  • Built-in CORS Support.
  • Reduces Boilerplate.
  • Compatible with Python*

* = You can import external Python modules and call them from you Ask code.

Easy to Learn

Ask's syntax is heavily inspired by Python, and can almost be considered to be a superset of Python. This means that picking up Ask is super easy if you’re already familiar with Python.

The main idea behind Ask is to simplify common backend actions (e.g. working with databases). Building a full database CRUD REST API with JWT authentication in Ask is very straight forward and simple and requires virtually zero lines of boilerplate code and no setup whatsoever.

Extendable.

Ask is a transpiled language (kind of like TypeScript) which means that it compiles the source code to another language that has a similar level of abstraction. In Ask's case, the target language is Python, more specifically a Flask app.

Flask is a very popular and well-established web framework for Python, so there's already a lot of tools, and services for deploying Flask apps.

The transpiled app is completely standalone and doesn't require Ask in any way.

Installation

  • You can install Ask from the PyPI. You can use pip but we recommend that you use pipx.
  • $ pipx install ask-lang.
  • Then run your apps with: $ ask [your file].ask.

Example (Ask vs Flask)

Here is the same basic app with one GET route written in Ask and in Python with Flask.

Ask

products = [
  {
    name: 'Product 1',
    price: 30.0,
    qty: 300
  },
  {
    name: 'Product 2',
    price: 15.5,
    qty: 20
  }
]

@get('/api/v1/products'):
  respond({products: products})

Flask

This is what the same application would look like in Flask.

from flask import Flask, jsonify

app = Flask(__name__)

products = [
  {
    'name': 'Product 1',
    'price': 30.0,
    'qty': 300
  },
  {
    'name': 'Product 2',
    'price': 15.5,
    'qty': 20
  }
]

@app.route('/api/v1/products', methods=['GET'])
def get_products():
  return jsonify({'products': products})

if __name__ == '__main__':
  app.run()

As you can see Ask hides away all the clutter and boilerplate.

Documentation

You can find the full documentation on docs.ask-lang.org

Contact

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ask_lang-1.0.6.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

ask_lang-1.0.6-py3-none-any.whl (53.6 kB view details)

Uploaded Python 3

File details

Details for the file ask_lang-1.0.6.tar.gz.

File metadata

  • Download URL: ask_lang-1.0.6.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Darwin/19.6.0

File hashes

Hashes for ask_lang-1.0.6.tar.gz
Algorithm Hash digest
SHA256 d0ab6f64dc5b74c845b7d1b07ca6453deab76bed855114a260a081403e30b96e
MD5 45b9cd7c590af2aab7795a598225a357
BLAKE2b-256 5253c89e3ac6979063bab7dc7505620e8c3da8fc516df5157a2a9050cc946e7d

See more details on using hashes here.

File details

Details for the file ask_lang-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: ask_lang-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 53.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Darwin/19.6.0

File hashes

Hashes for ask_lang-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 c702d9fd8237e21f9d1b4801f62bc64c67501396ab1c2783248cc8ae2b4ba1ab
MD5 80a5b2430538f6008f9956a11256d1e1
BLAKE2b-256 44800f7104d31321cea0b314535f8f7a44a8c51fece400144e758e6506d4987e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page