Independent Publisher connector krok po kroku
Spis treści:
Po pomyślnym opublikowaniu mojego pierwszego konektora w programie konektorów Independent Publisher (konektor myStrom), postanowiłem podzielić się z Tobą moimi doświadczeniami, abyś Ty również mógł podzielić się swoją pracą z całym światem!
Przede wszystkim to naprawdę nie jest trudne! Nie wymaga żadnego programowania, a jeśli kiedykolwiek stworzyłeś własny custom connector, to praktycznie masz już wszystko wykonane! Zróbmy to więc razem, krok po kroku. Poniżej zamieściłem doatkowo film gdzie pokazuję cały proces krok po kroku:
1. Stwórz custom connector
General information
- Nie używaj żadnej ikony. Zostanie zastąpiona przez domyślną.
- Użyj #da3b01 jako koloru.
- Podaj opis swojego łącznika. To jest wymagane.
- Wybierz typ połączenia.
- Zdefiniuj adres URL hosta — jest to główny adres URL dla wszystkich wywołań API.
- Zdefiniuj podstawowy adres URL — czyli po głównym adresie URL, ale przed wszystkimi adresami URL zdefiniowanymi dla określonych punktów końcowych.
Security
Zdefiniuj, jakiego uwierzytelnienia używa punkt końcowy. Zdefiniuj i skonfiguruj oczywiście 🙂
Definition
I tu zaczyna się zabawa 🙂
- Dodaj i zdefiniuj wszystkie działania
- Dodaj i zdefiniuj wszystkie wyzwalacze
- Dla każdej akcji/wyzwalacza określ:
- Summary- będzie używane jako etykieta w nagłówku akcji oraz na liście dostępnych akcji (Dowiedz się więcej).
- Description – będzie wyświetlany pod nazwą akcji na liście dostępnych akcji, a także pod ikoną info obok nazwy akcji w nagłówku (Dowiedz się więcej).
- Operation ID — używany wewnętrznie przez definicję łącznika.
- Visibility – w zależności od wybranej, akcja będzie się różnie wyświetlać na liście akcji (Dowiedz się więcej):
- none – regularny wygląd;
- advanced – widoczne po kliknięciu przez użytkownika „Zobacz więcej” na liście akcji;
- internal – niewidoczny dla użytkowników;
- important – widoczne jako pierwsza akcja na liście akcji.
Zdefiniuj request/ response
- Wybierz typ operacji;
- Podaj adres URL. Jeśli URL zawiera parametry, otocz je nawiasami klamrowymi, np. {PARAMETR};
- Zdefiniuj nagłówki i treść zapytania/ odpowiedzi (JSON);
- Kliknij importuj.
Ważne! Dla odpowiedzi (response) – nie określaj schematu odpowiedzi dla typu „domyślny”. Ale nie zostawiaj go pustego. Jeśli API zwraca dynamiczną odpowiedź, twórcy muszą użyć akcji Parse JSON, aby ją obsłużyć, jednak nie są dozwolone puste odpowiedzi/akcje.
Dla każdego parametru, który będziesz mieć w żądaniu/odpowiedzi:
- Name – używana wewnętrznie, niewidoczna dla użytkownika końcowego;
- Description – wyświetlany wewnątrz pola oraz jako opis na liście dynamic outcomes (Dowiedz się więcej);
- Summary – wyświetlane jako etykieta nad polem, również na liście dynamic outcomes (Dowiedz się więcej);
- Default value – nie trzeba wyjaśniać 😉
- Is required – czy pole wymaga zawartości, czy nie;
- Visibility – taka sama jak dla akcji (Dowiedz się więcej);
- Location – gdzie parametr występuje w danych żądania/odpowiedzi;
- Typ i format – określa typ i format danych;
- Dropdown type – czy pole powinno umożliwiać wpisanie dowolnej wartości (Disabled) czy też powinno umożliwiać wybór ze statycznego lub dynamicznego zestawu wartości (Dowiedz się więcej);
- Lista wartości statycznych lub dynamiczna konfiguracja rozwijana.
Ważne! Postaraj się zdefiniować jak najwięcej informacji. Przynajmniej pamiętaj o zdefiniowaniu Summary dla każdego parametru.
Code
Tutaj możesz napisać/wgrać dodatkowy kod napisany w C#, jeśli punkty końcowe wymagają dodatkowej manipulacji przed przesłaniem danych do przepływu w chmurze lub z niego.
Test
Musisz wykonać każdy zdefiniowany wyzwalacz i akcję. Każdy musi zakończyć się sukcesem.
Ważne! Po pomyślnym wykonaniu wszystkich metod zrób zrzut ekranu jako dowód do weryfikacji.
2. Przetestuj custom connector
Teraz musisz utworzyć testowy Cloud flow, który zawiera co najmniej 3 akcje (i wyzwalacz, jeśli jest zdefiniowany) z niestandardowego łącznika.
Ważne! Po zbudowaniu wykonaj i zrób zrzuty ekranu pokazujące, że przepływ przebiegł pomyślnie. Możesz rozwinąć akcje.
3. Zainstaluj Microsoft Power Platform Connectors CLI
Przejdź do tego adresu URL: https://docs.microsoft.com/en-us/connectors/custom-connectors/paconn-cli, aby pobrać i zainstalować interfejs wiersza polecenia Power Platform Connector.
4. Pobierz swój custom connector
Wykonaj następujące kroki: https://docs.microsoft.com/en-us/connectors/custom-connectors/certification-submission#step-4-prepare-the-connector-artifacts, aby pobrać łącznik niestandardowy. Musisz to zrobić w dwóch krokach:
- W konsoli CMD przejdź do katalogu, w którym chcesz pobrać łącznik.
- Wpisz
paconn login
, aby się zalogować. - Wpisz
paconn download
, aby pobrać wybrany łącznik z wybranego środowiska.
5. Dostosuj swój connector
Przejdź przez krok nr 3 — Add metadata z tego łącza: https://docs.microsoft.com/en-us/connectors/custom-connectors/certification-submission#step-3-add-metadata. Musisz uzupełnić informacje w pliku apiProperties.json
i apiDefinition.swagger.json
.
Ponadto dla każdego parametru zdefiniowanego w adresie URL żądania dodaj „x-ms-url-encoding”: „single”
(lub double, dowiedz się więcej), aby zdefiniować sposób zmiany znaczenia wartości. To jest wymagane.
Ważne! Usuń wszystkie puste właściwości z definicji łącznika. Usuń również wszystkie puste odpowiedzi i działania. Zamień/usuń wszystkie znaki Unicode.
6. Sprawdź swój connector
W konsoli przejdź do lokalizacji, w której zapisano plik apiDefinition.swagger.json
. Następnie wpisz: paconn validate --api-def apiDefinition.swagger.json.
Przejrzyj i napraw wszystkie błędy! Wynik walidacji musi być pozytywny (Dowiedz się więcej).
Ważne! Gdy walidacja się powiedzie, zrób zrzut ekranu. Będzie to trzeci dowód na to, że Twój łącznik jest prawidłowy.
7. Dodaj plik Readme.md
To jest ostatni wymagany plik. Musisz utworzyć plik readme zgodnie z istniejącymi szablonami (Dowiedz się więcej). Ja korzystam z tego, z github. Możesz go znaleźć tutaj: https://github.com/microsoft/PowerPlatformConnectors/blob/dev/templates/readme.md.
8. Zrób fork na repo Microsoft’s
Przejdź do https://github.com/microsoft/PowerPlatformConnectors i utwórz fork wewnątrz gałęzi dev. Spowoduje to utworzenie lokalnej wersji repozytorium na Twoim koncie.
9. Otwórz Visual Studio Code i przygotuj lokalne repo
Ja używam VS Code, możesz użyć Github Kraken lub dowolnego innego klienta github. To, co musisz teraz zrobić, to sklonować repozytorium (to, które sforkowałeś, z Github), na maszynę lokalną, a następnie utworzyć nowy branch dla swojego łącznika (opcjonalnie) i na koniec dodać wszystkie pliki i utworzyć pull request do brancha dev w repo Microsoft. Gotowy? Ok. Aaaa, najpierw zainstaluj dodatek Github w swoim VS Code 🙂
- Naciśnij F1 i wpisz
git: clone
i wpisz adres URL swojego forka z github. - Wybierz lokalizację, w której chcesz ją sklonować.
- Po sklonowaniu otwórz go jako nowy obszar roboczy w VS Code.
- Teraz naciśnij F1 i wpisz
git: create branch
, wybierz repozytorium. - Teraz utwórz nowy folder poniżej „independent-publisher-connectors” z nazwą swojego łącznika i skopiuj tam trzy pliki:
- apiDefinition.swagger.json
- apiProperties.json
- readme.md
Ważne! Upewnij się, że w Twoim commitcie znajdują się tylko powyższe trzy pliki!
- Teraz przejdź do kontroli źródła (Ctrl+Shift+G).
- Wpisz podsumowanie commita – jeśli jest to ostatni commit przed pull requestem, powinno to być zgodne ze wzorcem: „YOUR CONNECTOR NAME” (Independent Publisher).
- Kliknij „Zatwierdź”.
- Następnie kliknij „Synchronizuj zmiany” 😉
10. Utwórz Pull Request
Teraz utwórz pull request.
- Upewnij się, że wykonujesz pull request ze swojego repozytorium i odpowiedniej gałęzi;
- Upewnij się, że wykonujesz pull request do gałęzi dev Microsoft;
- Nazwij żądanie „YOUR CONNECTOR NAME” (Independent Publisher).
- Zaznacz wszystkie pola wyboru. Zanim to zrobisz, przeczytaj je oczywiście, aby sprawdzić, czy connector jest zgodny. Podaj również linki do 3 zrzutów ekranu jako dowód, że connector działa. Obrazy mogą być przechowywane na Twoim blogu lub w innym miejscu publicznie. Dowiedz się więcej, jak dołączyć obraz za pomocą języka markdown.
- Gdy skończysz – kliknij „Create” – rozpocznie się proces certyfikacji.
I to w zasadzie tyle. Teraz musisz poczekać na kontakt z programu Independent Publisher connector. Jeśli wystąpią jakiekolwiek problemy, zostaniesz poproszony o ich usunięcie przed wykonaniem kolejnego commita i pull request.
Powodzenia!