Update 07/01/20:

Ahora Amazon te permite publicar de forma automática una skill en todos los paises con el mismo idioma > https://developer.amazon.com/en-US/docs/alexa/faq/distribute-your-skill-to-additional-locales-of-the-same-language.html

Uno de los temas que me parece interesante a la hora de crear una skill es la posibilidad de publicarla en otros países. Y, dependiendo de la skill, puede ser una tarea bastante sencilla.

En mi caso, para la skill de Estrenos de cine, me llevó apenas unas horas preparar el backend y luego crear los modelos de interacción para español de México y español de Estados Unidos. Además la API que uso me ofrece la posibilidad de indicarle tanto la región como el idioma para los resultados.

Mi idea es publicarla también en inglés en distintos países, italiano, francés y portugués. Todos son idiomas que tanto la API como Alexa soportan. Pero, de momento, solo la tengo en español para tres países distintos y es lo que os voy a contar en este post.

Preparando el backend

En cada petición de un usuario vamos a tener la información del locale. Los locale soportados por Alexa están en la documentación oficial y tienen el siguiente formato: es-ES o es-MX para España o para México respectivamente. Por tanto de ahí podremos sacar las dos cosas que nos hacen falta: idioma y país.

Tenemos que adaptar:

  • A la hora de enviar la petición a la API le tenemos que pasar tanto el idioma como la región.
  • A la hora de crear las respuestas para el usuario debemos tener en cuenta, al menos, el idioma. Dependiendo del tipo de lenguaje/frases que usemos puede que no haga falta localizarlas por país también. En mi caso creo que he usado unos textos bastante neutros en ese sentido y no he creado una variante para cada país (España, México y Estados Unidos) pero podría hacer falta.

Ya de paso, todo lo que hagamos ahora no solo debería servir para países con español sino para cualquier otro como el inglés, el francés, etc.

Pasando a la API el idioma y el país

Según la especificación de la API podemos pasarle:

  • El language con un formato equivalente a lo que nos viene ya en la request.
  • La region con un formato equivalente a la "parte final" del locale de la request.

Por tanto yo hice un código muy simple que solo serviría con el formato actual:

Y a la hora de llamar a la API le paso la info en esos dos campos:

Localizando los textos para distintos idiomas

La otra parte a cubrir es tener textos localizados por idioma a la hora de elaborar la respuesta al usuario. Aunque yo solo tengo la skill publicada en español, quise dejar lista una solución para cubrir, al menos, casos de distintos idiomas. Pero, como decía antes, lo que hice no cubre si para un mismo idioma pero de distintos países quisiéramos tener textos distintos.

Hice una solución casera basada en una matriz de textos por idioma. No quise meterme en usar alguna librería ni le di muchas más vueltas pero todo feedback es bien recibido :)

Voy pidiendo los textos donde corresponda de usando las key del mapa que había definido.

Creando los nuevos modelos de interacción

Añadir un modelo de interacción en nuevo idioma para una skill existente es muy sencillo. Lo podemos hacer todo desde la Alexa Developer Console.

En la pestaña de Build tenemos un desplegable con los distintos idiomas que soporta nuestra skill. En mi caso ya veis los tres que os decía al inicio del post.

Para añadir uno nuevo simplemente tenemos que ir a Language Settings y usar la opción de Add new language.

Seleccionamos el idioma que queremos añadir y se listará en la tabla con el resto.

Imaginemos que añadimos English (US). Una vez aparezca en el listado solo tenemos que pulsar el botón de Save y ya lo tendríamos disponible desde la pestaña de Build.

Al añadir un nuevo idioma se crea una modelo de interacción vacío pero usando el JSON Editor resulta muy sencillo importar el existente en otro idioma.

En mi caso, al ser los tres idiomas que tengo en español, simplemente copié el modelo de interacción de Spanish (Spain) desde el JSON Editor y lo pegué en los otros dos (para Spanish US y Spanish MX). De esta forma tenía ya el modelo en los tres idiomas. A partir de ahí ya podemos hacer modificaciones a los utterance si hay palabras o expresiones que son particulares en algunos países.

Una vez tenemos el modelo ya podemos pasar a rellenar la información de Distribution para cada nuevo idioma y enviar la skill a certificar :)

Antes de terminar, es una buena práctica crear varios backend en distintas regiones de AWS si vamos a publicar nuestra skill en varios países. Desde la pantalla de Endpoint vamos a poder indicar la ruta de cada una de las lambdas.

De esta forma la latencia y rendimiento de nuestra skill será mejor para los nuevos países. No es obligatorio pero sí muy recomendado. Solo tenemos que crear lambdas nuevas y desplegar el backend. La pega es que aumenta la gestión de despliegues con cambios en el backend. Aún no tengo muchos conocimientos de AWS pero es posible que haya ya algo inventado para mantener sincronizados los despliegues de distintas lambdas.


Conseguir crear skills que se puedan publicar en varios países va a aumentar drásticamente el público accesible y el número de usuarios potenciales de la misma.

Los desarrolladores que las estamos creando en español tenemos una gran oportunidad ahora con ya tres países disponibles. Lo mismo si creas alguna en inglés donde ahora mismo hay cinco países disponibles. Además supongo que se irán abriendo más y el esfuerzo necesario es mínimo a veces. Seguro que será un tiempo bien invertido :)