cs-models 0.0.627__py3-none-any.whl → 0.0.847__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- cs_models/database/operations.py +17 -5
- cs_models/resources/ArtifactVectorIndex/__init__.py +0 -0
- cs_models/resources/ArtifactVectorIndex/models.py +32 -0
- cs_models/resources/ArtifactVectorIndex/schemas.py +16 -0
- cs_models/resources/ArtifactVectorIndexQueue/__init__.py +0 -0
- cs_models/resources/ArtifactVectorIndexQueue/models.py +34 -0
- cs_models/resources/ArtifactVectorIndexQueue/schemas.py +17 -0
- cs_models/resources/AssistantCommand/models.py +14 -1
- cs_models/resources/AssistantCommand/schemas.py +2 -0
- cs_models/resources/AssistantCommandArtifact/models.py +2 -1
- cs_models/resources/AssistantCommandArtifact/schemas.py +1 -0
- cs_models/resources/AssistantCommandChart/__init__.py +0 -0
- cs_models/resources/AssistantCommandChart/models.py +37 -0
- cs_models/resources/AssistantCommandChart/schemas.py +16 -0
- cs_models/resources/AssistantSession/models.py +8 -1
- cs_models/resources/AssistantSession/schemas.py +3 -0
- cs_models/resources/AssistantUserQuery/models.py +5 -1
- cs_models/resources/AssistantUserQuery/schemas.py +40 -1
- cs_models/resources/B3CRSS/__init__.py +0 -0
- cs_models/resources/B3CRSS/models.py +25 -0
- cs_models/resources/B3CRSS/schemas.py +14 -0
- cs_models/resources/CampaignTracker/__init__.py +0 -0
- cs_models/resources/CampaignTracker/models.py +29 -0
- cs_models/resources/CampaignTracker/schemas.py +17 -0
- cs_models/resources/CompanyDrugCount/__init__.py +0 -0
- cs_models/resources/CompanyDrugCount/models.py +28 -0
- cs_models/resources/CompanyDrugCount/schemas.py +11 -0
- cs_models/resources/CompanyMarketCap/__init__.py +0 -0
- cs_models/resources/CompanyMarketCap/models.py +29 -0
- cs_models/resources/CompanyMarketCap/schemas.py +11 -0
- cs_models/resources/CompanyOUS/models.py +4 -0
- cs_models/resources/CompanyOUS/schemas.py +6 -0
- cs_models/resources/CompanyOutbox/models.py +1 -0
- cs_models/resources/CompanyOutbox/schemas.py +1 -0
- cs_models/resources/CompanyReview/models.py +4 -1
- cs_models/resources/CompanyReview/schemas.py +3 -0
- cs_models/resources/CompanySEC/models.py +4 -0
- cs_models/resources/CompanySEC/schemas.py +6 -0
- cs_models/resources/Config/models.py +2 -0
- cs_models/resources/Config/schemas.py +3 -0
- cs_models/resources/CoverPage13F/__init__.py +0 -0
- cs_models/resources/CoverPage13F/models.py +29 -0
- cs_models/resources/CoverPage13F/schemas.py +27 -0
- cs_models/resources/Cusip13FSubsidiary/__init__.py +0 -0
- cs_models/resources/Cusip13FSubsidiary/models.py +28 -0
- cs_models/resources/Cusip13FSubsidiary/schemas.py +14 -0
- cs_models/resources/Deal/models.py +2 -0
- cs_models/resources/Deal/schemas.py +2 -0
- cs_models/resources/DealAdvisor/__init__.py +0 -0
- cs_models/resources/DealAdvisor/models.py +35 -0
- cs_models/resources/DealAdvisor/schemas.py +15 -0
- cs_models/resources/DealInvestor/models.py +1 -0
- cs_models/resources/DealInvestor/schemas.py +1 -0
- cs_models/resources/DealType/__init__.py +0 -0
- cs_models/resources/DealType/models.py +33 -0
- cs_models/resources/DealType/schemas.py +14 -0
- cs_models/resources/DealUnderwriter/__init__.py +0 -0
- cs_models/resources/DealUnderwriter/models.py +35 -0
- cs_models/resources/DealUnderwriter/schemas.py +15 -0
- cs_models/resources/DeepResearchAgenticUnit/__init__.py +14 -0
- cs_models/resources/DeepResearchAgenticUnit/models.py +123 -0
- cs_models/resources/DeepResearchAgenticUnit/schemas.py +50 -0
- cs_models/resources/DeepResearchSession/__init__.py +20 -0
- cs_models/resources/DeepResearchSession/models.py +170 -0
- cs_models/resources/DeepResearchSession/schemas.py +94 -0
- cs_models/resources/DeepResearchSubTask/__init__.py +20 -0
- cs_models/resources/DeepResearchSubTask/models.py +177 -0
- cs_models/resources/DeepResearchSubTask/schemas.py +105 -0
- cs_models/resources/Designation/models.py +7 -0
- cs_models/resources/Designation/schemas.py +2 -0
- cs_models/resources/DesignationOutbox/models.py +2 -0
- cs_models/resources/DesignationOutbox/schemas.py +1 -0
- cs_models/resources/Digest/models.py +1 -0
- cs_models/resources/Digest/schemas.py +1 -0
- cs_models/resources/DocChunk/__init__.py +0 -0
- cs_models/resources/DocChunk/models.py +33 -0
- cs_models/resources/DocChunk/schemas.py +20 -0
- cs_models/resources/DocMarkdownTable/__init__.py +0 -0
- cs_models/resources/DocMarkdownTable/models.py +29 -0
- cs_models/resources/DocMarkdownTable/schemas.py +16 -0
- cs_models/resources/EventLLM/__init__.py +0 -0
- cs_models/resources/EventLLM/models.py +41 -0
- cs_models/resources/EventLLM/schemas.py +39 -0
- cs_models/resources/EventsQueue/__init__.py +0 -0
- cs_models/resources/EventsQueue/models.py +33 -0
- cs_models/resources/EventsQueue/schemas.py +18 -0
- cs_models/resources/ExplorerColumn/__init__.py +0 -0
- cs_models/resources/ExplorerColumn/models.py +33 -0
- cs_models/resources/ExplorerColumn/schemas.py +16 -0
- cs_models/resources/ExternalDrive/__init__.py +0 -0
- cs_models/resources/ExternalDrive/models.py +29 -0
- cs_models/resources/ExternalDrive/schemas.py +14 -0
- cs_models/resources/FDADrugReview/__init__.py +0 -0
- cs_models/resources/FDADrugReview/models.py +29 -0
- cs_models/resources/FDADrugReview/schemas.py +19 -0
- cs_models/resources/FDADrugReviewFile/__init__.py +0 -0
- cs_models/resources/FDADrugReviewFile/models.py +43 -0
- cs_models/resources/FDADrugReviewFile/schemas.py +22 -0
- cs_models/resources/FDADrugReviewFileCondition/__init__.py +0 -0
- cs_models/resources/FDADrugReviewFileCondition/models.py +42 -0
- cs_models/resources/FDADrugReviewFileCondition/schemas.py +18 -0
- cs_models/resources/FDADrugReviewFileIntervention/__init__.py +0 -0
- cs_models/resources/FDADrugReviewFileIntervention/models.py +42 -0
- cs_models/resources/FDADrugReviewFileIntervention/schemas.py +18 -0
- cs_models/resources/FDADrugReviewFileTarget/__init__.py +0 -0
- cs_models/resources/FDADrugReviewFileTarget/models.py +42 -0
- cs_models/resources/FDADrugReviewFileTarget/schemas.py +18 -0
- cs_models/resources/FDALabel/models.py +3 -0
- cs_models/resources/FDALabel/schemas.py +2 -0
- cs_models/resources/FDAMeetingFiling/models.py +1 -0
- cs_models/resources/FDAMeetingFiling/schemas.py +1 -0
- cs_models/resources/FinancingDealType/__init__.py +0 -0
- cs_models/resources/FinancingDealType/models.py +28 -0
- cs_models/resources/FinancingDealType/schemas.py +13 -0
- cs_models/resources/InfoTable13F/__init__.py +0 -0
- cs_models/resources/InfoTable13F/models.py +26 -0
- cs_models/resources/InfoTable13F/schemas.py +20 -0
- cs_models/resources/Meeting/models.py +8 -0
- cs_models/resources/Meeting/schemas.py +84 -0
- cs_models/resources/MeetingDataOutbox/models.py +8 -1
- cs_models/resources/MeetingDataOutbox/schemas.py +4 -1
- cs_models/resources/MeetingUserDocument/__init__.py +0 -0
- cs_models/resources/MeetingUserDocument/models.py +39 -0
- cs_models/resources/MeetingUserDocument/schemas.py +17 -0
- cs_models/resources/MindgramOAuth/__init__.py +0 -0
- cs_models/resources/MindgramOAuth/models.py +35 -0
- cs_models/resources/MindgramOAuth/schemas.py +33 -0
- cs_models/resources/NCTFDADrugReviewFile/__init__.py +0 -0
- cs_models/resources/NCTFDADrugReviewFile/models.py +37 -0
- cs_models/resources/NCTFDADrugReviewFile/schemas.py +16 -0
- cs_models/resources/NCTFacilities/models.py +1 -0
- cs_models/resources/NCTFacilities/schemas.py +1 -0
- cs_models/resources/NCTParticipationCriteria/__init__.py +0 -0
- cs_models/resources/NCTParticipationCriteria/models.py +28 -0
- cs_models/resources/NCTParticipationCriteria/schemas.py +14 -0
- cs_models/resources/NCTStudy/models.py +2 -0
- cs_models/resources/NCTStudy/schemas.py +2 -0
- cs_models/resources/NotificationReadStatus/__init__.py +0 -0
- cs_models/resources/NotificationReadStatus/models.py +30 -0
- cs_models/resources/NotificationReadStatus/schemas.py +15 -0
- cs_models/resources/OtherManager13F/__init__.py +0 -0
- cs_models/resources/OtherManager13F/models.py +18 -0
- cs_models/resources/OtherManager13F/schemas.py +12 -0
- cs_models/resources/OtherManager213F/__init__.py +0 -0
- cs_models/resources/OtherManager213F/models.py +15 -0
- cs_models/resources/OtherManager213F/schemas.py +13 -0
- cs_models/resources/PipelineCrawlSession/__init__.py +0 -0
- cs_models/resources/PipelineCrawlSession/models.py +67 -0
- cs_models/resources/PipelineCrawlSession/schemas.py +22 -0
- cs_models/resources/PipelineCrawledPage/__init__.py +0 -0
- cs_models/resources/PipelineCrawledPage/models.py +80 -0
- cs_models/resources/PipelineCrawledPage/schemas.py +34 -0
- cs_models/resources/PipelineDrugPortfolio/__init__.py +0 -0
- cs_models/resources/PipelineDrugPortfolio/models.py +92 -0
- cs_models/resources/PipelineDrugPortfolio/schemas.py +31 -0
- cs_models/resources/PipelineExtractionLog/__init__.py +0 -0
- cs_models/resources/PipelineExtractionLog/models.py +55 -0
- cs_models/resources/PipelineExtractionLog/schemas.py +23 -0
- cs_models/resources/PromptIndices/__init__.py +0 -0
- cs_models/resources/PromptIndices/models.py +27 -0
- cs_models/resources/PromptIndices/schemas.py +17 -0
- cs_models/resources/PubmedMeetingSellSideSignal/__init__.py +0 -0
- cs_models/resources/PubmedMeetingSellSideSignal/models.py +64 -0
- cs_models/resources/PubmedMeetingSellSideSignal/schemas.py +21 -0
- cs_models/resources/PubmedMeetingUserDocument/__init__.py +0 -0
- cs_models/resources/PubmedMeetingUserDocument/models.py +40 -0
- cs_models/resources/PubmedMeetingUserDocument/schemas.py +16 -0
- cs_models/resources/PubmedUserDocument/__init__.py +0 -0
- cs_models/resources/PubmedUserDocument/models.py +35 -0
- cs_models/resources/PubmedUserDocument/schemas.py +15 -0
- cs_models/resources/PubmedVectorIndex/__init__.py +0 -0
- cs_models/resources/PubmedVectorIndex/models.py +33 -0
- cs_models/resources/PubmedVectorIndex/schemas.py +16 -0
- cs_models/resources/SalesEstimate/__init__.py +0 -0
- cs_models/resources/SalesEstimate/models.py +39 -0
- cs_models/resources/SalesEstimate/schemas.py +26 -0
- cs_models/resources/SalesEstimateCompany/__init__.py +0 -0
- cs_models/resources/SalesEstimateCompany/models.py +38 -0
- cs_models/resources/SalesEstimateCompany/schemas.py +35 -0
- cs_models/resources/SalesEstimateCondition/__init__.py +0 -0
- cs_models/resources/SalesEstimateCondition/models.py +41 -0
- cs_models/resources/SalesEstimateCondition/schemas.py +17 -0
- cs_models/resources/SalesEstimateIntervention/__init__.py +0 -0
- cs_models/resources/SalesEstimateIntervention/models.py +41 -0
- cs_models/resources/SalesEstimateIntervention/schemas.py +17 -0
- cs_models/resources/SalesEstimateTarget/__init__.py +0 -0
- cs_models/resources/SalesEstimateTarget/models.py +41 -0
- cs_models/resources/SalesEstimateTarget/schemas.py +17 -0
- cs_models/resources/SalesTable/__init__.py +0 -0
- cs_models/resources/SalesTable/models.py +34 -0
- cs_models/resources/SalesTable/schemas.py +20 -0
- cs_models/resources/SearchLink/__init__.py +0 -0
- cs_models/resources/SearchLink/models.py +29 -0
- cs_models/resources/SearchLink/schemas.py +16 -0
- cs_models/resources/SellSideAbstractMention/__init__.py +0 -0
- cs_models/resources/SellSideAbstractMention/models.py +57 -0
- cs_models/resources/SellSideAbstractMention/schemas.py +28 -0
- cs_models/resources/SellSideAbstractMentionLink/__init__.py +0 -0
- cs_models/resources/SellSideAbstractMentionLink/models.py +60 -0
- cs_models/resources/SellSideAbstractMentionLink/schemas.py +24 -0
- cs_models/resources/SellSideSource/__init__.py +0 -0
- cs_models/resources/SellSideSource/models.py +25 -0
- cs_models/resources/SellSideSource/schemas.py +13 -0
- cs_models/resources/Signature13F/__init__.py +0 -0
- cs_models/resources/Signature13F/models.py +15 -0
- cs_models/resources/Signature13F/schemas.py +13 -0
- cs_models/resources/SmartDefGrid/__init__.py +0 -0
- cs_models/resources/SmartDefGrid/models.py +30 -0
- cs_models/resources/SmartDefGrid/schemas.py +52 -0
- cs_models/resources/SmartDefGridCell/__init__.py +0 -0
- cs_models/resources/SmartDefGridCell/models.py +51 -0
- cs_models/resources/SmartDefGridCell/schemas.py +39 -0
- cs_models/resources/SmartDefGridCellAnswer/__init__.py +0 -0
- cs_models/resources/SmartDefGridCellAnswer/models.py +45 -0
- cs_models/resources/SmartDefGridCellAnswer/schemas.py +23 -0
- cs_models/resources/SmartDefGridCellAnswerCitation/__init__.py +0 -0
- cs_models/resources/SmartDefGridCellAnswerCitation/models.py +21 -0
- cs_models/resources/SmartDefGridCellAnswerCitation/schemas.py +14 -0
- cs_models/resources/SmartDefGridCellQuestion/__init__.py +0 -0
- cs_models/resources/SmartDefGridCellQuestion/models.py +76 -0
- cs_models/resources/SmartDefGridCellQuestion/schemas.py +41 -0
- cs_models/resources/SmartDefGridCellValue/__init__.py +0 -0
- cs_models/resources/SmartDefGridCellValue/models.py +54 -0
- cs_models/resources/SmartDefGridCellValue/schemas.py +19 -0
- cs_models/resources/SmartDefGridRun/__init__.py +0 -0
- cs_models/resources/SmartDefGridRun/models.py +60 -0
- cs_models/resources/SmartDefGridRun/schemas.py +31 -0
- cs_models/resources/SmartGrid/__init__.py +0 -0
- cs_models/resources/SmartGrid/models.py +34 -0
- cs_models/resources/SmartGrid/schemas.py +18 -0
- cs_models/resources/SmartGridCell/__init__.py +0 -0
- cs_models/resources/SmartGridCell/models.py +44 -0
- cs_models/resources/SmartGridCell/schemas.py +22 -0
- cs_models/resources/Submission13F/__init__.py +0 -0
- cs_models/resources/Submission13F/models.py +12 -0
- cs_models/resources/Submission13F/schemas.py +10 -0
- cs_models/resources/SummaryPage13F/__init__.py +0 -0
- cs_models/resources/SummaryPage13F/models.py +12 -0
- cs_models/resources/SummaryPage13F/schemas.py +9 -0
- cs_models/resources/TableFigure/__init__.py +0 -0
- cs_models/resources/TableFigure/models.py +40 -0
- cs_models/resources/TableFigure/schemas.py +61 -0
- cs_models/resources/TargetSyn/models.py +4 -0
- cs_models/resources/TargetSyn/schemas.py +3 -0
- cs_models/resources/Transcript/__init__.py +0 -0
- cs_models/resources/Transcript/models.py +31 -0
- cs_models/resources/Transcript/schemas.py +20 -0
- cs_models/resources/TranscriptCondition/__init__.py +0 -0
- cs_models/resources/TranscriptCondition/models.py +41 -0
- cs_models/resources/TranscriptCondition/schemas.py +17 -0
- cs_models/resources/TranscriptEquity/__init__.py +0 -0
- cs_models/resources/TranscriptEquity/models.py +28 -0
- cs_models/resources/TranscriptEquity/schemas.py +15 -0
- cs_models/resources/TranscriptEquityCompany/__init__.py +0 -0
- cs_models/resources/TranscriptEquityCompany/models.py +34 -0
- cs_models/resources/TranscriptEquityCompany/schemas.py +16 -0
- cs_models/resources/TranscriptGrouping/__init__.py +0 -0
- cs_models/resources/TranscriptGrouping/models.py +23 -0
- cs_models/resources/TranscriptGrouping/schemas.py +14 -0
- cs_models/resources/TranscriptGroupingMap/__init__.py +0 -0
- cs_models/resources/TranscriptGroupingMap/models.py +31 -0
- cs_models/resources/TranscriptGroupingMap/schemas.py +14 -0
- cs_models/resources/TranscriptIntervention/__init__.py +0 -0
- cs_models/resources/TranscriptIntervention/models.py +41 -0
- cs_models/resources/TranscriptIntervention/schemas.py +17 -0
- cs_models/resources/TranscriptItem/__init__.py +0 -0
- cs_models/resources/TranscriptItem/models.py +35 -0
- cs_models/resources/TranscriptItem/schemas.py +20 -0
- cs_models/resources/TranscriptTarget/__init__.py +0 -0
- cs_models/resources/TranscriptTarget/models.py +41 -0
- cs_models/resources/TranscriptTarget/schemas.py +17 -0
- cs_models/resources/UserAutomatedDigest/__init__.py +0 -0
- cs_models/resources/UserAutomatedDigest/models.py +35 -0
- cs_models/resources/UserAutomatedDigest/schemas.py +19 -0
- cs_models/resources/UserDocument/models.py +9 -0
- cs_models/resources/UserDocument/schemas.py +3 -0
- cs_models/resources/UserDocumentAccess/__init__.py +0 -0
- cs_models/resources/UserDocumentAccess/models.py +35 -0
- cs_models/resources/UserDocumentAccess/schemas.py +19 -0
- cs_models/resources/UserDocumentChunk/__init__.py +0 -0
- cs_models/resources/UserDocumentChunk/models.py +35 -0
- cs_models/resources/UserDocumentChunk/schemas.py +18 -0
- cs_models/resources/UserDocumentHierarchy/__init__.py +0 -0
- cs_models/resources/UserDocumentHierarchy/models.py +51 -0
- cs_models/resources/UserDocumentHierarchy/schemas.py +24 -0
- cs_models/resources/UserDocumentMeeting/__init__.py +0 -0
- cs_models/resources/UserDocumentMeeting/models.py +33 -0
- cs_models/resources/UserDocumentMeeting/schemas.py +14 -0
- cs_models/resources/UserDocumentTag/__init__.py +0 -0
- cs_models/resources/UserDocumentTag/models.py +31 -0
- cs_models/resources/UserDocumentTag/schemas.py +15 -0
- cs_models/resources/UserExplorerColumn/__init__.py +0 -0
- cs_models/resources/UserExplorerColumn/models.py +30 -0
- cs_models/resources/UserExplorerColumn/schemas.py +14 -0
- cs_models/resources/UserInternalDocWorkflow/__init__.py +0 -0
- cs_models/resources/UserInternalDocWorkflow/models.py +28 -0
- cs_models/resources/UserInternalDocWorkflow/schemas.py +11 -0
- cs_models/resources/UserMeeting/__init__.py +0 -0
- cs_models/resources/UserMeeting/models.py +31 -0
- cs_models/resources/UserMeeting/schemas.py +12 -0
- cs_models/resources/UserMeetingFavorite/__init__.py +0 -0
- cs_models/resources/UserMeetingFavorite/models.py +36 -0
- cs_models/resources/UserMeetingFavorite/schemas.py +13 -0
- cs_models/resources/UserSavedSearch/models.py +1 -0
- cs_models/resources/UserSavedSearch/schemas.py +1 -0
- cs_models/resources/UserSavedSearchAccess/__init__.py +0 -0
- cs_models/resources/UserSavedSearchAccess/models.py +34 -0
- cs_models/resources/UserSavedSearchAccess/schemas.py +18 -0
- cs_models/resources/UserSavedSearchCollectionMap/__init__.py +0 -0
- cs_models/resources/UserSavedSearchCollectionMap/models.py +33 -0
- cs_models/resources/UserSavedSearchCollectionMap/schemas.py +14 -0
- cs_models/resources/UserSavedSearchDigest/__init__.py +0 -0
- cs_models/resources/UserSavedSearchDigest/models.py +36 -0
- cs_models/resources/UserSavedSearchDigest/schemas.py +16 -0
- cs_models/resources/UserVAParameterView/__init__.py +0 -0
- cs_models/resources/UserVAParameterView/models.py +27 -0
- cs_models/resources/UserVAParameterView/schemas.py +13 -0
- cs_models/resources/UserWatchlistAccess/__init__.py +0 -0
- cs_models/resources/UserWatchlistAccess/models.py +31 -0
- cs_models/resources/UserWatchlistAccess/schemas.py +15 -0
- cs_models/resources/UserWorkbook/__init__.py +0 -0
- cs_models/resources/UserWorkbook/models.py +31 -0
- cs_models/resources/UserWorkbook/schemas.py +15 -0
- cs_models/resources/UserWorkbookWorkflows/__init__.py +0 -0
- cs_models/resources/UserWorkbookWorkflows/models.py +27 -0
- cs_models/resources/UserWorkbookWorkflows/schemas.py +15 -0
- cs_models/resources/UserWorkbookWorkflowsShared/__init__.py +0 -0
- cs_models/resources/UserWorkbookWorkflowsShared/models.py +31 -0
- cs_models/resources/UserWorkbookWorkflowsShared/schemas.py +15 -0
- cs_models/resources/VACompanyMap/__init__.py +0 -0
- cs_models/resources/VACompanyMap/models.py +37 -0
- cs_models/resources/VACompanyMap/schemas.py +38 -0
- cs_models/resources/VAParameter/__init__.py +0 -0
- cs_models/resources/VAParameter/models.py +36 -0
- cs_models/resources/VAParameter/schemas.py +25 -0
- cs_models/resources/VAParameterCondition/__init__.py +0 -0
- cs_models/resources/VAParameterCondition/models.py +41 -0
- cs_models/resources/VAParameterCondition/schemas.py +17 -0
- cs_models/resources/VAParameterGeography/__init__.py +0 -0
- cs_models/resources/VAParameterGeography/models.py +0 -0
- cs_models/resources/VAParameterGeography/schemas.py +0 -0
- cs_models/resources/VAParameterIntervention/__init__.py +0 -0
- cs_models/resources/VAParameterIntervention/models.py +41 -0
- cs_models/resources/VAParameterIntervention/schemas.py +17 -0
- cs_models/resources/VAParameterValue/__init__.py +0 -0
- cs_models/resources/VAParameterValue/models.py +42 -0
- cs_models/resources/VAParameterValue/schemas.py +27 -0
- cs_models/resources/VAParameterView/__init__.py +0 -0
- cs_models/resources/VAParameterView/models.py +35 -0
- cs_models/resources/VAParameterView/schemas.py +15 -0
- cs_models/resources/ViewPublicAssistantUserQuery/__init__.py +0 -0
- cs_models/resources/ViewPublicAssistantUserQuery/models.py +30 -0
- cs_models/resources/ViewPublicAssistantUserQuery/schemas.py +14 -0
- cs_models/resources/ViewPublicWorkbook/__init__.py +0 -0
- cs_models/resources/ViewPublicWorkbook/models.py +30 -0
- cs_models/resources/ViewPublicWorkbook/schemas.py +14 -0
- cs_models/resources/ViewPublicationCondition/__init__.py +0 -0
- cs_models/resources/ViewPublicationCondition/models.py +32 -0
- cs_models/resources/ViewPublicationCondition/schemas.py +16 -0
- cs_models/resources/WatchlistDigest/__init__.py +0 -0
- cs_models/resources/WatchlistDigest/models.py +36 -0
- cs_models/resources/WatchlistDigest/schemas.py +16 -0
- cs_models/resources/Workbook/__init__.py +0 -0
- cs_models/resources/Workbook/models.py +46 -0
- cs_models/resources/Workbook/schemas.py +32 -0
- cs_models/resources/WorkbookBlock/__init__.py +0 -0
- cs_models/resources/WorkbookBlock/models.py +50 -0
- cs_models/resources/WorkbookBlock/schemas.py +63 -0
- cs_models/resources/WorkbookBlockComment/__init__.py +0 -0
- cs_models/resources/WorkbookBlockComment/models.py +36 -0
- cs_models/resources/WorkbookBlockComment/schemas.py +15 -0
- cs_models/resources/WorkbookCommentThread/__init__.py +0 -0
- cs_models/resources/WorkbookCommentThread/models.py +59 -0
- cs_models/resources/WorkbookCommentThread/schemas.py +35 -0
- cs_models/resources/WorkbookMeta/__init__.py +0 -0
- cs_models/resources/WorkbookMeta/models.py +14 -0
- cs_models/resources/WorkbookMeta/schemas.py +9 -0
- cs_models/resources/WorkbookThreadComment/__init__.py +0 -0
- cs_models/resources/WorkbookThreadComment/models.py +38 -0
- cs_models/resources/WorkbookThreadComment/schemas.py +14 -0
- cs_models/resources/WorkbookWorkflow/__init__.py +0 -0
- cs_models/resources/WorkbookWorkflow/models.py +39 -0
- cs_models/resources/WorkbookWorkflow/schemas.py +24 -0
- cs_models/resources/WorkbookWorkflowBlock/__init__.py +0 -0
- cs_models/resources/WorkbookWorkflowBlock/models.py +37 -0
- cs_models/resources/WorkbookWorkflowBlock/schemas.py +60 -0
- cs_models/utils/utils.py +27 -1
- cs_models-0.0.847.dist-info/METADATA +29 -0
- {cs_models-0.0.627.dist-info → cs_models-0.0.847.dist-info}/RECORD +391 -52
- {cs_models-0.0.627.dist-info → cs_models-0.0.847.dist-info}/WHEEL +1 -1
- cs_models-0.0.627.dist-info/METADATA +0 -29
- {cs_models-0.0.627.dist-info → cs_models-0.0.847.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
from marshmallow import Schema, fields
|
|
2
|
+
from ...utils.utils import Safe13FInteger
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
class Othermanager213FSchema(Schema):
|
|
6
|
+
id = fields.Integer(dump_only=True)
|
|
7
|
+
ACCESSION_NUMBER = fields.String(required=True)
|
|
8
|
+
SEQUENCENUMBER = Safe13FInteger(required=True)
|
|
9
|
+
CIK = fields.String()
|
|
10
|
+
FORM13FFILENUMBER = fields.String()
|
|
11
|
+
CRDNUMBER = fields.String()
|
|
12
|
+
SECFILENUMBER = fields.String()
|
|
13
|
+
NAME = fields.String(required=True)
|
|
File without changes
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
Integer,
|
|
4
|
+
String,
|
|
5
|
+
DateTime,
|
|
6
|
+
Float,
|
|
7
|
+
Text,
|
|
8
|
+
ForeignKey,
|
|
9
|
+
Enum,
|
|
10
|
+
)
|
|
11
|
+
from datetime import datetime
|
|
12
|
+
|
|
13
|
+
from ...database import Base
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
class PipelineCrawlSessionModel(Base):
|
|
17
|
+
__tablename__ = 'pipeline_crawl_sessions'
|
|
18
|
+
|
|
19
|
+
id = Column(Integer, primary_key=True)
|
|
20
|
+
company_sec_id = Column(
|
|
21
|
+
Integer,
|
|
22
|
+
ForeignKey('companies_sec.id'),
|
|
23
|
+
nullable=True,
|
|
24
|
+
index=True,
|
|
25
|
+
)
|
|
26
|
+
company_ous_id = Column(
|
|
27
|
+
Integer,
|
|
28
|
+
ForeignKey('companies_ous.id'),
|
|
29
|
+
nullable=True,
|
|
30
|
+
index=True,
|
|
31
|
+
)
|
|
32
|
+
|
|
33
|
+
# Session tracking
|
|
34
|
+
session_uuid = Column(String(36), nullable=False, unique=True, index=True)
|
|
35
|
+
crawl_date = Column(DateTime, nullable=False, default=datetime.utcnow, index=True)
|
|
36
|
+
|
|
37
|
+
# Timing metrics
|
|
38
|
+
crawl_duration_seconds = Column(Float, nullable=True)
|
|
39
|
+
page_discovery_time_seconds = Column(Float, nullable=True)
|
|
40
|
+
extraction_time_seconds = Column(Float, nullable=True)
|
|
41
|
+
|
|
42
|
+
# Status tracking (MySQL ENUM)
|
|
43
|
+
status = Column(
|
|
44
|
+
Enum('started', 'discovering_pages', 'extracting_data', 'completed', 'failed', 'timeout'),
|
|
45
|
+
nullable=False,
|
|
46
|
+
default='started',
|
|
47
|
+
index=True,
|
|
48
|
+
)
|
|
49
|
+
error_message = Column(Text, nullable=True)
|
|
50
|
+
|
|
51
|
+
# Crawl statistics
|
|
52
|
+
total_pages_discovered = Column(Integer, nullable=True, default=0)
|
|
53
|
+
total_pages_crawled = Column(Integer, nullable=True, default=0)
|
|
54
|
+
total_screenshots_captured = Column(Integer, nullable=True, default=0)
|
|
55
|
+
total_drugs_extracted = Column(Integer, nullable=True, default=0)
|
|
56
|
+
|
|
57
|
+
# Crawl configuration
|
|
58
|
+
crawl_method = Column(String(50), nullable=True)
|
|
59
|
+
max_depth = Column(Integer, nullable=True, default=2)
|
|
60
|
+
|
|
61
|
+
created_at = Column(DateTime, nullable=False, default=datetime.utcnow)
|
|
62
|
+
updated_at = Column(
|
|
63
|
+
DateTime,
|
|
64
|
+
nullable=False,
|
|
65
|
+
default=datetime.utcnow,
|
|
66
|
+
onupdate=datetime.utcnow,
|
|
67
|
+
)
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
from marshmallow import Schema, fields
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class PipelineCrawlSessionSchema(Schema):
|
|
5
|
+
id = fields.Int(dump_only=True)
|
|
6
|
+
company_sec_id = fields.Int(allow_none=True)
|
|
7
|
+
company_ous_id = fields.Int(allow_none=True)
|
|
8
|
+
session_uuid = fields.Str(required=True)
|
|
9
|
+
crawl_date = fields.DateTime(required=True)
|
|
10
|
+
crawl_duration_seconds = fields.Float(allow_none=True)
|
|
11
|
+
page_discovery_time_seconds = fields.Float(allow_none=True)
|
|
12
|
+
extraction_time_seconds = fields.Float(allow_none=True)
|
|
13
|
+
status = fields.Str(required=True)
|
|
14
|
+
error_message = fields.Str(allow_none=True)
|
|
15
|
+
total_pages_discovered = fields.Int(allow_none=True)
|
|
16
|
+
total_pages_crawled = fields.Int(allow_none=True)
|
|
17
|
+
total_screenshots_captured = fields.Int(allow_none=True)
|
|
18
|
+
total_drugs_extracted = fields.Int(allow_none=True)
|
|
19
|
+
crawl_method = fields.Str(allow_none=True)
|
|
20
|
+
max_depth = fields.Int(allow_none=True)
|
|
21
|
+
created_at = fields.DateTime(dump_only=True)
|
|
22
|
+
updated_at = fields.DateTime(dump_only=True)
|
|
File without changes
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
Integer,
|
|
4
|
+
String,
|
|
5
|
+
DateTime,
|
|
6
|
+
Float,
|
|
7
|
+
Boolean,
|
|
8
|
+
ForeignKey,
|
|
9
|
+
Enum,
|
|
10
|
+
Index,
|
|
11
|
+
UniqueConstraint,
|
|
12
|
+
)
|
|
13
|
+
from datetime import datetime
|
|
14
|
+
|
|
15
|
+
from ...database import Base
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
class PipelineCrawledPageModel(Base):
|
|
19
|
+
__tablename__ = 'pipeline_crawled_pages'
|
|
20
|
+
|
|
21
|
+
id = Column(Integer, primary_key=True)
|
|
22
|
+
session_id = Column(
|
|
23
|
+
Integer,
|
|
24
|
+
ForeignKey('pipeline_crawl_sessions.id'),
|
|
25
|
+
nullable=False,
|
|
26
|
+
index=True,
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# URL information
|
|
30
|
+
url = Column(String(1024), nullable=False)
|
|
31
|
+
url_hash = Column(String(64), nullable=False, index=True)
|
|
32
|
+
page_title = Column(String(512), nullable=True)
|
|
33
|
+
|
|
34
|
+
# Page content storage (S3)
|
|
35
|
+
html_content_s3_key = Column(String(512), nullable=True)
|
|
36
|
+
html_content_hash = Column(String(64), nullable=True)
|
|
37
|
+
html_content_length = Column(Integer, nullable=True)
|
|
38
|
+
|
|
39
|
+
# Screenshot storage (S3)
|
|
40
|
+
screenshot_s3_key = Column(String(512), nullable=True)
|
|
41
|
+
screenshot_hash = Column(String(64), nullable=True)
|
|
42
|
+
screenshot_width = Column(Integer, nullable=True)
|
|
43
|
+
screenshot_height = Column(Integer, nullable=True)
|
|
44
|
+
screenshot_file_size = Column(Integer, nullable=True)
|
|
45
|
+
|
|
46
|
+
# Page classification (MySQL ENUM)
|
|
47
|
+
page_type = Column(
|
|
48
|
+
Enum('pipeline', 'science', 'rd', 'products', 'clinical_trials', 'other'),
|
|
49
|
+
nullable=True,
|
|
50
|
+
)
|
|
51
|
+
relevance_score = Column(Float, nullable=True)
|
|
52
|
+
|
|
53
|
+
# Extraction metadata
|
|
54
|
+
has_drug_data = Column(Boolean, nullable=True, default=False)
|
|
55
|
+
extraction_method = Column(String(50), nullable=True)
|
|
56
|
+
|
|
57
|
+
# Crawl metadata
|
|
58
|
+
crawl_depth = Column(Integer, nullable=True, default=0)
|
|
59
|
+
parent_page_id = Column(Integer, ForeignKey('pipeline_crawled_pages.id'), nullable=True)
|
|
60
|
+
discovered_from_url = Column(String(1024), nullable=True)
|
|
61
|
+
|
|
62
|
+
# Technical metadata
|
|
63
|
+
http_status_code = Column(Integer, nullable=True)
|
|
64
|
+
content_type = Column(String(128), nullable=True)
|
|
65
|
+
response_time_ms = Column(Integer, nullable=True)
|
|
66
|
+
|
|
67
|
+
# Timestamps
|
|
68
|
+
crawled_at = Column(DateTime, nullable=False, default=datetime.utcnow)
|
|
69
|
+
created_at = Column(DateTime, nullable=False, default=datetime.utcnow)
|
|
70
|
+
updated_at = Column(
|
|
71
|
+
DateTime,
|
|
72
|
+
nullable=False,
|
|
73
|
+
default=datetime.utcnow,
|
|
74
|
+
onupdate=datetime.utcnow,
|
|
75
|
+
)
|
|
76
|
+
|
|
77
|
+
__table_args__ = (
|
|
78
|
+
Index('idx_session_url_hash', 'session_id', 'url_hash'),
|
|
79
|
+
UniqueConstraint('session_id', 'url_hash', name='uq_session_url'),
|
|
80
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
from marshmallow import Schema, fields
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class PipelineCrawledPageSchema(Schema):
|
|
5
|
+
id = fields.Int(dump_only=True)
|
|
6
|
+
session_id = fields.Int(required=True)
|
|
7
|
+
url = fields.Str(required=True)
|
|
8
|
+
url_hash = fields.Str(required=True)
|
|
9
|
+
page_title = fields.Str(allow_none=True)
|
|
10
|
+
html_content_s3_key = fields.Str(allow_none=True)
|
|
11
|
+
html_content_hash = fields.Str(allow_none=True)
|
|
12
|
+
html_content_length = fields.Int(allow_none=True)
|
|
13
|
+
screenshot_s3_key = fields.Str(allow_none=True)
|
|
14
|
+
screenshot_hash = fields.Str(allow_none=True)
|
|
15
|
+
screenshot_width = fields.Int(allow_none=True)
|
|
16
|
+
screenshot_height = fields.Int(allow_none=True)
|
|
17
|
+
screenshot_file_size = fields.Int(allow_none=True)
|
|
18
|
+
page_type = fields.Str(allow_none=True)
|
|
19
|
+
relevance_score = fields.Float(allow_none=True)
|
|
20
|
+
has_drug_data = fields.Bool(allow_none=True)
|
|
21
|
+
extraction_method = fields.Str(allow_none=True)
|
|
22
|
+
crawl_depth = fields.Int(allow_none=True)
|
|
23
|
+
parent_page_id = fields.Int(allow_none=True)
|
|
24
|
+
discovered_from_url = fields.Str(allow_none=True)
|
|
25
|
+
http_status_code = fields.Int(allow_none=True)
|
|
26
|
+
content_type = fields.Str(allow_none=True)
|
|
27
|
+
response_time_ms = fields.Int(allow_none=True)
|
|
28
|
+
crawled_at = fields.DateTime(required=True)
|
|
29
|
+
created_at = fields.DateTime(dump_only=True)
|
|
30
|
+
updated_at = fields.DateTime(dump_only=True)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
class PipelineCrawledPageResourceSchema(PipelineCrawledPageSchema):
|
|
34
|
+
pass
|
|
File without changes
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
BIGINT,
|
|
4
|
+
Integer,
|
|
5
|
+
String,
|
|
6
|
+
DateTime,
|
|
7
|
+
Float,
|
|
8
|
+
Text,
|
|
9
|
+
Boolean,
|
|
10
|
+
ForeignKey,
|
|
11
|
+
Enum,
|
|
12
|
+
Index,
|
|
13
|
+
JSON,
|
|
14
|
+
)
|
|
15
|
+
from datetime import datetime
|
|
16
|
+
|
|
17
|
+
from ...database import Base
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
class PipelineDrugPortfolioModel(Base):
|
|
21
|
+
__tablename__ = 'pipeline_drug_portfolio'
|
|
22
|
+
|
|
23
|
+
id = Column(BIGINT, primary_key=True)
|
|
24
|
+
session_id = Column(
|
|
25
|
+
Integer,
|
|
26
|
+
ForeignKey('pipeline_crawl_sessions.id'),
|
|
27
|
+
nullable=False,
|
|
28
|
+
index=True,
|
|
29
|
+
)
|
|
30
|
+
page_id = Column(
|
|
31
|
+
Integer,
|
|
32
|
+
ForeignKey('pipeline_crawled_pages.id'),
|
|
33
|
+
nullable=False,
|
|
34
|
+
index=True,
|
|
35
|
+
)
|
|
36
|
+
|
|
37
|
+
company_sec_id = Column(
|
|
38
|
+
Integer,
|
|
39
|
+
ForeignKey('companies_sec.id'),
|
|
40
|
+
nullable=True,
|
|
41
|
+
index=True,
|
|
42
|
+
)
|
|
43
|
+
company_ous_id = Column(
|
|
44
|
+
Integer,
|
|
45
|
+
ForeignKey('companies_ous.id'),
|
|
46
|
+
nullable=True,
|
|
47
|
+
index=True,
|
|
48
|
+
)
|
|
49
|
+
|
|
50
|
+
# Core drug information
|
|
51
|
+
drug_name = Column(String(512), nullable=False, index=True)
|
|
52
|
+
drug_name_normalized = Column(String(512), nullable=True, index=True)
|
|
53
|
+
synonyms = Column(JSON, nullable=True)
|
|
54
|
+
|
|
55
|
+
modality = Column(String(256), nullable=True)
|
|
56
|
+
targets = Column(JSON, nullable=True)
|
|
57
|
+
mechanism_of_action = Column(Text, nullable=True)
|
|
58
|
+
|
|
59
|
+
# Indications (JSON)
|
|
60
|
+
indications = Column(JSON, nullable=False)
|
|
61
|
+
|
|
62
|
+
# Additional information (JSON)
|
|
63
|
+
additional_info = Column(JSON, nullable=True)
|
|
64
|
+
|
|
65
|
+
# Extraction metadata (MySQL ENUM)
|
|
66
|
+
extraction_method = Column(
|
|
67
|
+
Enum('html_parsing', 'vision_model', 'hybrid', 'manual'),
|
|
68
|
+
nullable=False,
|
|
69
|
+
)
|
|
70
|
+
extraction_confidence = Column(Float, nullable=True)
|
|
71
|
+
raw_extraction_text = Column(Text, nullable=True)
|
|
72
|
+
|
|
73
|
+
# Data quality flags
|
|
74
|
+
is_verified = Column(Boolean, nullable=True, default=False)
|
|
75
|
+
is_duplicate = Column(Boolean, nullable=True, default=False, index=True)
|
|
76
|
+
needs_review = Column(Boolean, nullable=True, default=False, index=True)
|
|
77
|
+
review_notes = Column(Text, nullable=True)
|
|
78
|
+
|
|
79
|
+
# Timestamps
|
|
80
|
+
extracted_at = Column(DateTime, nullable=False, default=datetime.utcnow)
|
|
81
|
+
created_at = Column(DateTime, nullable=False, default=datetime.utcnow)
|
|
82
|
+
updated_at = Column(
|
|
83
|
+
DateTime,
|
|
84
|
+
nullable=False,
|
|
85
|
+
default=datetime.utcnow,
|
|
86
|
+
onupdate=datetime.utcnow,
|
|
87
|
+
)
|
|
88
|
+
|
|
89
|
+
__table_args__ = (
|
|
90
|
+
Index('idx_company_drug_name', 'company_sec_id', 'drug_name_normalized'),
|
|
91
|
+
Index('idx_session_drug', 'session_id', 'drug_name_normalized'),
|
|
92
|
+
)
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
from marshmallow import Schema, fields
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class PipelineDrugPortfolioSchema(Schema):
|
|
5
|
+
id = fields.Int(dump_only=True)
|
|
6
|
+
session_id = fields.Int(required=True)
|
|
7
|
+
page_id = fields.Int(required=True)
|
|
8
|
+
company_sec_id = fields.Int(allow_none=True)
|
|
9
|
+
company_ous_id = fields.Int(allow_none=True)
|
|
10
|
+
drug_name = fields.Str(required=True)
|
|
11
|
+
drug_name_normalized = fields.Str(allow_none=True)
|
|
12
|
+
synonyms = fields.Raw(allow_none=True) # JSON array
|
|
13
|
+
modality = fields.Str(allow_none=True)
|
|
14
|
+
targets = fields.Raw(allow_none=True) # JSON array
|
|
15
|
+
mechanism_of_action = fields.Str(allow_none=True)
|
|
16
|
+
indications = fields.Raw(required=True) # JSON array
|
|
17
|
+
additional_info = fields.Raw(allow_none=True) # JSON object
|
|
18
|
+
extraction_method = fields.Str(required=True)
|
|
19
|
+
extraction_confidence = fields.Float(allow_none=True)
|
|
20
|
+
raw_extraction_text = fields.Str(allow_none=True)
|
|
21
|
+
is_verified = fields.Bool(allow_none=True)
|
|
22
|
+
is_duplicate = fields.Bool(allow_none=True)
|
|
23
|
+
needs_review = fields.Bool(allow_none=True)
|
|
24
|
+
review_notes = fields.Str(allow_none=True)
|
|
25
|
+
extracted_at = fields.DateTime(required=True)
|
|
26
|
+
created_at = fields.DateTime(dump_only=True)
|
|
27
|
+
updated_at = fields.DateTime(dump_only=True)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
class PipelineDrugPortfolioResourceSchema(PipelineDrugPortfolioSchema):
|
|
31
|
+
pass
|
|
File without changes
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
Integer,
|
|
4
|
+
String,
|
|
5
|
+
DateTime,
|
|
6
|
+
Text,
|
|
7
|
+
ForeignKey,
|
|
8
|
+
Enum,
|
|
9
|
+
)
|
|
10
|
+
from datetime import datetime
|
|
11
|
+
|
|
12
|
+
from ...database import Base
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
class PipelineExtractionLogModel(Base):
|
|
16
|
+
__tablename__ = 'pipeline_extraction_logs'
|
|
17
|
+
|
|
18
|
+
id = Column(Integer, primary_key=True)
|
|
19
|
+
session_id = Column(
|
|
20
|
+
Integer,
|
|
21
|
+
ForeignKey('pipeline_crawl_sessions.id'),
|
|
22
|
+
nullable=False,
|
|
23
|
+
index=True,
|
|
24
|
+
)
|
|
25
|
+
page_id = Column(
|
|
26
|
+
Integer,
|
|
27
|
+
ForeignKey('pipeline_crawled_pages.id'),
|
|
28
|
+
nullable=True,
|
|
29
|
+
)
|
|
30
|
+
|
|
31
|
+
# Log details (MySQL ENUM)
|
|
32
|
+
log_level = Column(
|
|
33
|
+
Enum('debug', 'info', 'warning', 'error'),
|
|
34
|
+
nullable=False,
|
|
35
|
+
default='info',
|
|
36
|
+
index=True,
|
|
37
|
+
)
|
|
38
|
+
message = Column(Text, nullable=False)
|
|
39
|
+
|
|
40
|
+
# Context
|
|
41
|
+
extraction_method = Column(String(50), nullable=True)
|
|
42
|
+
model_name = Column(String(128), nullable=True)
|
|
43
|
+
tokens_used = Column(Integer, nullable=True)
|
|
44
|
+
api_latency_ms = Column(Integer, nullable=True)
|
|
45
|
+
|
|
46
|
+
# Error tracking
|
|
47
|
+
exception_type = Column(String(256), nullable=True)
|
|
48
|
+
exception_message = Column(Text, nullable=True)
|
|
49
|
+
stack_trace = Column(Text, nullable=True)
|
|
50
|
+
|
|
51
|
+
# Retry tracking
|
|
52
|
+
attempt_number = Column(Integer, nullable=True, default=1)
|
|
53
|
+
max_attempts = Column(Integer, nullable=True, default=3)
|
|
54
|
+
|
|
55
|
+
created_at = Column(DateTime, nullable=False, default=datetime.utcnow, index=True)
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
from marshmallow import Schema, fields
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class PipelineExtractionLogSchema(Schema):
|
|
5
|
+
id = fields.Int(dump_only=True)
|
|
6
|
+
session_id = fields.Int(required=True)
|
|
7
|
+
page_id = fields.Int(allow_none=True)
|
|
8
|
+
log_level = fields.Str(required=True)
|
|
9
|
+
message = fields.Str(required=True)
|
|
10
|
+
extraction_method = fields.Str(allow_none=True)
|
|
11
|
+
model_name = fields.Str(allow_none=True)
|
|
12
|
+
tokens_used = fields.Int(allow_none=True)
|
|
13
|
+
api_latency_ms = fields.Int(allow_none=True)
|
|
14
|
+
exception_type = fields.Str(allow_none=True)
|
|
15
|
+
exception_message = fields.Str(allow_none=True)
|
|
16
|
+
stack_trace = fields.Str(allow_none=True)
|
|
17
|
+
attempt_number = fields.Int(allow_none=True)
|
|
18
|
+
max_attempts = fields.Int(allow_none=True)
|
|
19
|
+
created_at = fields.DateTime(dump_only=True)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class PipelineExtractionLogResourceSchema(PipelineExtractionLogSchema):
|
|
23
|
+
pass
|
|
File without changes
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
Integer,
|
|
4
|
+
String,
|
|
5
|
+
Text,
|
|
6
|
+
DateTime,
|
|
7
|
+
)
|
|
8
|
+
from datetime import datetime
|
|
9
|
+
from ...database import Base
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class PromptIndicesModel(Base):
|
|
13
|
+
__tablename__ = 'prompt_indices'
|
|
14
|
+
|
|
15
|
+
id = Column(Integer, primary_key=True)
|
|
16
|
+
prompt_index = Column(String(128), nullable=False)
|
|
17
|
+
text = Column(Text, nullable=False)
|
|
18
|
+
metadatas = Column(Text, nullable=False)
|
|
19
|
+
vector = Column(Text, nullable=False)
|
|
20
|
+
search_type = Column(String(50), nullable=True)
|
|
21
|
+
updated_at = Column(
|
|
22
|
+
DateTime,
|
|
23
|
+
nullable=False,
|
|
24
|
+
# https://stackoverflow.com/questions/58776476/why-doesnt-freezegun-work-with-sqlalchemy-default-values
|
|
25
|
+
default=lambda: datetime.utcnow(),
|
|
26
|
+
onupdate=lambda: datetime.utcnow(),
|
|
27
|
+
)
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
from marshmallow import (
|
|
2
|
+
Schema,
|
|
3
|
+
fields,
|
|
4
|
+
validate,
|
|
5
|
+
)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class PromptIndicesSchema(Schema):
|
|
9
|
+
not_blank = validate.Length(min=1, error='Field cannot be blank')
|
|
10
|
+
|
|
11
|
+
id = fields.Integer(dump_only=True)
|
|
12
|
+
prompt_index = fields.String(required=True)
|
|
13
|
+
text = fields.String(required=True)
|
|
14
|
+
metadatas = fields.String(required=True)
|
|
15
|
+
vector = fields.String(required=True)
|
|
16
|
+
search_type = fields.String(allow_none=True)
|
|
17
|
+
updated_at = fields.DateTime()
|
|
File without changes
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
from sqlalchemy import (
|
|
2
|
+
Column,
|
|
3
|
+
Integer,
|
|
4
|
+
Float,
|
|
5
|
+
DateTime,
|
|
6
|
+
ForeignKey,
|
|
7
|
+
UniqueConstraint,
|
|
8
|
+
)
|
|
9
|
+
from datetime import datetime
|
|
10
|
+
|
|
11
|
+
from ...database import Base
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class PubmedMeetingSellSideSignalModel(Base):
|
|
15
|
+
__tablename__ = "pubmed_meeting_sell_side_signals"
|
|
16
|
+
|
|
17
|
+
id = Column(Integer, primary_key=True)
|
|
18
|
+
|
|
19
|
+
pubmed_id = Column(
|
|
20
|
+
Integer,
|
|
21
|
+
ForeignKey("pubmed.id"),
|
|
22
|
+
nullable=False,
|
|
23
|
+
index=True,
|
|
24
|
+
)
|
|
25
|
+
meeting_id = Column(
|
|
26
|
+
Integer,
|
|
27
|
+
ForeignKey("meetings.id"),
|
|
28
|
+
nullable=False,
|
|
29
|
+
index=True,
|
|
30
|
+
)
|
|
31
|
+
sell_side_source_id = Column(
|
|
32
|
+
Integer,
|
|
33
|
+
ForeignKey("sell_side_sources.id"),
|
|
34
|
+
nullable=False,
|
|
35
|
+
index=True,
|
|
36
|
+
)
|
|
37
|
+
|
|
38
|
+
# intensity
|
|
39
|
+
doc_count = Column(Integer, nullable=False) # distinct notes
|
|
40
|
+
mention_count = Column(Integer, nullable=False) # total mentions across those notes
|
|
41
|
+
|
|
42
|
+
# sentiment summary
|
|
43
|
+
avg_sentiment = Column(Float, nullable=True)
|
|
44
|
+
max_sentiment = Column(Float, nullable=True)
|
|
45
|
+
|
|
46
|
+
first_mention_at = Column(DateTime, nullable=True)
|
|
47
|
+
last_mention_at = Column(DateTime, nullable=True)
|
|
48
|
+
|
|
49
|
+
created_at = Column(DateTime, default=lambda: datetime.utcnow(), nullable=False)
|
|
50
|
+
updated_at = Column(
|
|
51
|
+
DateTime,
|
|
52
|
+
default=lambda: datetime.utcnow(),
|
|
53
|
+
onupdate=lambda: datetime.utcnow(),
|
|
54
|
+
nullable=False,
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
__table_args__ = (
|
|
58
|
+
UniqueConstraint(
|
|
59
|
+
"pubmed_id",
|
|
60
|
+
"meeting_id",
|
|
61
|
+
"sell_side_source_id",
|
|
62
|
+
name="uq_pubmed_meeting_source",
|
|
63
|
+
),
|
|
64
|
+
)
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
from marshmallow import Schema, fields, validate
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class PubmedMeetingSellSideSignalResourceSchema(Schema):
|
|
5
|
+
id = fields.Integer(dump_only=True)
|
|
6
|
+
|
|
7
|
+
pubmed_id = fields.Integer(required=True)
|
|
8
|
+
meeting_id = fields.Integer(required=True)
|
|
9
|
+
sell_side_source_id = fields.Integer(required=True)
|
|
10
|
+
|
|
11
|
+
doc_count = fields.Integer(required=True)
|
|
12
|
+
mention_count = fields.Integer(required=True)
|
|
13
|
+
|
|
14
|
+
avg_sentiment = fields.Float(allow_none=True)
|
|
15
|
+
max_sentiment = fields.Float(allow_none=True)
|
|
16
|
+
|
|
17
|
+
first_mention_at = fields.DateTime(allow_none=True)
|
|
18
|
+
last_mention_at = fields.DateTime(allow_none=True)
|
|
19
|
+
|
|
20
|
+
created_at = fields.DateTime(dump_only=True)
|
|
21
|
+
updated_at = fields.DateTime(dump_only=True)
|
|
File without changes
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
from datetime import datetime
|
|
2
|
+
|
|
3
|
+
from sqlalchemy import (
|
|
4
|
+
Column,
|
|
5
|
+
Text,
|
|
6
|
+
Integer,
|
|
7
|
+
DateTime,
|
|
8
|
+
ForeignKey,
|
|
9
|
+
)
|
|
10
|
+
|
|
11
|
+
from ...database import Base
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class PubmedMeetingUserDocumentModel(Base):
|
|
15
|
+
__tablename__ = "pubmed_meeting_user_documents"
|
|
16
|
+
|
|
17
|
+
id = Column(Integer, primary_key=True)
|
|
18
|
+
pubmed_id = Column(
|
|
19
|
+
Integer,
|
|
20
|
+
ForeignKey('pubmed.id'),
|
|
21
|
+
nullable=False,
|
|
22
|
+
)
|
|
23
|
+
meeting_id = Column(
|
|
24
|
+
Integer,
|
|
25
|
+
ForeignKey('meetings.id'),
|
|
26
|
+
nullable=False,
|
|
27
|
+
)
|
|
28
|
+
user_document_id = Column(
|
|
29
|
+
Integer,
|
|
30
|
+
ForeignKey('user_documents.id'),
|
|
31
|
+
nullable=False,
|
|
32
|
+
)
|
|
33
|
+
details = Column(Text, nullable=True)
|
|
34
|
+
updated_at = Column(
|
|
35
|
+
DateTime,
|
|
36
|
+
nullable=False,
|
|
37
|
+
# https://stackoverflow.com/questions/58776476/why-doesnt-freezegun-work-with-sqlalchemy-default-values
|
|
38
|
+
default=lambda: datetime.utcnow(),
|
|
39
|
+
onupdate=lambda: datetime.utcnow(),
|
|
40
|
+
)
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
from marshmallow import (
|
|
2
|
+
Schema,
|
|
3
|
+
fields,
|
|
4
|
+
validate,
|
|
5
|
+
)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class PubmedMeetingUserDocumentResourceSchema(Schema):
|
|
9
|
+
not_blank = validate.Length(min=1, error='Field cannot be blank')
|
|
10
|
+
|
|
11
|
+
id = fields.Integer(dump_only=True)
|
|
12
|
+
pubmed_id = fields.Integer(required=True)
|
|
13
|
+
meeting_id = fields.Integer(required=True)
|
|
14
|
+
user_document_id = fields.Integer(required=True)
|
|
15
|
+
details = fields.String(allow_none=True)
|
|
16
|
+
updated_at = fields.DateTime()
|
|
File without changes
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
from datetime import datetime
|
|
2
|
+
|
|
3
|
+
from sqlalchemy import (
|
|
4
|
+
Column,
|
|
5
|
+
Integer,
|
|
6
|
+
DateTime,
|
|
7
|
+
ForeignKey,
|
|
8
|
+
Boolean,
|
|
9
|
+
)
|
|
10
|
+
|
|
11
|
+
from ...database import Base
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class PubmedUserDocumentModel(Base):
|
|
15
|
+
__tablename__ = "pubmed_user_documents"
|
|
16
|
+
|
|
17
|
+
id = Column(Integer, primary_key=True)
|
|
18
|
+
pubmed_id = Column(
|
|
19
|
+
Integer,
|
|
20
|
+
ForeignKey('pubmed.id'),
|
|
21
|
+
nullable=False,
|
|
22
|
+
)
|
|
23
|
+
user_document_id = Column(
|
|
24
|
+
Integer,
|
|
25
|
+
ForeignKey('user_documents.id'),
|
|
26
|
+
nullable=False,
|
|
27
|
+
)
|
|
28
|
+
is_deleted = Column(Boolean, nullable=True)
|
|
29
|
+
updated_at = Column(
|
|
30
|
+
DateTime,
|
|
31
|
+
nullable=False,
|
|
32
|
+
# https://stackoverflow.com/questions/58776476/why-doesnt-freezegun-work-with-sqlalchemy-default-values
|
|
33
|
+
default=lambda: datetime.utcnow(),
|
|
34
|
+
onupdate=lambda: datetime.utcnow(),
|
|
35
|
+
)
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
from marshmallow import (
|
|
2
|
+
Schema,
|
|
3
|
+
fields,
|
|
4
|
+
validate,
|
|
5
|
+
)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class PubmedUserDocumentResourceSchema(Schema):
|
|
9
|
+
not_blank = validate.Length(min=1, error='Field cannot be blank')
|
|
10
|
+
|
|
11
|
+
id = fields.Integer(dump_only=True)
|
|
12
|
+
pubmed_id = fields.Integer(required=True)
|
|
13
|
+
user_document_id = fields.Integer(required=True)
|
|
14
|
+
is_deleted = fields.Boolean(allow_none=True)
|
|
15
|
+
updated_at = fields.DateTime()
|