From 41136303f84d2dfd1cf913a8e261425f636737d1 Mon Sep 17 00:00:00 2001 From: Nick Phura Date: Tue, 25 Jun 2024 11:50:02 -0700 Subject: [PATCH] BugFixes: Bug Fixes and Misc Cleanup (#1312) * Migrate deprecated attachment file_type values (was impacting Test and Prod). * Remove deprecated wldtaxonomic_units_id and field_method_id columns. * Update minimum replicas to stop some of the platform alert spam about horizontal pod autoscalars * Comment out HorizontalPodAutoscaler in API/APP * Update clamav readme and files. --- api/.pipeline/config.js | 2 +- api/.pipeline/templates/api.dc.yaml | 41 ++-- api/src/models/biohub-create.test.ts | 2 - .../repositories/observation-repository.ts | 1 - api/src/repositories/survey-repository.ts | 1 - api/src/services/observation-service.test.ts | 2 - app/.pipeline/config.js | 4 +- app/.pipeline/templates/app.dc.yaml | 41 ++-- containers/clamav/Dockerfile | 32 ++-- containers/clamav/README.md | 84 +++++++-- containers/clamav/config/clamd.conf | 2 +- containers/clamav/config/freshclam.conf | 11 -- .../clamav/openshift/templates/clamav-bc.yaml | 63 ++----- .../clamav/openshift/templates/clamav-dc.yaml | 177 +++++++++--------- .../20240624000000_attachment_type_fix.ts | 49 +++++ .../seeds/03_basic_project_survey_setup.ts | 11 -- 16 files changed, 287 insertions(+), 236 deletions(-) create mode 100644 database/src/migrations/20240624000000_attachment_type_fix.ts diff --git a/api/.pipeline/config.js b/api/.pipeline/config.js index ae315d1a09..05d8dc2980 100644 --- a/api/.pipeline/config.js +++ b/api/.pipeline/config.js @@ -100,7 +100,7 @@ const phases = { memoryRequest: '100Mi', memoryLimit: '4Gi', replicas: '1', - replicasMax: (isStaticDeployment && '2') || '1' + replicasMax: '1' }, test: { namespace: 'af2668-test', diff --git a/api/.pipeline/templates/api.dc.yaml b/api/.pipeline/templates/api.dc.yaml index bcf5fd08f8..dadc130ce9 100644 --- a/api/.pipeline/templates/api.dc.yaml +++ b/api/.pipeline/templates/api.dc.yaml @@ -464,23 +464,24 @@ objects: status: ingress: null - - kind: HorizontalPodAutoscaler - apiVersion: autoscaling/v2 - metadata: - annotations: {} - labels: {} - name: ${NAME}${SUFFIX} - spec: - minReplicas: ${{REPLICAS}} - maxReplicas: ${{REPLICAS_MAX}} - scaleTargetRef: - apiVersion: apps.openshift.io/v1 - kind: DeploymentConfig - name: ${NAME}${SUFFIX} - metrics: - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: 80 + # Disable the HPA for now, as it is preferrable to run an exact number of pods (e.g. min:2, max:2) + # - kind: HorizontalPodAutoscaler + # apiVersion: autoscaling/v2 + # metadata: + # annotations: {} + # labels: {} + # name: ${NAME}${SUFFIX} + # spec: + # minReplicas: ${{REPLICAS}} + # maxReplicas: ${{REPLICAS_MAX}} + # scaleTargetRef: + # apiVersion: apps.openshift.io/v1 + # kind: DeploymentConfig + # name: ${NAME}${SUFFIX} + # metrics: + # - type: Resource + # resource: + # name: cpu + # target: + # type: Utilization + # averageUtilization: 80 diff --git a/api/src/models/biohub-create.test.ts b/api/src/models/biohub-create.test.ts index 81261b3d65..c5dedaba10 100644 --- a/api/src/models/biohub-create.test.ts +++ b/api/src/models/biohub-create.test.ts @@ -16,7 +16,6 @@ describe('PostSurveyObservationToBiohubObject', () => { const obj = { survey_observation_id: 1, survey_id: 1, - wldtaxonomic_units_id: 1, survey_sample_site_id: 1, survey_sample_method_id: 1, survey_sample_period_id: 1, @@ -159,7 +158,6 @@ describe('PostSurveySubmissionToBioHubObject', () => { { survey_observation_id: 1, survey_id: 1, - wldtaxonomic_units_id: 1, survey_sample_site_id: 1, survey_sample_method_id: 1, survey_sample_period_id: 1, diff --git a/api/src/repositories/observation-repository.ts b/api/src/repositories/observation-repository.ts index 66f2d37cbf..3ed31fc931 100644 --- a/api/src/repositories/observation-repository.ts +++ b/api/src/repositories/observation-repository.ts @@ -24,7 +24,6 @@ const defaultLog = getLogger('repositories/observation-repository'); export const ObservationRecord = z.object({ survey_observation_id: z.number(), survey_id: z.number(), - wldtaxonomic_units_id: z.number().nullable(), itis_tsn: z.number(), itis_scientific_name: z.string().nullable(), survey_sample_site_id: z.number().nullable(), diff --git a/api/src/repositories/survey-repository.ts b/api/src/repositories/survey-repository.ts index f93ed62c39..57b223394e 100644 --- a/api/src/repositories/survey-repository.ts +++ b/api/src/repositories/survey-repository.ts @@ -48,7 +48,6 @@ export interface ISurveyProprietorModel { const SurveyRecord = z.object({ survey_id: z.number(), project_id: z.number(), - field_method_id: z.number().nullable(), uuid: z.string().uuid().nullable(), name: z.string().nullable(), additional_details: z.string().nullable(), diff --git a/api/src/services/observation-service.test.ts b/api/src/services/observation-service.test.ts index 80cc19d552..be821fbf48 100644 --- a/api/src/services/observation-service.test.ts +++ b/api/src/services/observation-service.test.ts @@ -40,7 +40,6 @@ describe('ObservationService', () => { { survey_observation_id: 11, survey_id: 1, - wldtaxonomic_units_id: 2, latitude: 3, longitude: 4, count: 5, @@ -60,7 +59,6 @@ describe('ObservationService', () => { { survey_observation_id: 6, survey_id: 1, - wldtaxonomic_units_id: 2, latitude: 8, longitude: 9, count: 10, diff --git a/app/.pipeline/config.js b/app/.pipeline/config.js index d5c194ad0c..26853318e4 100644 --- a/app/.pipeline/config.js +++ b/app/.pipeline/config.js @@ -87,8 +87,8 @@ const phases = { cpuLimit: '300m', memoryRequest: '100Mi', memoryLimit: '500Mi', - replicas: (isStaticDeployment && '1') || '1', - replicasMax: (isStaticDeployment && '2') || '1', + replicas: '1', + replicasMax: '1', biohubFeatureFlag: 'true', backbonePublicApiHost: 'https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca', biohubTaxonPath: '/api/taxonomy/taxon', diff --git a/app/.pipeline/templates/app.dc.yaml b/app/.pipeline/templates/app.dc.yaml index 6bc31cf023..b5dc3a60c9 100644 --- a/app/.pipeline/templates/app.dc.yaml +++ b/app/.pipeline/templates/app.dc.yaml @@ -264,23 +264,24 @@ objects: status: ingress: null - - kind: HorizontalPodAutoscaler - apiVersion: autoscaling/v2 - metadata: - annotations: {} - labels: {} - name: ${NAME}${SUFFIX} - spec: - minReplicas: ${{REPLICAS}} - maxReplicas: ${{REPLICAS_MAX}} - scaleTargetRef: - apiVersion: apps.openshift.io/v1 - kind: DeploymentConfig - name: ${NAME}${SUFFIX} - metrics: - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: 80 + # Disable the HPA for now, as it is preferrable to run an exact number of pods (e.g. min:2, max:2) + # - kind: HorizontalPodAutoscaler + # apiVersion: autoscaling/v2 + # metadata: + # annotations: {} + # labels: {} + # name: ${NAME}${SUFFIX} + # spec: + # minReplicas: ${{REPLICAS}} + # maxReplicas: ${{REPLICAS_MAX}} + # scaleTargetRef: + # apiVersion: apps.openshift.io/v1 + # kind: DeploymentConfig + # name: ${NAME}${SUFFIX} + # metrics: + # - type: Resource + # resource: + # name: cpu + # target: + # type: Utilization + # averageUtilization: 80 diff --git a/containers/clamav/Dockerfile b/containers/clamav/Dockerfile index 25c47ff5a2..c143369be5 100644 --- a/containers/clamav/Dockerfile +++ b/containers/clamav/Dockerfile @@ -1,28 +1,30 @@ -FROM registry.access.redhat.com/ubi8/ubi +FROM registry.access.redhat.com/ubi9/ubi +ARG VERSION=1.0.5 LABEL name="ubi8-clamav" \ vendor="Red Hat" \ - version="0.1.0" \ + version="${VERSION}" \ release="1" \ - summary="UBI 8 ClamAV" \ - description="ClamAV for UBI 8" \ + summary="UBI 9 ClamAV" \ + description="ClamAV for UBI 9" \ maintainer="EPIC" -RUN yum -y update \ - && yum -y install yum-utils \ - && rpm --import http://dl.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-8 \ - && yum -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm -RUN yum install -y clamav-server clamav-data clamav-update clamav-filesystem clamav clamav-scanner-systemd clamav-devel clamav-lib clamav-server-systemd -RUN yum install -y wget +RUN yum -y update +RUN yum -y install https://www.clamav.net/downloads/production/clamav-${VERSION}.linux.x86_64.rpm +RUN yum -y install nc wget -COPY config/clamd.conf /etc/clamd.conf -COPY config/freshclam.conf /etc/freshclam.conf +# copy our configs to where clamav expects +COPY config/clamd.conf /usr/local/etc/clamd.conf +COPY config/freshclam.conf /usr/local/etc/freshclam.conf -RUN mkdir /opt/app-root -RUN mkdir /opt/app-root/src +RUN mkdir -p /opt/app-root/src RUN chown -R 1001:0 /opt/app-root/src RUN chmod -R ug+rwx /opt/app-root/src +# copy health check script to app-root +COPY clamdcheck.sh /opt/app-root +RUN chmod ug+rwx /opt/app-root/clamdcheck.sh + # # To fix check permissions error for clamAV RUN mkdir /var/log/clamav RUN touch /var/log/clamav/clamav.log @@ -36,4 +38,4 @@ USER 1001 EXPOSE 3310 -CMD freshclam && clamd -c /etc/clamd.conf +CMD freshclam && clamd diff --git a/containers/clamav/README.md b/containers/clamav/README.md index edfb17c750..13e97d4342 100644 --- a/containers/clamav/README.md +++ b/containers/clamav/README.md @@ -2,34 +2,84 @@ ClamAV® is an open source antivirus engine for detecting trojans, viruses, malware & other malicious threats. -This is a repo setup for utilization in Red Hat Openshift. This solution allows you to create a pod in your openshift environment to scan any file for known virus signatures, quickly and effectively. +See this repo for the OpenShift templates needed to deploy ClamAV: https://github.com/bcgov/clamav -The builds package the barebones service, and the deployment config will download latest signatures on first run. +The source repo should be used as it will have the latest versions, etc. +Note: at the time of writing this, the `clamav-dc.conf` in the source repo has the `IMAGE_NAMESPACE` variable hard-coded to a random project, which will need to be updated to this projects tools environment. Similarly, depending on the current version of OpenShift, some of the `apiVersion` in the build config and/or deploy config may be out of date and need updating. -Freshclam can be run within the container at any time to update the existing signatures. Alternatively, you can re-deploy which will fetch the latest into the running container. +A copy of the templates patched templates (converted to yaml) are included here as backup, in case the source repo is moved or becomes unavailable. -This clamav setup is cloned from the repo: https://github.com/bcgov/clamav +## Installation -## Prerequisites For Deploying On OpenShift +### Checkout the clamav repo. -### Import Base Image for `ubi8/ubi` Used By `clamav-bc.yaml` +### Import the Build Config -- Fetch latest version +1. Log into OpenShift +2. Switch to your tools environment. - ``` - oc import-image ubi8/ubi:latest --from=registry.access.redhat.com/ubi8/ubi:latest --confirm - ``` + ``` + oc project -tools + ``` -Openshift documentation on importing images +3. Navigate to the `/openshift/templates` folder +4. Import the clamav build config (clamav-bc.yaml) -- https://catalog.redhat.com/software/containers/ubi8/ubi/5c359854d70cc534b3a3784e?tag=latest&push_date=1673532745000&architecture=amd64&container-tabs=gti>i-tabs=unauthenticated + ``` + oc process -f clamav-bc.conf | oc create -f - + ``` - - See `oc import-image` command + This will create a new BuildConfig (`clamav-build`) and ImageStream (`clamav`). -## Build/Deployment +#### Build the Image -The templates in the `./openshift/templates` will build and deploy the app. Modify to suit your own environment. +1. Run the build -The build config `./openshift/templates/clamav-bc.yaml` will create your builder image (ideally in your tools project), and the deployment config `./openshift/templates/clamav-dc.yaml` will create the pod deployment. + ``` + OpenShift Web UI (Administrator) -> Builds -> BuildConfigs -> clamav-build -> Actions -> Start build + ``` -Modify the environment variables defined in both the build config and deployment config appropriately. + This will build the image, adding a new tag to the `clamav` ImageStream (`clamav:latest`) + +### Import the Deployment Config + +1. Log into OpenShift +2. Switch to your dev environment. + + ``` + oc project -dev + ``` + +3. Navigate to the `/openshift/templates` folder +4. Import the clamav deployment config (clamav-dc.yaml) + + ``` + oc process -f clamav-dc.conf | oc create -f - + ``` + + This will create a new DeploymentConfig (`clamav`) and Service (`clamav`). + +#### Deploy the Image + +1. Deploy the image + + ``` + OpenShift Web UI (Administrator) -> Workloads -> DeploymentConfigs -> clamav -> Actions -> Start Rollout + ``` + + This will deploy a Pod running the ClamaAV image. + +#### Repeat for the Test and Prod environments + +## Testing Files For Viruses Against ClamAV + +See NPM Package: [clamscan](https://www.npmjs.com/package/clamscan) + +When creating a new instance of clamscan, the default Host and Port of the above installation are: + +- Host: `clamav` +- Port: `3310` + +## Other + +Depending on your OpenShift setup, you may need to add a NetworkPolicy to allow dev/test/prod to see images from tools, etc. diff --git a/containers/clamav/config/clamd.conf b/containers/clamav/config/clamd.conf index 11d678cfce..85ecfa870f 100644 --- a/containers/clamav/config/clamd.conf +++ b/containers/clamav/config/clamd.conf @@ -118,7 +118,7 @@ TCPSocket 3310 # Close the connection when the data size limit is exceeded. # The value should match your MTA's limit for a maximum attachment size. # Default: 25M -StreamMaxLength 300M +StreamMaxLength 4000M # Limit port range. # Default: 1024 diff --git a/containers/clamav/config/freshclam.conf b/containers/clamav/config/freshclam.conf index 632fe74a85..161f238d1c 100644 --- a/containers/clamav/config/freshclam.conf +++ b/containers/clamav/config/freshclam.conf @@ -69,17 +69,6 @@ DatabaseOwner clamupdate # Use the ClamAV Mirror provided in OCP4 Silver cluster DatabaseMirror https://clamav-mirror.apps.silver.devops.gov.bc.ca -# Uncomment the following line and replace XY with your country -# code. See http://www.iana.org/cctld/cctld-whois.htm for the full list. -# You can use db.XY.ipv6.clamav.net for IPv6 connections. -DatabaseMirror db.ca.clamav.net - -# database.clamav.net is a round-robin record which points to our most -# reliable mirrors. It's used as a fall back in case db.XY.clamav.net is -# not working. DO NOT TOUCH the following line unless you know what you -# are doing. -DatabaseMirror database.clamav.net - # How many attempts to make before giving up. # Default: 3 (per mirror) #MaxAttempts 5 diff --git a/containers/clamav/openshift/templates/clamav-bc.yaml b/containers/clamav/openshift/templates/clamav-bc.yaml index 633bcdb60f..af9b5bc210 100644 --- a/containers/clamav/openshift/templates/clamav-bc.yaml +++ b/containers/clamav/openshift/templates/clamav-bc.yaml @@ -1,86 +1,61 @@ kind: Template apiVersion: template.openshift.io/v1 metadata: - name: clamav-build + name: clamav parameters: - name: NAME displayName: Name description: The name assigned to all of the objects defined in this template. - value: clamav required: true + value: clamav - name: GIT_SOURCE_URL displayName: GIT Source Repo URL description: A GIT URL to your source code. - value: "https://github.com/bcgov/biohubbc.git" required: true + value: https://github.com/bcgov/clamav.git - name: GIT_REF displayName: Git Reference description: The git reference or branch. - value: dev - required: true - - name: SOURCE_CONTEXT_DIR - displayName: Source Context Directory - description: The source context directory. - value: containers/clamav - - name: NAME_SPACE - displayName: Namespace for source image - value: af2668-tools required: true - - name: CPU_REQUEST - value: "100m" - - name: CPU_LIMIT - value: "1000m" - - name: MEMORY_REQUEST - value: "2G" - - name: MEMORY_LIMIT - value: "4G" + value: master objects: - kind: ImageStream - apiVersion: image.openshift.io/v1 + apiVersion: v1 metadata: name: "${NAME}" - - kind: BuildConfig - apiVersion: build.openshift.io/v1 + apiVersion: v1 metadata: name: "${NAME}-build" + creationTimestamp: labels: app: "${NAME}" spec: runPolicy: Serial completionDeadlineSeconds: 1800 + triggers: + - type: ConfigChange source: type: Git git: - ref: "${GIT_REF}" uri: "${GIT_SOURCE_URL}" - contextDir: "${SOURCE_CONTEXT_DIR}" - secrets: - - secret: - name: platform-services-controlled-etc-pki-entitlement - destinationDir: etc-pki-entitlement - configMaps: - - configMap: - name: platform-services-controlled-rhsm-conf - destinationDir: rhsm-conf - - configMap: - name: platform-services-controlled-rhsm-ca - destinationDir: rhsm-ca + ref: "${GIT_REF}" strategy: type: Docker dockerStrategy: - from: - kind: ImageStreamTag - name: "ubi:latest" - namespace: "${NAME_SPACE}" + env: + - name: CLAMAV_NO_MILTERD + value: "true" output: to: kind: ImageStreamTag name: "${NAME}:latest" resources: requests: - cpu: ${CPU_REQUEST} - memory: ${MEMORY_REQUEST} + cpu: 100m + memory: 2Gi limits: - cpu: ${CPU_LIMIT} - memory: ${MEMORY_LIMIT} + cpu: "1" + memory: 4Gi + status: + lastVersion: 0 diff --git a/containers/clamav/openshift/templates/clamav-dc.yaml b/containers/clamav/openshift/templates/clamav-dc.yaml index e0f5260544..0bf4505e4f 100644 --- a/containers/clamav/openshift/templates/clamav-dc.yaml +++ b/containers/clamav/openshift/templates/clamav-dc.yaml @@ -1,109 +1,110 @@ kind: Template -apiVersion: template.openshift.io/v1 +apiVersion: v1 metadata: - name: clamav-deploy + name: clamav parameters: - - name: NAME_SPACE - value: af2668-tools + - description: + The name assigned to all of the openshift objects defined in this template. + It is also the name of runtime image you want. + displayName: Name + name: NAME required: true - - name: CPU_REQUEST - value: "100m" - - name: CPU_LIMIT - value: "1100m" - - name: MEMORY_REQUEST - value: "500M" - - name: MEMORY_LIMIT - value: "2G" - - name: REPLICAS - value: "1" + value: clamav + - description: The namespace where to get the above image name + displayName: Image Namespace + name: IMAGE_NAMESPACE + required: true + value: biohubbc-tools + - description: The name of the role label, used to uniquely identify this deployment + displayName: Role Name + name: ROLE_NAME + value: clamav + - description: The TAG name for this environment, e.g., dev, test, prod + displayName: Env TAG name + name: TAG_NAME + value: dev objects: - - kind: Service - apiVersion: v1 + - apiVersion: apps.openshift.io/v1 + kind: DeploymentConfig metadata: - name: clamav + creationTimestamp: labels: - app: clamav + app: "${NAME}" + role: "${ROLE_NAME}" + name: "${NAME}" spec: - ports: - - name: 3310-tcp - protocol: TCP - port: 3310 - targetPort: 3310 + replicas: 1 selector: - deploymentconfig: clamav - type: ClusterIP - sessionAffinity: None - status: - loadBalancer: {} - - - kind: DeploymentConfig - apiVersion: apps.openshift.io/v1 - metadata: - name: clamav - generation: 1 - labels: - app: clamav - spec: + app: "${NAME}" + deploymentconfig: "${NAME}" strategy: + rollingParams: + intervalSeconds: 1 + maxSurge: 25% + maxUnavailable: 25% + timeoutSeconds: 600 + updatePeriodSeconds: 1 type: Rolling - activeDeadlineSeconds: 21600 - triggers: - - type: ImageChange - imageChangeParams: - automatic: true - containerNames: - - clamav - from: - kind: ImageStreamTag - namespace: "${NAME_SPACE}" - name: "clamav:latest" - - type: ConfigChange - replicas: ${{REPLICAS}} - test: false - selector: - app: clamav - deploymentconfig: clamav template: metadata: + creationTimestamp: labels: - app: clamav - deploymentconfig: clamav - annotations: - openshift.io/generated-by: OpenShiftWebConsole + app: "${NAME}" + role: "${ROLE_NAME}" + deploymentconfig: "${NAME}" spec: containers: - - resources: - requests: - cpu: ${CPU_REQUEST} - memory: ${MEMORY_REQUEST} - limits: - cpu: ${CPU_LIMIT} - memory: ${MEMORY_LIMIT} - readinessProbe: - tcpSocket: - port: 3310 - initialDelaySeconds: 240 - timeoutSeconds: 3 - periodSeconds: 10 - successThreshold: 1 - failureThreshold: 3 - terminationMessagePath: /dev/termination-log - name: clamav - livenessProbe: - tcpSocket: - port: 3310 - initialDelaySeconds: 240 - timeoutSeconds: 3 - periodSeconds: 10 - successThreshold: 1 - failureThreshold: 3 + - image: "${NAME}" + imagePullPolicy: Always + name: "${NAME}" ports: - containerPort: 3310 protocol: TCP - imagePullPolicy: Always - terminationMessagePolicy: File - restartPolicy: Always - terminationGracePeriodSeconds: 30 + env: + - name: RealIpFrom + value: "${REAL_IP_FROM}" + - name: AdditionalRealIpFromRules + value: "${AdditionalRealIpFromRules}" + - name: IpFilterRules + value: "${IpFilterRules}" + resources: + requests: + cpu: 1000m + memory: 1Gi + limits: + cpu: 2000m + memory: 2Gi dnsPolicy: ClusterFirst + restartPolicy: Always securityContext: {} - schedulerName: default-scheduler + terminationGracePeriodSeconds: 30 + test: false + triggers: + - type: ConfigChange + - type: ImageChange + imageChangeParams: + automatic: true + containerNames: + - "${NAME}" + from: + kind: ImageStreamTag + namespace: "${IMAGE_NAMESPACE}" + name: "${NAME}:${TAG_NAME}" + - apiVersion: v1 + kind: Service + metadata: + creationTimestamp: + labels: + app: "${NAME}" + name: "${NAME}" + spec: + ports: + - name: 3310-tcp + port: 3310 + protocol: TCP + targetPort: 3310 + selector: + app: "${NAME}" + deploymentconfig: "${NAME}" + sessionAffinity: None + type: ClusterIP diff --git a/database/src/migrations/20240624000000_attachment_type_fix.ts b/database/src/migrations/20240624000000_attachment_type_fix.ts new file mode 100644 index 0000000000..da8a4cf061 --- /dev/null +++ b/database/src/migrations/20240624000000_attachment_type_fix.ts @@ -0,0 +1,49 @@ +import { Knex } from 'knex'; + +/** + * Drop deprecated study_species.wldtaxonomic_units_id column. + * Drop deprecated survey.field_method_id column. + * + * Migrate outdated project_attachment.file_type and survey_attachment.file_type values: + * - Deprecated values 'Spatial Data' and 'Data File' are now 'Other'. + * + * @export + * @param {Knex} knex + * @return {*} {Promise} + */ +export async function up(knex: Knex): Promise { + await knex.raw(`--sql + ---------------------------------------------------------------------------------------- + -- Drop views + ---------------------------------------------------------------------------------------- + SET SEARCH_PATH=biohub_dapi_v1; + + DROP VIEW IF EXISTS study_species; + DROP VIEW IF EXISTS survey; + + ---------------------------------------------------------------------------------------- + -- Alter tables/data + ---------------------------------------------------------------------------------------- + SET SEARCH_PATH=biohub; + + -- Drop deprecated columns + ALTER TABLE study_species DROP COLUMN wldtaxonomic_units_id; + ALTER TABLE survey DROP COLUMN field_method_id; + + -- Migrate deprecated file_type values + UPDATE project_attachment SET file_type = 'Other' WHERE file_type NOT IN ('Other', 'KeyX', 'Report'); + UPDATE survey_attachment SET file_type = 'Other' WHERE file_type NOT IN ('Other', 'KeyX', 'Report'); + + ---------------------------------------------------------------------------------------- + -- Update views + ---------------------------------------------------------------------------------------- + SET SEARCH_PATH=biohub_dapi_v1; + + CREATE OR REPLACE VIEW study_species as SELECT * FROM biohub.study_species; + CREATE OR REPLACE VIEW survey as SELECT * FROM biohub.survey; + `); +} + +export async function down(knex: Knex): Promise { + await knex.raw(``); +} diff --git a/database/src/seeds/03_basic_project_survey_setup.ts b/database/src/seeds/03_basic_project_survey_setup.ts index ea98085d57..8756f40285 100644 --- a/database/src/seeds/03_basic_project_survey_setup.ts +++ b/database/src/seeds/03_basic_project_survey_setup.ts @@ -254,21 +254,16 @@ const insertSurveyFundingData = (surveyId: number) => ` */ const insertSurveyFocalSpeciesData = (surveyId: number) => { const focalSpecies = focalTaxonIdOptions[Math.floor(Math.random() * focalTaxonIdOptions.length)]; - const testValue = [ - 2012, 2013, 828, 2019, 1594, 1718, 2037, 2062, 2068, 2065, 2070, 2069, 23918, 23922, 23920, 35369, 35370, 28516 - ][Math.floor(Math.random() * 18)]; return ` INSERT into study_species ( survey_id, - wldtaxonomic_units_id, itis_tsn, is_focal ) VALUES ( ${surveyId}, - ${testValue}, ${focalSpecies.itis_tsn}, 'Y' ); @@ -632,15 +627,10 @@ const insertObservationSubCount = (surveyObservationId: number) => ` * */ const insertSurveyObservationData = (surveyId: number, count: number) => { - const testValue = [ - 2012, 2013, 828, 2019, 1594, 1718, 2037, 2062, 2068, 2065, 2070, 2069, 23918, 23922, 23920, 35369, 35370, 28516 - ][Math.floor(Math.random() * 18)]; - return ` INSERT INTO survey_observation ( survey_id, - wldtaxonomic_units_id, itis_tsn, itis_scientific_name, latitude, @@ -655,7 +645,6 @@ const insertSurveyObservationData = (surveyId: number, count: number) => { VALUES ( ${surveyId}, - ${testValue}, $$${focalTaxonIdOptions[0].itis_tsn}$$, $$${focalTaxonIdOptions[0].itis_scientific_name}$$, $$${faker.number.int({ min: 48, max: 60 })}$$,