Manually Preparing and Syncing¶
If you don’t use Git, or you’re using a different Git hosting provider, you can still Glide using the new polyapi
commands:
prepare
which will find all your poly functions and prepare them for deployment, engaging AI for help filling in any missing documentation.sync
which will take our prepared functions and deploy them to your PolyAPI instance in the cloud.
Let’s see what these commands look like in practice:
Poly Prepare¶
Create a file called helloPoly.ts
and add the following code:
import { PolyServerFunction } from 'polyapi';
const polyConfig: PolyServerFunction = {
name: 'helloPoly',
context: 'myContext',
// you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
logsEnabled: true,
visibility: 'TENANT', // make this function visible to all environments in your tenant
};
function helloPoly(first_name: string): string {
return `Hello ${first_name}! I'm Poly, your helpful AI Assistant.`;
}
Run the following command in your console:
$ npx poly prepare
You’ll see Poly searching your whole repository for functions, finding your new myContext.helloPoly
server function, and preparing it for deployment.
And if you check helloPoly.ts
you’ll see it’s been updated with some JSDocs that should look something like this:
import { PolyServerFunction } from 'polyapi';
const polyConfig: PolyServerFunction = {
name: 'helloPoly',
context: 'myContext',
// you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
logsEnabled: true,
visibility: 'TENANT', // make this function visible to all environments in your tenant
};
/**
* Function that has Poly greet a user by their name
*
* @param {string} first_name - The user's first name
* @returns {string} Returns a greeting from Poly
*/
function helloPoly(first_name: string): string {
return `Hello ${first_name}! I'm Poly, your helpful AI Assistant.`;
}
Create a file called hello_poly.py
and add the following code:
from polyapi.typedefs import PolyServerFunction
polyConfig: PolyServerFunction = {
'name': 'hello_poly',
'context': 'myContext',
# you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
'logsEnabled': True,
'visibility': 'TENANT', # make this function visible to all environments in your tenant
}
def hello_poly(first_name: str) -> str:
return f"Hello {first_name}! I'm Poly, your helpful AI Assistant."
Run the following command in your console:
$ python3 -m polyapi prepare
You’ll see Poly searching your whole repository for functions, finding your new myContext.helloPoly
server function, and preparing it for deployment.
And if you check hello_poly.py
you’ll see it’s been updated with some docstrings that should look something like this:
from polyapi.typedefs import PolyServerFunction
polyConfig: PolyServerFunction = {
'name': 'hello_poly',
'context': 'myContext',
# you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
'logsEnabled': True,
'visibility': 'TENANT', # make this function visible to all environments in your tenant
}
def hello_poly(first_name: str) -> str:
"""Function that has Poly greet a user by their name
Args:
first_name (str): The user's first name
Returns:
str: Returns a greeting from Poly
"""
return f"Hello {first_name}! I'm Poly, your helpful AI Assistant."
You can add or update any descriptions to your satisfaction–these doc strings match what will be generated in your SDK.
At this point your functions should be prepared and ready to be synced to Poly.
Poly Sync¶
Warning
The Sync command should generally only be run from a single location per project and target Poly instance being deployed to.
If you’re working alone this is generally not a concern, but if you’re working with others: we recommend you setup a CI/CD workflow that will handle this in a central place for your team, and will handle caching the contents of your node_modules/.poly
directory to ensure the sync command can handle removing deployed functions after you delete them from your source code.
Run the following command in your console:
$ npx poly sync
If you didn’t already run the prepare step you might see the prepare step output as that must always happen before syncing (though it will be run without AI during a sync to avoid making any unintended changes). Then you’ll see additional console output deploying your function to poly.
And if you look at your helloPoly.ts
file one more time you’ll see an auto-generated comment at the top containing the Poly deployment receipt:
// Poly deployed @ 2024-09-20T21:58:31.264Z - myContext.helloPoly - https://na1.polyapi.io/canopy/polyui/collections/server-functions/f382e9df-d591-4080-93e0-9dc2d0297444 - 75a08d6
import { PolyServerFunction } from 'polyapi';
const polyConfig: PolyServerFunction = {
name: 'helloPoly',
context: 'myContext',
// you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
logsEnabled: true,
visibility: 'TENANT', // make this function visible to all environments in your tenant
};
/**
* Function that has Poly greet a user by their name
*
* @param {string} first_name - The user's first name
* @returns {string} Returns a greeting from Poly
*/
function helloPoly(first_name: string): string {
return `Hello ${first_name}! I'm Poly, your helpful AI Assistant.`;
}
Warning
The Sync command should generally only be run from a single location per project and target Poly instance being deployed to.
If you’re working alone this is generally not a concern, but if you’re working with others: we recommend you setup a CI/CD workflow that will handle this in a central place for your team, and will handle caching the contents of your polyapi/.poly
directory to ensure the sync command can handle removing deployed functions after you delete them from your source code.
Run the following command in your console:
$ python3 -m polyapi sync
If you didn’t already run the prepare step you might see the prepare step output as that must always happen before syncing (though it will be run without AI during a sync to avoid making any unintended changes). Then you’ll see additional console output deploying your function to poly.
And if you look at your hello_poly.py
file one more time you’ll see an auto-generated comment at the top containing the Poly deployment receipt:
# Poly deployed @ 2024-09-20T21:58:31.264Z - myContext.hello_poly - https://na1.polyapi.io/canopy/polyui/collections/server-functions/f382e9df-d591-4080-93e0-9dc2d0297444 - 75a08d6
from polyapi.typedefs import PolyServerFunction
polyConfig: PolyServerFunction = {
'name': 'hello_poly',
'context': 'myContext',
# you can also add in optional, additional configuration for your server function here using the helpful type hints provided by the imported PolyServerFunction type. For example:
'logsEnabled': True,
'visibility': 'TENANT', # make this function visible to all environments in your tenant
}
def hello_poly(first_name: str) -> str:
"""Function that has Poly greet a user by their name
Args:
first_name (str): The user's first name
Returns:
str: Returns a greeting from Poly
"""
return f"Hello {first_name}! I'm Poly, your helpful AI Assistant."
This comment shows you:
when the function was deployed
the name and context under which it was deployed
a link to the live function in the PolyUI web management UI (with the functions full unique id) where you can view runtime logs or execute the function manually
a checksum id for the file (excluding any header deployment comments as these comments do not impact your function in any way) which helps us ensure that the function you see in code always matches the live instance of it.
And that’s really all there is to it. You can continue to create new functions in a similar manner as you’ve just done, and run the same commands to prepare and sync them all.