Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Обновление под новую версию Аудитора #148

Open
wants to merge 10 commits into
base: master
Choose a base branch
from

Conversation

zetroot
Copy link
Collaborator

@zetroot zetroot commented Nov 6, 2021

Начал реализацию сущностей виртуальной файловой системы на основе Github API для обновлённого API Аудитора.

Пока blazor проект немного не собирается.
@kulakovt можешь подробнее рассказать, как эта реализация будет предоставляться Аудитору, для выполнения его ORM магии? Пока это для меня скрыто туманом войны.

Так же я не очень понимаю как будет осуществляться создание файла и "фиксация" изменений при редактировании файла

@kulakovt
Copy link
Member

kulakovt commented Nov 6, 2021

можешь подробнее рассказать, как эта реализация будет предоставляться Аудитору, для выполнения его ORM магии?
Пока это для меня скрыто туманом войны.

// Для начала нужна только рутовая IDirectory
var auditDirectory = GithubDirectory.ForRoot(...);
var store = await AuditStore.OpenAsync(auditDirectory);
var session = store.OpenSession();
var communities = await session.QueryAsync<Community>();

Можно посмотреть и подебажить на примере AuditFixture. Если у тебя IDirectory рабочая, то можешь просто скопировать весь код из ValidationTest, подставить свой store и все тесты должны пройти.

Так же я не очень понимаю как будет осуществляться создание файла и "фиксация" изменений при редактировании файла

Создание файла (а также обновление и удаление) я делаю сейчас. В текущей версии этого пока нет.

Как оно будет выглядеть для GitHub'а, я пока не представляю. Тут нужны твои знания об API. Давай доделаем чтение, а потом созвонимся и обсудим, что делать с записью.

@zetroot
Copy link
Collaborator Author

zetroot commented Nov 6, 2021

О, спасибо, теперь мне стало немного понятнее :-)
В принципе у меня уже всё есть, чтобы набросать демку на blazor. Попробую завтра прикрутить это.
Метод запроса редактирования файла я пока не делал, ну и видимо пока не буду, раз эта часть api не реализована.

@kulakovt
Copy link
Member

kulakovt commented Nov 6, 2021

Метод запроса редактирования файла я пока не делал, ну и видимо пока не буду, раз эта часть api не реализована.

Не, пока не надо. Я ещё обкатаю его на PhysicalFileSystem. Там ещё может всё поменяться. Давай доделаем «только чтение» на всех уровнях. Для первой вехи запись не нужна.

@zetroot
Copy link
Collaborator Author

zetroot commented Nov 7, 2021

У нас тут будут проблемки с анонимным доступом - rate limit для одного хоста 60 запросов в час

@codecov-commenter
Copy link

codecov-commenter commented Nov 7, 2021

Codecov Report

Merging #148 (2841d73) into master (fd6377c) will decrease coverage by 1.01%.
The diff coverage is 0.00%.

Impacted file tree graph

@@            Coverage Diff            @@
##           master    #148      +/-   ##
=========================================
- Coverage    2.12%   1.11%   -1.02%     
=========================================
  Files           7      10       +3     
  Lines          94     180      +86     
=========================================
  Hits            2       2              
- Misses         92     178      +86     
Impacted Files Coverage Δ
DotNetRu.Commune.GithubFilesystem/ClientFactory.cs 0.00% <0.00%> (ø)
...tNetRu.Commune.GithubFilesystem/GitHubDirectory.cs 0.00% <0.00%> (ø)
DotNetRu.Commune.GithubFilesystem/GitHubFile.cs 0.00% <0.00%> (ø)
....Commune.GithubFilesystem/GitHubFilesystemEntry.cs 0.00% <0.00%> (ø)
...etRu.Commune.WasmClient/BizLayerServiceRegistry.cs 40.00% <0.00%> (ø)
DotNetRu.Commune.WasmClient/Pages/Index.razor 0.00% <0.00%> (ø)
DotNetRu.Commune.WasmClient/Program.cs 0.00% <0.00%> (ø)

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update fd6377c...2841d73. Read the comment docs.

@kulakovt
Copy link
Member

kulakovt commented Nov 7, 2021

Есть способ скачать весь репозиторий (или какое-то подмножество файлов) за один запрос? Что-то типа git clone, который работает стабильно под анонимусом, несмотря на количество файлов в репозитории.

В таком случае, мы можем на старте затянуть всё за один запрос. А все остальные изменения уложатся в официальный лимит. Хотя для изменений всё-равно нужна авторизация, но это уже не настолько критично.

@zetroot
Copy link
Collaborator Author

zetroot commented Nov 7, 2021

Не могу однозначно ответить отрицательно.
Я пока наблюдал что файлики он отдаёт только когда конкретно к файлу обращаешься, то есть даже нельзя получить все содержимое папки за один запрос.
Хуже того, теперь со всех моих адресов даже авторизованные запросы упираются в тот же ratelimit, так что я пока отвисаю в бане.

@kulakovt
Copy link
Member

kulakovt commented Nov 7, 2021

Тогда нужно рыть в этом направлении. Скачивать по одному файлу, это явно не наш вариант. Нужно научиться забирать всё за раз, не расходуя сильно лимит.

Может быть параллельно стоит посмотреть на File System Access API. Хотя бы для начальной инициализации.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants