1 13-API


1.1 Data serialization

To export a data structure (dict, list), dump it as a string,
in a serialization format:
https://en.wikipedia.org/wiki/Serialization
https://en.wikipedia.org/wiki/XML
https://en.wikipedia.org/wiki/JSON
https://en.wikipedia.org/wiki/YAML
https://en.wikipedia.org/wiki/TOML
Then, you can re-import the serialized plain text string,
and have your data structure back!

The classic Unix philosopy stated that programs should input and output plain text, so they may be piped and composed.
Recent innovative programming languages extend that notion, by piping serialized plain text.
Serializing I/O with programs improves composability and abstraction.

Classic BSD-socket clients and servers input and output plain-text data as networking protocol.
Recent networking protocls extent that notion, by tunneling serialized plain text.
Serializing I/O with network endpoints streamlines protocol design and interoperability.

1.2 User interface

https://en.wikipedia.org/wiki/User_interface
A computer’s user interface is for a person.

1.3 Applcation Programming Interface (API)

https://en.wikipedia.org/wiki/API
https://www.redhat.com/en/topics/api/what-are-application-programming-interfaces
An API defines how two or more computer programs or components to communicate with each other.
It is a software interface, offering an automated service to other pieces of software.
A document or standard that describes how to build or use the interface is an API specification.
A system that meets this standard is said to implement, or expose, an API.
A client program may call or execute parts of the API.
The calls that make up the API are also known as:
subroutines, methods, requests, or endpoints.
An API specification defines these calls,
meaning that it explains how to use or implement them.

1.4 Networking protocols as API

In addition to local software APIs via libraries, modules, etc.,
one can see the following as APIs:

plaint-text networking protocols,
POSIX sockets,
POSIX itself,
etc.

1.5 Higher level Web tools

Rather than use a web browser, or write HTTP requests and responses manually,
one can use an HTTP library, which allows a higher level interface to custom HTTP messages:
https://docs.python-requests.org/en/latest/index.html

Demo this in class:

import requests

r = requests.get("http://info.cern.ch")
r.text
r.content
r.raw

r = requests.get("https://api.github.com/events")
r.url
r.text
r.json()

# To pretty print:
print(json.dumps(r.json(), indent=4))

# Custom headers:
url = "https://api.github.com/some/endpoint"
headers = {"user-agent": "my-app/0.0.1"}
r = requests.get(url, headers=headers)

# Post headers:
payload = {"key1": "value1", "key2": "value2"}
r = requests.post("https://httpbin.org/post", data=payload)
print(r.text)

1.6 Remote API

Remote APIs allow developers to manipulate remote resources through networked protocols.
An API call, executed locally on a proxy object,
invokes the corresponding method on the remote object,
using the remote protocol,
and acquires the result to be used locally,
potentially changing the object remotely.

1.7 Synchronous versus asynchronous

An application programming interface can be synchronous or asynchronous.

A synchronous API call is a design pattern where the call site is blocked,
while waiting for the called code to finish.

With an asynchronous API call,
the call site is not blocked while waiting for the called code to finish,
and instead, when the reply arrives, the calling thread is notified.

1.8 Microservices

https://en.wikipedia.org/wiki/Microservices
Loosely coupled services accessed through public APIs.

1.9 Web API

https://en.wikipedia.org/wiki/API#Web_APIs
https://en.wikipedia.org/wiki/Web_API
Web APIs are a service accessed from client devices (mobile phones, laptops, etc.),
connecting to a web server, using the Hypertext Transfer Protocol (HTTP).

Client devices send a request in the form of an HTTP request,
and are met with a response message,
usually in JavaScript Object Notation (JSON) or
Extensible Markup Language (XML) format.

A server-side web API consists of one or more publicly exposed endpoints,
to a defined request–response message system,
typically expressed in JSON or XML.
The web API is exposed most commonly by means of an HTTP-based web server.

1.9.1 SOAP API

https://en.wikipedia.org/wiki/SOAP
SOAP (formerly an acronym for Simple Object Access Protocol) is a messaging protocol specification for exchanging structured information in the implementation of web services in computer networks.
It uses XML Information Set for its message format, and relies on application layer protocols, most often Hypertext Transfer Protocol (HTTP), although some legacy systems communicate over Simple Mail Transfer Protocol (SMTP), for message negotiation and transmission.

1.9.2 SOA API

https://en.wikipedia.org/wiki/Service-oriented_architecture

1.9.3 ROA API

https://en.wikipedia.org/wiki/Resource-oriented_architecture

1.9.4 GraphQL

https://en.wikipedia.org/wiki/GraphQL

1.9.5 REST and RESTful API

https://en.wikipedia.org/wiki/REST
https://en.wikipedia.org/wiki/Overview_of_RESTful_API_Description_Languages
https://www.redhat.com/en/topics/api/what-is-a-rest-api
https://en.wikipedia.org/wiki/OpenAPI_Specification
https://stackoverflow.com/questions/671118/what-exactly-is-restful-programming

REST (Representational State Transfer) APIs tunnel json data through HTTP.
A REST API allows remote functions (endpoints) to be called via urls.
Lookups should use GET requests.
PUT, POST, and DELETE requests should be used for
mutation, creation, and deletion respectively.
The json data often contains informatino about the needed HTTP methods (GET, PUT, etc.).

The formal REST constraints are as follows:

Client/Server:
Client are separated from servers by a well-defined interface.

Stateless:
A specific client does not consume server storage when it is “at rest”.

Cache:
Responses indicate their own cacheability.

Uniform Interface:
Individual resources are identified in requests using URIs.

Layered System:
A client cannot ordinarily tell whether it is connected directly to the end server,
or to an intermediary along the way.

