mirror of https://github.com/Chocobozzz/PeerTube
				
				
				
			
		
			
				
	
	
		
			112 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
import { DestroyOptions, Op, Transaction } from 'sequelize'
 | 
						|
import { AllowNull, BelongsTo, Column, CreatedAt, ForeignKey, IsInt, Model, Table, UpdatedAt } from 'sequelize-typescript'
 | 
						|
import { MUserAccountId, MUserId } from '@server/types/models'
 | 
						|
import { AttributesOnly } from '@shared/typescript-utils'
 | 
						|
import { VideoModel } from '../video/video'
 | 
						|
import { UserModel } from './user'
 | 
						|
 | 
						|
@Table({
 | 
						|
  tableName: 'userVideoHistory',
 | 
						|
  indexes: [
 | 
						|
    {
 | 
						|
      fields: [ 'userId', 'videoId' ],
 | 
						|
      unique: true
 | 
						|
    },
 | 
						|
    {
 | 
						|
      fields: [ 'userId' ]
 | 
						|
    },
 | 
						|
    {
 | 
						|
      fields: [ 'videoId' ]
 | 
						|
    }
 | 
						|
  ]
 | 
						|
})
 | 
						|
export class UserVideoHistoryModel extends Model<Partial<AttributesOnly<UserVideoHistoryModel>>> {
 | 
						|
  @CreatedAt
 | 
						|
  createdAt: Date
 | 
						|
 | 
						|
  @UpdatedAt
 | 
						|
  updatedAt: Date
 | 
						|
 | 
						|
  @AllowNull(false)
 | 
						|
  @IsInt
 | 
						|
  @Column
 | 
						|
  currentTime: number
 | 
						|
 | 
						|
  @ForeignKey(() => VideoModel)
 | 
						|
  @Column
 | 
						|
  videoId: number
 | 
						|
 | 
						|
  @BelongsTo(() => VideoModel, {
 | 
						|
    foreignKey: {
 | 
						|
      allowNull: false
 | 
						|
    },
 | 
						|
    onDelete: 'CASCADE'
 | 
						|
  })
 | 
						|
  Video: VideoModel
 | 
						|
 | 
						|
  @ForeignKey(() => UserModel)
 | 
						|
  @Column
 | 
						|
  userId: number
 | 
						|
 | 
						|
  @BelongsTo(() => UserModel, {
 | 
						|
    foreignKey: {
 | 
						|
      allowNull: false
 | 
						|
    },
 | 
						|
    onDelete: 'CASCADE'
 | 
						|
  })
 | 
						|
  User: UserModel
 | 
						|
 | 
						|
  static listForApi (user: MUserAccountId, start: number, count: number, search?: string) {
 | 
						|
    return VideoModel.listForApi({
 | 
						|
      start,
 | 
						|
      count,
 | 
						|
      search,
 | 
						|
      sort: '-"userVideoHistory"."updatedAt"',
 | 
						|
      nsfw: null, // All
 | 
						|
      displayOnlyForFollower: null,
 | 
						|
      user,
 | 
						|
      historyOfUser: user
 | 
						|
    })
 | 
						|
  }
 | 
						|
 | 
						|
  static removeUserHistoryElement (user: MUserId, videoId: number) {
 | 
						|
    const query: DestroyOptions = {
 | 
						|
      where: {
 | 
						|
        userId: user.id,
 | 
						|
        videoId
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    return UserVideoHistoryModel.destroy(query)
 | 
						|
  }
 | 
						|
 | 
						|
  static removeUserHistoryBefore (user: MUserId, beforeDate: string, t: Transaction) {
 | 
						|
    const query: DestroyOptions = {
 | 
						|
      where: {
 | 
						|
        userId: user.id
 | 
						|
      },
 | 
						|
      transaction: t
 | 
						|
    }
 | 
						|
 | 
						|
    if (beforeDate) {
 | 
						|
      query.where['updatedAt'] = {
 | 
						|
        [Op.lt]: beforeDate
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    return UserVideoHistoryModel.destroy(query)
 | 
						|
  }
 | 
						|
 | 
						|
  static removeOldHistory (beforeDate: string) {
 | 
						|
    const query: DestroyOptions = {
 | 
						|
      where: {
 | 
						|
        updatedAt: {
 | 
						|
          [Op.lt]: beforeDate
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    return UserVideoHistoryModel.destroy(query)
 | 
						|
  }
 | 
						|
}
 |