Publishing your package
Now that your package is implemented and tested, you can:
- Publish your package to PyPi
- Add documentation for your package to the LangChain Monorepo
Publishing your package to PyPi
This guide assumes you have already implemented your package and written tests for it. If you haven't done that yet, please refer to the component-specific guides.
Note that Poetry is not required to publish a package to PyPi, and we're using it in this guide end-to-end for convenience. You are welcome to publish your package using any other method you prefer.
First, make sure you have a PyPi account and have logged in with Poetry:
How to create a PyPi Token
- Go to the PyPi website and create an account.
- Verify your email address by clicking the link that PyPi emails to you.
- Go to your account settings and click "Generate Recovery Codes" to enable 2FA. To generate an API token, you must have 2FA enabled currently.
- Go to your account settings and generate a new API token.
poetry config pypi-token.pypi <your-pypi-token>
Next, build your package:
poetry build
Finally, publish your package to PyPi:
poetry publish
You're all set! Your package is now available on PyPi and can be installed with pip install langchain-parrot-link
.
Adding documentation to the LangChain Monorepo
To add documentation for your package to the LangChain Monorepo, you will need to:
- Fork and clone the LangChain Monorepo
- Make a "Provider Page" at
docs/docs/integrations/providers/<your-package-name>.ipynb
- Make "Component Pages" at
docs/docs/integrations/<component-type>/<your-package-name>.ipynb
- Register your package in
libs/packages.yml
- Submit a PR with only these changes to the LangChain Monorepo
Fork and clone the LangChain Monorepo
First, fork the LangChain Monorepo to your GitHub account.
Next, clone the repository to your local machine:
git clone https://github.com/<your-username>/langchain.git
You're now ready to make your PR!
Bootstrap your documentation pages with the langchain-cli (recommended)
To make it easier to create the necessary documentation pages, you can use the langchain-cli
to bootstrap them for you.
First, install the latest version of the langchain-cli
package:
pip install --upgrade langchain-cli
To see the available commands to bootstrap your documentation pages, run:
langchain-cli integration create-doc --help
Let's bootstrap a provider page from the root of the monorepo:
langchain-cli integration create-doc \
--component-type Provider \
--destination-dir docs/docs/integrations/providers \
--name parrot-link \
--name-class ParrotLink
And a chat model component page:
langchain-cli integration create-doc \
--component-type ChatModel \
--destination-dir docs/docs/integrations/chat \
--name parrot-link \
--name-class ParrotLink
And a vector store component page:
langchain-cli integration create-doc \
--component-type VectorStore \
--destination-dir docs/docs/integrations/vectorstores \
--name parrot-link \
--name-class ParrotLink
These commands will create the following 3 files, which you should fill out with information about your package:
docs/docs/integrations/providers/parrot_link.ipynb
docs/docs/integrations/chat/parrot_-_link.ipynb
docs/docs/integrations/vectorstores/parrot_-_link.ipynb
Manually create your documentation pages (if you prefer)
If you prefer to create the documentation pages manually, you can create the same files listed above and fill them out with information about your package.
You can view the templates that the CLI uses to create these files here if helpful!
Register your package in libs/packages.yml
Finally, add your package to the end of the libs/packages.yml
file in the LangChain Monorepo.
packages:
- name: langchain-parrot-link
repo: <your github handle>/<your repo>
path: .
For path
, you can use .
if your package is in the root of your repository, or specify a subdirectory (e.g. libs/parrot-link
) if it is in a subdirectory.
If you followed the package bootstrapping guide, then your path is .
.
Submit a PR with your changes
Once you have completed these steps, you can submit a PR to the LangChain Monorepo with only these changes.
If you have additional changes to request, please submit them in a separate PR.