Code on Demand (optional):
Servers are able to temporarily extend or customize the functionality of a client,
by transferring logic to the client that can be executed within a standard virtual machine.

API/rest-api_1.png
API/rest-api_2.png
API/rest-api_3.png
API/rest-api_4.png
API/rest-api_5.png

1.9.5.1 Example: NASA

NASA has some accessible APIs:
https://api.nasa.gov/

For example, Astronomy Picture Of the Day (APoD):
https://api.nasa.gov/planetary/apod

The documentation states that this endpoint accepts GET requests.
It requires one piece of information from the user, an API key,
and accepts several other optional pieces of information.
Such pieces of information are known as parameters.
The parameters for this API are written in a format known as a query string,
which is separated by a question mark character (?) from the endpoint.
An ampersand (&) separates the parameters in the query string from each other.
Together, the endpoint and the query string form a URL,
that determines how the API will respond.
This URL is also known as a query or an API call.

In the below example, two parameters are transmitted (or passed) to the API via the query string.
The first is the required API key and the second is an optional parameter — the date of the photograph requested.

Open this in a browser (thus using GET request):
https://api.nasa.gov/planetary/apod?api_key=DEMO_KEY&date=1996-12-03

Or, run this in python:

import requests
import json

r = requests.get("https://api.nasa.gov/planetary/apod?api_key=DEMO_KEY&date=1996-12-03")
print(json.dumps(r.json(), indent=4))

1.9.5.2 Example: https://weather.gov

https://www.weather.gov/documentation/services-web-api
https://weather-gov.github.io/api/

1.10 Webhooks

https://en.wikipedia.org/wiki/Webhook
https://www.redhat.com/en/topics/automation/what-is-a-webhook
Instead of asking the server for data,
as the server to send data when a condition is met.
Despite their nicknames, webhooks are not APIs;
they work together.
An application must have an API to use a webhook.

1.11 Demonstrations of API specifications:

Three class-related examples follow:

1.11.1 Gitlab API

https://docs.gitlab.com/ee/api/rest/
https://docs.gitlab.com/ee/api/repositories.html
assigner project example.

1.11.2 Canvas API

https://canvas.instructure.com/doc/api/
https://community.canvaslms.com/t5/Canvas-Developers-Group/Canvas-APIs-Getting-started-the-practical-ins-and-outs-gotchas/ba-p/263685
assigner project example.

1.11.3 Zulip API

https://zulip.com/api/rest

1.11.4 Client software example

We use this software to manage your assignments:
https://github.com/redkyn/assigner
It uses web requests as a client to both the Canvas and Gitlab REST APIs.

1.12 Potential REST assignment

Show this in class!

1.13 Security

We can think of the security of API interaction in two parts:
1. The network connection
2. The endpoints (server and client)

1.13.1 The network connection itself

In any HTTPS connection, first a TLS connection is made,
and then HTTP data are tunneled through it.
Thus, if you are using any modern library, for example requests,
then the network part of the token is secured.
Issues arise if you browser, or the server, log any access token, key, or password,
based on the way you send it in code, or the way you store it on disk.

Demo this with wget, curl, python requests, in Wireshark.
https://api.nasa.gov/

Others just rely on a token via requests:
https://docs.gitlab.com/ee/api/personal_access_tokens.html
https://canvas.instructure.com/doc/api/file.oauth.html#using-access-tokens

Some have their own library API for the REST API:
https://zulip.com/api/configuring-python-bindings

1.13.2 The endpoints

How do you improve the security of tokens stored on disk?

Background: discuss the way RSAa and GnuPG Keys are secured on disk.

Demo securing the NASA API above.
This is the ideal way to interact with GnuPG in code:
https://www.gnupg.org/software/gpgme/index.html
https://www.gnupg.org/documentation/howtos.html
https://www.gnupg.org/documentation/manuals/gpgme/

Here’s an example:
http://files.au.adversary.org/crypto/gpgme-python-howto.html#howto-basic-decryption

Where API_TOKEN_KEY.gpg is a gpg2 encrypted text file containing the decrypted token:

DEMO_KEY

To generate:

echo "DEMO_KEY" >temp
gpg2 --gen-key # Name: bob, Email: bob@alice@com, Password: 1234
gpg2 --encrypt --output API_TOKEN_KEY.gpg --recipient bob@alice.com temp
rm temp

And a python script: secure_rest_client.py:

#!/usr/bin/python3
# -*- coding: utf-8 -*-

import requests
import json
import gpg

with open("API_TOKEN_KEY.gpg", "rb") as ciphertext_file:
    try:
        key, result, verify_result = gpg.Context().decrypt(ciphertext_file)
        key = key.decode().strip()
    except gpg.errors.GPGMEError as e:
        key = None
        print(e)

r = requests.get(f'https://api.nasa.gov/planetary/apod?api_key={key}&date=2024-05-01')
print(r.text, "\n")
print(r.content, "\n")
print(r.raw, "\n")
print(json.dumps(r.json(), indent=4))

1.14 MediaWiki API

https://www.mediawiki.org/wiki/MediaWiki
https://en.wikipedia.org/wiki/MediaWiki
MediaWiki is used for many Wikis, and it has a REST API:
https://www.mediawiki.org/wiki/API:REST_API

For example:
https://www.snpedia.com/
https://en.wikipedia.org/wiki/SNPedia
https://www.snpedia.com/index.php/Bulk
https://bots.snpedia.com/api.php
Discussed in more depth here:
../../Bioinformatics/Content/25-WGS.html

1.15 Humor

https://www.reddit.com/r/ProgrammerHumor/comments/6pylb0/hello_id_like_to_hear_a_restful_api_joke/