2020-04-21 21:55:39 +00:00
# search.nixos.org
This repository contains the scripts and the web application for
`search.nixos.org` .
## How this project came to be
Initial idea was to replace NixOS packages and options search which was
fetching one JSON file which contained all packages (or options). This approach
is good for its simple setup, but started to show its problems when packages
number was getting bigger and bigger. I'm sure we could optimize it further,
but ideas what all could we do if there would be some database in the back were
to tempting not to try.
For backend we are using Elasticsearch instance which is kindly sponsored by
[bonsai.io ](https://bonsai.io ). On the frontend we are using
[Elm ](https://elm-lang.org ).
2020-06-18 10:24:52 +00:00
## How search works?
The use case we want to solve is that a visitor want to see if a package
exists or to look up certain package's details.
A user wants to converge to a single result if possible. The more characters
are added to a search query the more narrow is search is and we should show
less results.
Very important is also ranking of search results. This will bring more relevant
search results to the top, since a lot of times it is hard to produce search
query that will output only one result item.
A less important, but providing better user experience. are suggestions for
writing better search query. Suggesting feature should guide user to write
better queries which in turn will produce better results.
2020-04-21 21:55:39 +00:00
## Development
To start developing open a terminal and run:
```
2022-07-28 13:11:00 +00:00
env --chdir=frontend nix develop -c yarn dev
2020-04-21 21:55:39 +00:00
```
You can point your browser to `http://localhost:3000` and start developing.
2022-04-07 21:13:06 +00:00
Any changes to source files (`./frontend/src`) will trigger a hot reload of an
2020-04-21 21:55:39 +00:00
application.
## Deploying
2022-03-17 07:13:53 +00:00
- On each commit to `main` branch a GitHub Action is triggered.
2020-04-21 21:55:39 +00:00
- GitHub Action then builds production version of the web application using
`yarn prod` command.
- The built web application (in `./dist` ) is then deployed to Netlify.
- GitHub Action can also be triggered via Pull Request, which if Pull Request
was created from a non-forked repo's branch, will provide a preview url in a
comment.
2021-11-23 12:58:38 +00:00
## Adding flakes
To add your own flakes to the search index edit [./flakes/manual.toml ](./flakes/manual.toml ).
Possible types are `github` , `gitlab` , and `git` (which is the fallback for any kind of git repository but requires to set a revision key manually as of now).
To test whether your flake is compatible with nix flake-info you can try running `flake-info` against it
```
2021-12-06 17:48:18 +00:00
$ nix run github:nixos/nixos-search#flake-info -- flake < your flake handle >
2021-11-23 12:58:38 +00:00
```